跳至主要内容

Mongo 入门

https://pymongo.readthedocs.io/en/stable/tutorial.html
https://www.mongodb.com/languages/python
https://zhuanlan.zhihu.com/p/51171906
https://www.runoob.com/python3/python-mongodb.html

https://hub.docker.com/_/mongo

安装 MongoDB

$ docker search mongo

启动一个mongo服务器实例

$ docker run --name some-mongo -d mongo:tag
some-mongo是您要分配给容器的名称,tag是指定您想要的 MongoDB 版本的标签
MongoDB 的默认数据目录路径是/data/db
如下:
$ docker run -it -v mongodata:/data/db -p 27017:27017 --name mongodb --restart unless-stopped -d mongo

你应该让 MongoDB 在端口 27017 上运行,并且可以通过localhostWindows 和 Ubuntu 20.04 上的URL访问
http://localhost:27017/

-pHOST_PORT:CLIENT_PORT  -P 随机端口
-p 27017:27017 :将容器的27017 端口映射到主机的27017 端口
-v mongodata:/data/db :将主机中当前目录下的db挂载到容器的/data/db,作为mongo数据存储目录

从另一个 Docker 容器连接到 MongoDB

镜像中的 MongoDB 服务器侦听标准 MongoDB 端口27017,因此通过 Docker 网络连接将与连接到远程mongod. 以下示例启动另一个 MongoDB 容器实例,并mongo针对上述示例中的原始 MongoDB 容器运行命令行客户端,从而允许您针对数据库实例执行 MongoDB 语句:

$ docker run -it --network some-network --rm mongo mongo --host some-mongo test
some-mongo是原始mongo容器的名称
some-network选择$ docker network ls 中的 host
$ docker run -it --network host --rm mongo mongo --host localhost test
> show databases
> exit

或着
$ docker exec -it mongodb bash
root@a81a363259ab:/# mongo
> show databases
> exit

web 管理数据库

$ docker run -d --name mongo-express -e ME_CONFIG_MONGODB_SERVER=host.docker.internal -p 8081:8081 mongo-express

https://docs.docker.com/docker-for-windows/networking/

我想从容器连接到主机上的服务

主机有一个不断变化的 IP 地址(如果您没有网络访问权限,则没有)。我们建议您连接到host.docker.internal解析为主机使用的内部 IP 地址的特殊 DNS 名称 这是出于开发目的,不适用于 Docker Desktop for Windows 之外的生产环境。

您也可以使用 到达网关gateway.docker.internal

http://localhost:8081/

dangzenglong@DANG-PC:~$ docker port  mongodb
27017/tcp -> 0.0.0.0:27017
27017/tcp -> :::27017
dangzenglong@DANG-PC:~$ docker port  mongo-express
8081/tcp -> 0.0.0.0:8081
8081/tcp -> :::8081

shell访问容器和查看MongoDB日志

该docker exec命令允许您在 Docker 容器内运行命令。以下命令行将为您提供mongo容器内的 bash shell :
$ docker exec -it some-mongo bash
如下:
$ docker exec -it mongodb bash
root@a81a363259ab:/# mongo
> show databases
> exit

MongoDB 服务器日志可通过 Docker 的容器日志获得:

$ docker logs some-mongo
如下:
$  docker logs mongodb

如有以下报错:
docker: Error response from daemon: Ports are not available: listen tcp 0.0.0.0:8081: bind: An attempt was made to access a socket in a way forbidden by its access permissions.

https://github.com/docker/for-win/issues/3171

在 Windows 上启用 Hyper-V 时,会保留许多动态端口,所以其他应用程序无法监听在这个端口。

首先,检查您所需的端口是否已保留
PS C:\Users\DANG> netsh interface ipv4 show excludedportrange protocol=tcp

如果您的端口在其中一个范围内,请停止 winnat:
PS C:\Users\DANG> net stop winnat

禁止对您所需的端口进行动态保留(例如,原始问题中所述的 50051):
PS C:\Users\DANG> netsh int ipv4 add excludedportrange protocol=tcp startport=50051 numberofports=1
Start your docker services

重启winnat:
PS C:\Users\DANG> net start winnat


通过组件安装

运行此命令以下载 Docker Compose 的当前稳定版本:

$ sudo curl -L "https://github.com/docker/compose/releases/download/1.29.2/docker-compose-$(uname -s)-$(uname -m)" -o /usr/local/bin/docker-compose
要安装不同版本的 Compose,请替换1.29.2 为您要使用的 Compose 版本。

对二进制文件应用可执行权限:

$ sudo chmod +x /usr/local/bin/docker-compose
注意:如果docker-compose安装后命令失败,请检查您的路径。您还可以/usr/bin在路径中创建指向或任何其他目录的符号链接。
例如:$ sudo ln -s /usr/local/bin/docker-compose /usr/bin/docker-compose

测试安装

$ docker-compose --version

升级

如果您从 Compose 1.2 或更早版本升级,请在升级 Compose 后移除或迁移现有容器。这是因为,从 1.3 版开始,Compose 使用 Docker 标签来跟踪容器,并且需要重新创建容器以添加标签。

如果 Compose 检测到创建时没有标签的容器,它会拒绝运行,这样您就不会得到两组。如果您想继续使用现有容器(例如,因为它们有您想要保留的数据卷),您可以使用 Compose 1.5.x 使用以下命令迁移它们:
$ docker-compose migrate-to-labels

或者,如果您不担心保留它们,则可以删除它们。Compose 只是创建新的。
$ docker container rm -f -v myapp_web_1 myapp_db_1 ...

卸载

如果您使用curl以下方式安装,则卸载 Docker Compose :
sudo rm /usr/local/bin/docker-compose

如果您使用pip以下方式安装,则卸载 Docker Compose :
pip uninstall docker-compose

收到“权限被拒绝”(Permission denied )错误?
如果您使用上述任一方法收到“权限被拒绝”错误,您可能没有适当的权限来删除 docker-compose. 要强制删除,请sudo添加上述任一命令并再次运行。

从同一个 docker-compose 启动 Mongo 和 Mongo-Express

via docker stack deploy or docker-compose
Example stack.yml for mongo:

# Use root/example as user/password credentials
version: '3.1'

services:

  mongo:
    image: mongo
    restart: always
    environment:
      MONGO_INITDB_ROOT_USERNAME: root
      MONGO_INITDB_ROOT_PASSWORD: example

  mongo-express:
    image: mongo-express
    restart: always
    ports:
      - 8081:8081
    environment:
      ME_CONFIG_MONGODB_ADMINUSERNAME: root
      ME_CONFIG_MONGODB_ADMINPASSWORD: example
      ME_CONFIG_MONGODB_URL: mongodb://root:example@mongo:27017/

运行docker stack deploy -c stack.yml mongo(或docker-compose -f stack.yml up),等待它完全初始化,然后访问http://swarm-ip:8081、http://localhost:8081、 或http://host-ip:8081

version: '3'

services:
    mongo:
        image: mongo
        environment:
            - MONGO_INITDB_ROOT_USERNAME=${MONGO_ROOT_USER}
            - MONGO_INITDB_ROOT_PASSWORD=${MONGO_ROOT_PASSWORD}
            - MONGO_INITDB_DATABASE=project
    mongo-express:
        image: mongo-express
        environment:
            - ME_CONFIG_MONGODB_SERVER=mongo
            - ME_CONFIG_MONGODB_PORT=27017
            - ME_CONFIG_MONGODB_ENABLE_ADMIN=false
            - ME_CONFIG_MONGODB_AUTH_DATABASE=admin
            - ME_CONFIG_MONGODB_AUTH_USERNAME=${MONGO_ROOT_USER}
            - ME_CONFIG_MONGODB_AUTH_PASSWORD=${MONGO_ROOT_PASSWORD}
            - ME_CONFIG_BASICAUTH_USERNAME=${MONGOEXPRESS_LOGIN}
            - ME_CONFIG_BASICAUTH_PASSWORD=${MONGOEXPRESS_PASSWORD}
        depends_on:
            - mongo
        ports:
          - 8080:8081

og .env filen:

MONGO_ROOT_USER=devroot
MONGO_ROOT_PASSWORD=devroot
MONGOEXPRESS_LOGIN=dev
MONGOEXPRESS_PASSWORD=dev

评论

此博客中的热门博文

MechanicalSoup

用于自动与网站交互的 Python 库。 MechanicalSoup 自动存储和发送 cookie,跟踪重定向,并且可以跟踪链接和提交表单。 它不执行 JavaScript。 https://github.com/MechanicalSoup/MechanicalSoup https://mechanicalsoup.readthedocs.io/en/stable/index.html https://realpython.com/python-web-scraping-practical-introduction/ pip show Mechanicalsoup 找到模块的安装位置 https://stackoverflow.com/questions/54352162/download-file-with-mechanicalsoup # Install dependencies # pip install requests # pip install BeautifulSoup4 # pip install MechanicalSoup # Import libraries import mechanicalsoup import urllib.request import requests from bs4 import BeautifulSoup import re # Create a browser object that can collect cookies browser = mechanicalsoup.StatefulBrowser() browser.open("https://www.ons.gov.uk/economy/grossdomesticproductgdp/timeseries/l2kq/qna") browser.download_link(link_text=".xls",file="D:/ONS_Data.xls" )

端口映射 公网访问内网

https://portforward.com/ Holer 通过安全隧道将位于NAT和防火墙之后的本地服务器暴露给公共Internet。 Holer是一个将原型中的应用映射到公网访问的端口映射软件,支持转发基于TCP协议的报文 https://github.com/wisdom-projects/holer 方式一:使用(公告)的holer映射或者开通holer服务,通过holer客户端软件经 holer服务器实现公网访问。 公开的holer映射详情如下: 访问密钥 访问域名 公网地址 本地地址 使用场景 HOLER_CLIENT-2F8D8B78B3C2A0AE holer65530.wdom.net holer.org:65530 127.0.0.1:8080 网页 HOLER_CLIENT-3C07CDFD1BF99BF2 holer65531.wdom.net holer.org:65531 127.0.0.1:8088 网页 HOLER_CLIENT-2A623FCB6E2A7D1D holer65532.wdom.net holer.org:65532 127.0.0.1:80 网页 HOLER_CLIENT-AF3E6391525F70E4 不适用 holer.org:65533 127.0.0.1:3389 远程桌面 HOLER_CLIENT-822404317F9D8ADD 不适用 holer.org:65534 127.0.0.1:22 SSH协议 HOLER_CLIENT-27DD1389DF1D4DBC 不适用 holer.org:65535 127.0.0.1:3306 数据库 使用Java版本的holer客户端 ①java 1.7或者更高版本 ②下载holer-client.zip 修改配置文件C:\holer-client\conf\holer.conf HOLER_ACCESS_KEY=HOLER_CLIENT-2A623FCB6E2A7D1D HOLER_SERVER_HOST=holer65532.wdom.net ③建议先双击运行C:\holer-client\bin\shutdown.bat,再双击运行C:\holer-client\bin\startup.bat...