跳至主要内容

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

评论

此博客中的热门博文

端口映射 公网访问内网

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...

安装和卸载软件(msi\exe)

如何判断一个软件是64位的还是32位的? 情况1、 未安装--右键安装程序查看属性,兼容性,勾选兼容模式查看最低适配是vista的是64位,反之32位, 不太准确 情况2、 已安装--运行软件,64位操作系统打开任务管理器看进程后缀名,带*32就是32位,反之64位 https://www.joci.net/xxbk/126251/ FileMon 和 Regmon 不再可供下载。从Windows 2000 SP4,Windows XP SP2,Windows Server 2003 SP1和Windows Vista开始的Windows版本上,它们已被 Process Monitor 取代 https://adamtheautomator.com/procmon/ Process Monitor 是Windows的高级监视工具,它显示实时文件系统,注册表和进程/线程活动。 它结合了两个旧的Sysinternals实用程序 Filemon 和  Regmon的功能 ,并添加了广泛的增强功能列表,包括丰富的和非破坏性的过滤,全面的事件属性(例如会话ID和用户名),可靠的过程信息,带有集成符号的完整线程堆栈支持每个操作,同时记录到文件等。 它独特的强大功能将使Process Monitor成为您的系统故障排除和恶意软件搜索工具包中的核心实用程序。 https://wikileaks.org/ciav7p1/cms/page_42991626.html HKLM\Software\Microsoft\Cryptography\MachineGuid Machine GUID/Cryptography GUID---该密钥通常用作机器的唯一标识符。它也已用于将两台计算机链接在一起-在某些情况下,计算机GUID是与设备(MP3播放器等)一起传递的。 Machine GUID不是唯一 https://docs.microsoft.com/zh-cn/windows/win32/properties/props-system-identity-uniqueid?redirectedfrom=MSDN UniqueID才是唯一 注册表 是存储系统和应用程序的设置信息 打开注册表的方式很简单:cmd中输入regedit 卸载路径只有一个 已安装32位的程序,如果是系统是32位...