dokcer-compose方式部署 mongo集群

news/2025/2/24 0:56:35/文章来源:https://www.cnblogs.com/dzqdzq/p/18733172

声明:本人在单台机器上部署的mongo机器, mongo版本为8.0, 这玩意居然部署了一天,终于搞好了, 希望对后面想要部署的人有帮助

先创建一个mongodb目录, 后续的配置,数据都存放在这个目录中:

1. 创建mongo-secrets目录,mkdir  mongo-secrets

2. 创建keyfile文件, openssl rand -base64 756 > keyfile

3. 设置权限,所属组

chmod 600 mongo-secrets/keyfile

sudo chown 999:999 mongo-secrets/keyfile 

4. 创建docker-compose.yaml,如果你想用,请修改密码,将xxxxxx改成自己的。  文件如下: 

services:mongo1:image: mongo:latesthostname: mongo1container_name: mongo1restart: unless-stoppedenvironment:MONGO_INITDB_ROOT_USERNAME: adminMONGO_INITDB_ROOT_PASSWORD: xxxxxxxMONGO_REPLICA_SET_NAME: rs0volumes:- ./mongo1/data:/data/db- ./mongo-secrets/keyfile:/etc/mongo-secrets/keyfileports:- "27017:27017"networks:- mongo-cluster-netcommand: - mongod- --replSet=rs0- --bind_ip_all- --keyFile=/etc/mongo-secrets/keyfile- --authdepends_on:- mongo2- mongo3mongo2:image: mongo:latesthostname: mongo2container_name: mongo2restart: unless-stoppedenvironment:MONGO_INITDB_ROOT_USERNAME: adminMONGO_INITDB_ROOT_PASSWORD: xxxxxxxMONGO_REPLICA_SET_NAME: rs0volumes:- ./mongo2/data:/data/db- ./mongo-secrets/keyfile:/etc/mongo-secrets/keyfilenetworks:- mongo-cluster-netcommand: - mongod- --replSet=rs0- --bind_ip_all- --keyFile=/etc/mongo-secrets/keyfile- --authmongo3:image: mongo:latesthostname: mongo3container_name: mongo3restart: unless-stoppedenvironment:MONGO_INITDB_ROOT_USERNAME: adminMONGO_INITDB_ROOT_PASSWORD: xxxxxxxMONGO_REPLICA_SET_NAME: rs0volumes:- ./mongo3/data:/data/db- ./mongo-secrets/keyfile:/etc/mongo-secrets/keyfilenetworks:- mongo-cluster-netcommand: - mongod- --replSet=rs0- --bind_ip_all- --keyFile=/etc/mongo-secrets/keyfile- --authnetworks:mongo-cluster-net:driver: bridge

5. 运行: docker-compose up -d

6. 查看结果:docker-compose ps -a

 状态一定要注意: 是Up状态,而不是restart状态。
7. 初始化集群

docker-compose exec mongo1 mongosh --username admin --password xxxxxx --authenticationDatabase admin --eval 'rs.initiate({_id: "rs0", members: [{_id: 0, host: "mongo1:27017"}, {_id: 1, host: "mongo2:27017"}, {_id: 2, host: "mongo3:27017"}]})'
 
8. 查看集群状态:
sleep 5 && docker-compose exec mongo1 mongosh --username admin --password xxxxxxx --authenticationDatabase admin --eval 'rs.status()'

9. 目录结构如下:

 10. 状态如下, 太长了(部分截图)

 

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.hqwc.cn/news/888641.html

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

两个终端小玩具:Yazi和elinks

1. 终端文件管理器yazi 可以很方便地查找文件,跳转,并且很容易看出文件 1.1 下载安装 参考官方地址:鸭子官方安装手册安装rust编译环境curl --proto =https --tlsv1.2 -sSf https://sh.rustup.rs | sh rustup update编译yazigit clone https://github.com/sxyazi/yazi.git c…

两个终端小玩具

1. 终端浏览器 1.1 m3w 1.2 elinks 2. 终端文件管理器yazi 可以很方便地查找文件,跳转,并且很容易看出文件 2.1 下载安装 参考官方地址:鸭子官方安装手册安装rust编译环境curl --proto =https --tlsv1.2 -sSf https://sh.rustup.rs | sh rustup update编译yazigit clone htt…

用大模型DeepSeek分析一篇小公司创业失败的文章,失败的原因有哪些?

第一步:把原文保存为Doc格式文档 原本我想直接让 DeepSeek 分析链接的文章,但是两次写提示词后让 DeepSeek 深度分析,都失败了,它说无法直接访问,所以就无法直接分析原文内容。但还是基于搜索的结果进行普遍原因分析。 于是就把原文直接保存为 Doc,上传到 DeepSeek 让它分…

Markdowm学习

标题 二级标题 三级标题 四级标题 五级标题 六级标题 (#*n+空格+标题内容+回车——n级标题 注:此方法最多为六级标题) 字体样式 Hello World (两边加**为粗体) Hello World (两边加*为斜体) Hello World (两边加***为粗体+斜体) Hello World (两边加~~为删除线) 引用h…

区块链模型原理入门学习2——细化模型

以上描述中,存在一些非生产情景的理想化设定。比如:1.没有设计谜题难度平衡 2.没有加入加密校验数字签证 3.没有设计个人钱包 4.广播问题【敬畏能量 敬畏自然】

upload-labs/Pass-12 白名单检测 - %00 截断 GET

save_path 为客户端向服务器端传递的额外信息,可能用此参数指定上传文件的保存目录将save_path 更改为../upload/test.php%00 filename=test.png,filename 的后缀名需要满足白名单 路径和文件名组合在一起会变成../upload/test.php%00test.png , 后缀名满足白名单那么文件就…

upload-labs/Pass-13 白名单检测 - %00 截断 POST

POST 数据包的路径在请求体中在请求体中添加文件名称test.php, 但是不能像GET请求的数据包一样直接添加%00 了,我们需要直接在hex 中将标记修改为00;同时记得把文件名修改为可以上传的后缀重放数据包即可成功绕过上传

upload-labs/Pass-14 Pass-15 图片码绕过

copy .\test.png/b+.\test.php/a kb.png /b:以二进制模式 读取文件 .\test.png /b:以二进制读取test.png /a:以 ASCII 文本模式 读取文件,遇到第一个 EOF(文件结束符,如 0x1A)时停止读取。 .\as.php /a:以 ASCII 文本模式 读取as.php +:表示合并操作,将多个文件内容拼…

upload-labs/Pass-07 黑名单检测 -空格绕过

代码中没有对文件左右两侧去除空格,在文件名后面添加空格不影响文件执行,因此可以绕过

upload-labs/Pass-06 黑名单检测 - 后缀大小写绕过

利用Windows对大小写不敏感的特性。代码中没有对文件大小写做归一,更改文件后缀名大小写可以绕过黑名单

upload-labs/Pass-05 Pass-10 黑名单检测 - 点空格点绕过

利用Windows系统的文件名特性,会自动去掉后缀名最后的.,上传 as.php..进行绕过。 在Windows系统下命名test.php. . ; 命名成功后显示的文件名称为test.php在BP 中更改文件名,文件上传成功访问文件成功 3. 代码分析:删除文件名最后的点之后,以字符串最后的点为分界线,点之…

jvm调优_内存泄漏诊断

1️⃣ 使用Spring Boot模拟场景:注入List持续添加数据(内存泄漏源) 2️⃣ Arthas实时分析: heapdump生成 → MAT导入 → 定位Dominator Tree 3️⃣ 修复验证: 优化弱引用缓存 → GC后观察对象回收实例代码通过api接口不断访问增加元空间的内存 启动 arthas 查看内存或使用…