Mongodb复制集的安装和部署

Mongodb复制集由一组Mongod实例(进程)组成,包含一个Primary节点和多个Secondary节点,Mongodb Driver(客户端)的所有数据都写入Primary,Secondary从Primary同步写入的数据,以保持复制集内所有成员存储相同的数据集,提供数据的高可用。

准备工作

软件环境

OS:Oracle Linux 6.5

MongoDB:mongodb3.2.3

部署架构

模拟有三台服务器

10.1.5.123:28001 主节点

10.1.5.123:28002 从节点

10.1.5.123:28003 选举节点

复制集架构:一主,一从,一选举节点

下载安装

下载地址:https://www.mongodb.org/downloads

mongodb-linux-x86_64-rhel62-3.2.3.tgz

部署步骤

1.创建目录及用户

[root@devtest mongodb]# mkdir conf data log

[root@devtest data]# mkdir 28001 28002 28003

--创建mongo用户

[root@devtest conf]# groupadd mongod

[root@devtest conf]# useradd -g mongod mongod

2.创建配置文件 –配置三个实例的配置文件(修改相应的端口号即可)

–节点1

$ vi /home/mongod/mongodb3.2.3/conf/28001.conf

port=28001

bind_ip=10.1.5.123

logpath=/home/mongod/mongodb3.2.3/log/28001.log

dbpath=/home/mongod/mongodb3.2.3/data/28001/

logappend=true

pidfilepath=/home/mongod/mongodb3.2.3/data/28001/28001.pid

fork=true

oplogSize=1024

replSet=MyMongo

–节点2

$ vi /home/mongod/mongodb3.2.3/conf/28002.conf

port=28002

bind_ip=10.1.5.123

logpath=/home/mongod/mongodb3.2.3/log/28002.log

dbpath=/home/mongod/mongodb3.2.3/data/28002/

logappend=true

pidfilepath=/home/mongod/mongodb3.2.3/data/28002/28002.pid

fork=true

oplogSize=1024

replSet=MyMongo

–节点3

$ vi /home/mongod/mongodb3.2.3/conf/28003.conf

port=28003

bind_ip=10.1.5.123

logpath=/home/mongod/mongodb3.2.3/log/28003.log

dbpath=/home/mongod/mongodb3.2.3/data/28003/

logappend=true

pidfilepath=/home/mongod/mongodb3.2.3/data/28003/28003.pid

fork=true

oplogSize=1024

replSet=MyMongo

3.启动mongo复制集

$ mongod -f /home/mongod/mongodb3.2.3/conf/28001.conf

$ mongod -f /home/mongod/mongodb3.2.3/conf/28002.conf

$ mongod -f /home/mongod/mongodb3.2.3/conf/28003.conf

4.初始化复制集

[mongod@devtest ~]$ mongo 10.1.5.123:28001/admin

MongoDB shell version: 3.2.3

connecting to: 10.1.5.123:28001/admin

Welcome to the MongoDB shell.

For interactive helptype"help".

For more comprehensive documentation, see

•    http://docs.mongodb.org/

Questions? Try the support group

  http://groups.google.com/group/mongodb-user

\> db

admin

\> config = {

... "_id":"MyMongo",

... members:[

...{"_id":0,host:"10.1.5.123:28001"},

...{"_id":1,host:"10.1.5.123:28002"},

... {"_id":2,host:"10.1.5.123:28003"}]

... }

{

  "id" : "MyMongo",

  "members" : [

•        {

•            "_id" : 0,

•            "host" :"10.1.5.123:28001"

•        },

•        {

•            "_id" : 1,

•            "host" :"10.1.5.123:28002"

•        },

•        {

•            "_id" : 2,

•            "host" :"10.1.5.123:28003"

•        }

  ]

}

–查看复制集成员

\> config.members

[

  {

•        "_id" : 0,

•        "host" :"10.1.5.123:28001"

  },

  {

•        "_id" : 1,

•        "host" :"10.1.5.123:28002"

  },

  {

•        "_id" : 2,

•        "host" :"10.1.5.123:28003"

  }

]

–把节点3修改为arbiter选举节点

\> config.members[2]

{ "_id" : 2, "host" :"10.1.5.123:28003" }

\> config.members[2] ={"_id":2,"host":"10.1.5.123:28003",arbiterOnly:true}

{ "id" : 0, "host" :"10.1.5.123:28003""arbiterOnly" : true }

–进行复制集初始化

\> rs.initiate(config)

{ "ok" : 1 }

–查看复制集状态

MyMongo:OTHER> rs.status()

{

•    "set" : "MyMongo",

•    "date" :ISODate("2016-03-15T09:42:47.643Z"),

•    "myState" : 1,

•    "term" : NumberLong(1),

•    "heartbeatIntervalMillis" :NumberLong(2000),

•    "members" : [

•        {

•            "_id" : 0,

•            "name" :"10.1.5.123:28001",

•            "health" : 1,

•            "state" : 1,

•            "stateStr" :"PRIMARY",

•            "uptime" :1812,

•            "optime" : {

•                "ts": Timestamp(1458034899, 1),

•                "t" :NumberLong(1)

•            },

•            "optimeDate": ISODate("2016-03-15T09:41:39Z"),

•            "infoMessage""could not find member to sync from",

•           "electionTime" : Timestamp(1458034898, 1),

•            "electionDate": ISODate("2016-03-15T09:41:38Z"),

•           "configVersion" : 1,

•            "self" : true

•        },

•        {

•            "_id" : 1,

•            "name" :"10.1.5.123:28002",

•            "health" : 1,

•            "state" : 2,

•            "stateStr" :"SECONDARY",

•            "uptime" :80,

•            "optime" : {

•                "ts": Timestamp(1458034899, 1),

•                "t" :NumberLong(1)

•            },

•            "optimeDate": ISODate("2016-03-15T09:41:39Z"),

•           "lastHeartbeat" :ISODate("2016-03-15T09:42:46.947Z"),

•            "lastHeartbeatRecv" :ISODate("2016-03-15T09:42:46.445Z"),

•            "pingMs" :NumberLong(0),

•            "syncingTo" :"10.1.5.123:28001",

•           "configVersion" : 1

•        },

•        {

•            "_id" : 2,

•            "name" :"10.1.5.123:28003",

•            "health" : 1,

•            "state" : 7,

•            "stateStr" :"ARBITER",

•            "uptime" :80,

•           "lastHeartbeat" :ISODate("2016-03-15T09:42:46.946Z"),

•           "lastHeartbeatRecv" :ISODate("2016-03-15T09:42:44.428Z"),

•            "pingMs" :NumberLong(0),

•            "configVersion": 1

•        }

•    ],

•    "ok" : 1

}

MyMongo:PRIMARY>

\5. 验证复制集同步 分别登录两从节点查看登录状态,分别为secondary和arbite

下面登录从secondary节点进行测试:

在从节点进行查询时报下面的错误,因为在默认情况下,不通过驱动连接mongodb从节点数据库时,如果不开始slaveOK=true,是无法读取从节点数据的。

[mongod@devtest conf]$ mongo10.1.5.123:28002/admin

MongoDB shell version: 3.2.3

connecting to:10.1.5.123:28002/admin

MyMongo:SECONDARY> show dbs

2016-03-15T17:49:47.854+0800 EQUERY  [thread1] Error: listDatabasesfailed:{ "ok" : 0, "errmsg" : "not master andslaveOk=false""code" : 13435 } :

_getErrorWithCode@src/mongo/shell/utils.js:23:13

Mongo.prototype.getDBs@src/mongo/shell/mongo.js:53:1

shellHelper.show@src/mongo/shell/utils.js:700:19

shellHelper@src/mongo/shell/utils.js:594:15

@(shellhelp2):1:1

MyMongo:SECONDARY>rs.slaveOk(true)

MyMongo:SECONDARY> show dbs

local 0.000GB

test 0.000GB

MyMongo:SECONDARY> use test

switched to db test

MyMongo:SECONDARY> showtables

t1

MyMongo:SECONDARY>db.t1.find()

{ "_id" :ObjectId("56e7dc310ebd75f9ef3546c1"), "name" :"licz" }

下面登录从arbite节点进行测试:

然后登录arbite节点,会发现数据没有同步,因为arbite不参与数据库的同步,即不存储数据

但local数据库大小已经改变了,因为local库存储命名空间(local.ns文件)的内容。

MyMongo:ABITER> rs.slaveOk(true)

MyMongo:ARBITER> show dbs

local 0.000GB

6.模拟主-从故障切换 –杀掉当前主节点为28001端口

[mongod@devtest ~]$ ps -ef|grep mongo

root  7186 7150 0 09:15 pts/2  00:00:00 su - mongod

mongod 7187 7186 0 09:15 pts/2  00:00:00 -bash

mongod 7306 7187 0 09:16 pts/2  00:00:00 ps -ef

mongod 7307 7187 0 09:16 pts/2  00:00:00 grep mongo

mongod 16253  1 2 Mar15 ?    00:22:00 mongod -f/home/mongod/mongodb3.2.3/conf/28001.conf

mongod 16299  1 2 Mar15 ?    00:21:50 mongod -f/home/mongod/mongodb3.2.3/conf/28002.conf

mongod 16345  1 2 Mar15 ?    00:20:05 mongod -f/home/mongod/mongodb3.2.3/conf/28003.conf

[mongod@devtest ~]$ kill -9 16253

–发现主节点已经切换至28002端口

[mongod@devtest ~]$ mongo 10.1.5.123:28002/admin

MongoDB shell version: 3.2.3

connecting to: 10.1.5.123:28002/admin

MyMongo:PRIMARY>

–再次启动28001端口并登录,发现28001已为从节点

[mongod@devtest ~]$ mongod -f /home/mongod/mongodb3.2.3/conf/28001.conf

about to fork child process, waiting untilserver is ready for connections.

forked process: 21410

child process started successfully, parentexiting

[mongod@devtest ~]$ mongo 10.1.5.123:28001/admin          

MongoDB shell version: 3.2.3

connecting to: 10.1.5.123:28001/admin

MyMongo:SECONDARY>

原创文章,作者:晴川运维,如若转载,请注明出处:https://baike.qcidc.com/10098.html

(0)
晴川运维晴川运维
上一篇 3小时前
下一篇 3小时前

相关推荐

  • Linux内核(内核模块)的加载过程(超详细)

    GRUB 加载了内核之后,内核首先会再进行二次系统的自检,而不一定使用 BIOS 检测的硬件信息。这时内核终于开始替代 BIOS 接管 linux 的启动过程了。 内核完成再次系统…

    Linux系统 2025年6月8日
  • 在 Fedora 上为 SSH 设置双因子验证

    每天似乎都有一个安全漏洞的新闻报道,说我们的数据会因此而存在风险。尽管 SSH 是一种远程连接系统的安全方式,但你仍然可以使它更安全。本文将向你展示如何做到这一点。 此时双因子验证…

    Linux系统 2025年6月9日
  • 详解grep命令的排除功能

    grep命令是linux中一种强大的文本搜索工具,它能使用正则表达式搜索文本,并把匹配的行打印出来。 在一个或多个文件中搜素字符串模式,如果字符串模式包括空格,也必须被引用,模式后…

    Linux系统 2025年6月8日
  • 详解Python虚拟环境virtualenv

    VirtualEnv用于在一台机器上创建多个独立的python运行环境,VirtualEnvWrapper为前者提供了一些便利的命令行上的封装。 了解虚拟环境 如果在一台机器上,想…

    Linux系统 2天前
  • Linux下使用free命令查看内存使用情况

    free命令可以显示当前系统未使用的和已使用的内存数目,还可以显示被内核使用的内存缓冲区,下面为大家详细讲解一下 free命令使用实例。 显示系统内存 不带任何选项运行 free …

    Linux系统 2025年6月8日
  • 初次登录 Linux 服务器马上要做的 9 件事

    在将新配置的服务器投入工作之前,请确保你知道你正在使用什么。 当我在 linux 上测试软件时(这是我工作中的一个常规部分),我需要使用多台运行 Linux 的不同架构的服务器。我…

    Linux系统 1天前
  • CentOS7中安装Weblogic具体步骤

    WebLogic是美国Oracle公司出品的一个application server确切的说是一个基于JAVAEE架构的中间件,BEA WebLogic是用于开发、集成、部署和管理…

    Linux系统 2025年6月8日
  • 讲解一下缓存系统三座大山

    缓存在计算机系统是无处不在,在CPU层面有L1-L3的Cache,在Linux中有TLB加速虚拟地址和物理地址的转换,在浏览器有本地缓存、手机有本地缓存等。 1.无处不在的缓存 缓…

    Linux系统 2025年6月8日
  • 讲解一下ES6 async关键字的使用方法

    async 作为一个关键字放到函数前面,用于表示函数是一个异步函数,因为async就是异步的意思, 异步函数也就意味着该函数的执行不会阻塞后面代码的执行。 async 语法 asy…

    Linux系统 2025年6月12日
  • Python退出时强制运行一段代码具体方法

    设想这样一个场景,你要给一个项目开发测试程序,程序开始运行的时候,会创建初始环境,测试完成以后,会清理环境。 这段逻辑本身非常简单: setup() test() clean() …

    Linux系统 2025年6月8日

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注