既然有了主从复制,为啥又出来个副本集?一个东西的出现,肯定存在一种东西被解救。所谓一物降一物O(_)O 上文中说道主从复制缺点主服务器出现故障,从服务器是干瞪眼。这篇文章就要解说,主仆之间会有一个怎样的变化? 仍然是一台电脑工作。步骤如下: 1.准
既然有了主从复制,为啥又出来个副本集?一个东西的出现,肯定存在一种东西被解救。所谓一物降一物O(∩_∩)O 上文中说道主从复制缺点—主服务器出现故障,从服务器是干瞪眼。这篇文章就要解说,主仆之间会有一个怎样的变化?
仍然是一台电脑工作。步骤如下:
节点1: HOST:localhost:10001 Log File:e:\mastersavle\logs\node1\logs.txt Data File:E:\mastersavle\dbs\node1 节点2: HOST:localhost:10002 Log File:E:\mastersavle\logs\node2\logs.txt Data File:E:\mastersavle\dbs\node2 节点3: HOST:localhost:10003 Log File:E:\mastersavle\logs\node3\logs.txt Data File:E:\mastersavle\dbs\node3
mongod --dbpath E:\mastersavle\dbs\node1 --logpath E:\mastersavle\logs\node1\logs.txt --logappend --port 10001 --replSet itcast/localhost:10002 --master启动节点1中:replSet指定副本集名称,后面是可选参数。说明该副本集群中还有10002数据库。
mongod --dbpath E:\mastersavle\dbs\node2 --logpath E:\mastersavle\logs\node2\logs.txt --logappend --port 10002 --replSet itcast/localhost:10001启动节点2中日志:
mongod --dbpath E:\mastersavle\dbs\node3 --logpath E:\mastersavle\logs\node3\logs.txt --logappend --port 10003 --replSet itcast/localhost:10001,localhost:10002其中启动节点3时,可以只指定副本集中的一个服务,或同时指定。副本集的一个特性为:自动检测,你仅指定单台服务器后,MongoDB会自动搜索并连接到同一副本集的其余的节点。其中节点3中日志:
db.runCommand({"replSetInitiate":{"_id":"itcast","members":[{"_id":1,"host":"localhost:10001","priority":3},{"_id":2,"host":"localhost:10002","priority":2},{"_id":3,"host":"localhost:10003","priority":1}]}});"_id":“itcast", 指副本集的名称 "members":[...] 副本集的服务器列表 每个列表有个 "_id": 每个服务器的唯一id, "host" 指定服务器的主机, “priority”设置优先级,默认优先级为1,可以是1-1000的数字,数字越大,优先级越高。