xshell7 vmware16 centos8 nosql booster
为了降低资源分配,这里仅使用一台服务器,但是分配3个端口(27017、27018、27019)来分别实现 主节点、副本节点、和仲裁节点的功能。副本集各服务器的基本信息及角色分配如下
虚拟机 | ip地址 | 成员角色 | 主机名 |
nosql_01 | 192.168.22.100 | 主节点 | Server01 |
nosql_02 | 192.168.22.100 | 副本节点 | server01 |
nosql_03 | 192.168.22.100 | 仲裁节点 | server01 |
所有节点的存放数据和日志的目录请放在/usr/local/mongodb/replica_sets路径下:
操作代码:
#1、主节点,建立存放数据和日志的目录(代码粘贴下方):
- mkdir -p /usr/local/mongodb/replica_sets/myrs_27017/logs \ & mkdir -p
- /usr/local/mongodb/replica_sets/myrs_27017/data/db
#2、新建或修改配置文件(代码粘贴下方):
vi /usr/local/mongodb/replica_sets/myrs_27017/mongod.conf
#3、mongod.conf配置文件中的内容,副本集的名称使用姓名全拼+rs,例如replSetName:
LiMingrs(代码粘贴下方):
- systemLog:
- #MongoDB发送所有日志输出的目标指定为文件
- ##The path of the log file to which mongod or mongos should send all
- diagnostic logging information
- destination: file
- #mongod或mongos应向其发送所有诊断日志记录信息的日志文件的路径
- path: "/usr/local/mongodb/replica_sets/myrs_27017/logs/mongologs.log"
- #当mongos或mongod实例重新启动时,mongos或mongod会将新条目附加到现有日志文件的末尾。
- logAppend: true
- storage:
- #mongod实例存储其数据的目录。storage.dbPath设置仅适用于mongod。
- ##The directory where the mongod instance stores its data.Default Value is
- "/data/db".
- dbPath: "/usr/local/mongodb/replica_sets/myrs_27017/data/db"
- journal:
- #启用或禁用持久性日志以确保数据文件保持有效和可恢复。
- enabled: true
- processManagement:
- #启用在后台运行mongos或mongod进程的守护进程模式。
- fork: true
- #指定用于保存mongos或mongod进程的进程ID的文件位置,其中mongos或mongod将写入其PID
- pidFilePath: "/usr/local/mongodb/replica_sets/myrs_27017/logs/mongod.pid"
- net:
- #服务实例绑定所有IP,有副作用,副本集初始化的时候,节点名字会自动设置为本地域名,而不是ip
- #bindIpAll: true
- #服务实例绑定的IP
-
- bindIp: localhost,192.168.22.100
- #bindIp
- #绑定的端口,默认是27017
- port: 27017
- replication:
- #副本集的名称
- replSetName: wuweixianrs
#4、启动节点服务:
mongod -f /usr/local/mongodb/replica_sets/myrs_27017/mongod.conf
#1、副本节点,建立存放数据和日志的目录(代码粘贴下方):
- mkdir -p /usr/local/mongodb/replica_sets/myrs_27018/logs \ & mkdir -p /usr/local/mongodb/replica_sets/myrs_27018/data/db
-
#2、新建或修改配置文件(代码粘贴下方):
vi /usr/local/mongodb/replica_sets/myrs_27018/mongod.conf
#3、mongod.conf配置文件中的内容,副本集的名称使用姓名全拼+rs,例如replSetName: LiMingrs(代码粘贴下方):
- systemLog:
- #MongoDB发送所有日志输出的目标指定为文件
- ##The path of the log file to which mongod or mongos should send all
- diagnostic logging information
- destination: file
- #mongod或mongos应向其发送所有诊断日志记录信息的日志文件的路径
- path: "/usr/local/mongodb/replica_sets/myrs_27018/logs/mongologs.log"
- #当mongos或mongod实例重新启动时,mongos或mongod会将新条目附加到现有日志文件的末尾。
- logAppend: true
- storage:
- #mongod实例存储其数据的目录。storage.dbPath设置仅适用于mongod。
- ##The directory where the mongod instance stores its data.Default Value is
- "/data/db".
- dbPath: "/usr/local/mongodb/replica_sets/myrs_27018/data/db"
- journal:
- #启用或禁用持久性日志以确保数据文件保持有效和可恢复。
- enabled: true
- processManagement:
- #启用在后台运行mongos或mongod进程的守护进程模式。
- fork: true
- #指定用于保存mongos或mongod进程的进程ID的文件位置,其中mongos或mongod将写入其PID
- pidFilePath: "/usr/local/mongodb/replica_sets/myrs_27018/logs/mongod.pid"
- net:
- #服务实例绑定所有IP,有副作用,副本集初始化的时候,节点名字会自动设置为本地域名,而不是ip
- #bindIpAll: true
- #服务实例绑定的IP
- bindIp: localhost,192.168.22.100
- #bindIp
- #绑定的端口,默认是27018
- port: 27018
- replication:
- #副本集的名称
- replSetName: wuweixianrs
#4、启动节点服务:
mongod -f /usr/local/mongodb/replica_sets/myrs_27018/mongod.conf
#1、仲裁节点,建立存放数据和日志的目录(代码粘贴下方):
mkdir -p /usr/local/mongodb/replica_sets/myrs_27019/logs \ & mkdir -p /usr/local/mongodb/replica_sets/myrs_27019/data/db
#2、新建或修改配置文件(代码粘贴下方):
vi /usr/local/mongodb/replica_sets/myrs_27019/mongod.conf
#3、mongod.conf配置文件中的内容,副本集的名称使用姓名全拼+rs,例如replSetName: LiMingrs(代码粘贴下方):
- systemLog:
- #MongoDB发送所有日志输出的目标指定为文件
- ##The path of the log file to which mongod or mongos should send all
- diagnostic logging information
- destination: file
- #mongod或mongos应向其发送所有诊断日志记录信息的日志文件的路径
- path: "/usr/local/mongodb/replica_sets/myrs_27019/logs/mongologs.log"
- #当mongos或mongod实例重新启动时,mongos或mongod会将新条目附加到现有日志文件的末尾。
- logAppend: true
- storage:
- #mongod实例存储其数据的目录。storage.dbPath设置仅适用于mongod。
- ##The directory where the mongod instance stores its data.Default Value is
- "/data/db".
- dbPath: "/usr/local/mongodb/replica_sets/myrs_27019/data/db"
- journal:
- #启用或禁用持久性日志以确保数据文件保持有效和可恢复。
- enabled: true
- processManagement:
- #启用在后台运行mongos或mongod进程的守护进程模式。
- fork: true
- #指定用于保存mongos或mongod进程的进程ID的文件位置,其中mongos或mongod将写入其PID
- pidFilePath: "/usr/local/mongodb/replica_sets/myrs_27019/logs/mongod.pid"
- net:
- #服务实例绑定所有IP,有副作用,副本集初始化的时候,节点名字会自动设置为本地域名,而不是ip
- #bindIpAll: true
- #服务实例绑定的IP
- bindIp: localhost,192.168.22.100
- #bindIp
- #绑定的端口,默认是27019
- port: 27019
- replication:
- #副本集的名称
- replSetName: wuweixianrs
-
#4、启动节点服务:
mongod -f /usr/local/mongodb/replica_sets/myrs_27019/mongod.conf
执行 ps -ef|grep mongod 查看端口是否已启动服务
使用客户端命令连接任意一个节点,但这里尽量要连接主节点(27017节点):
mongo --port=27017
rs.conf()
rs.add("192.168.22.100:27018")
rs.addArb("192.168.22.100:27019"
mongo --host=192.168.22.100 --port=27017
使用mongo shell 登录从节点,读取测试数据
mongo --host=192.168.22.100 --port=27018