- ubuntu12.04环境下使用kvm ioctl接口实现最简单的虚拟机
- Ubuntu 通过无线网络安装Ubuntu Server启动系统后连接无线网络的方法
- 在Ubuntu上搭建网桥的方法
- ubuntu 虚拟机上网方式及相关配置详解
CFSDN坚持开源创造价值,我们致力于搭建一个资源共享平台,让每一个IT人在这里找到属于你的精彩世界.
这篇CFSDN的博客文章mongodb replica set 配置高性能多服务器详解由作者收集整理,如果你对这篇文章有兴趣,记得点赞哟.
mongodb的多服务器配置,以前写过一篇文章,是master-slave模式的,请参考:详解mongodb 主从配置。master-slave模式,不能自动实现故障转移和恢复。所以推荐大家使用mongodb的replica set,来实现多服务器的高可用。给我的感觉是replica set好像自带了heartbeat功能,挺强大的.
一,三台服务器,1主,2从 。
服务器1:127.0.0.1:27017 服务器2:127.0.0.1:27018 服务器3:127.0.0.1:27019 。
1,创建数据库目录 。
1
|
[root@localhost ~]
# mkdir /var/lib/{mongodb_2,mongodb_3}
|
在一台机子上面模拟,三台服务器,所以把DB目录分开了。 2,创建配置文件 。
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
|
[root@localhost ~]# cat /etc/mongodb.conf |awk '{if($0 !~ /^$/ && $0 !~ /^#/) {print $0}}' //主服务器配置
port = 27017 //监听端口
fork = true //后台运行
pidfilepath = /var/run/mongodb/mongodb.pid //进程PID文件
logpath = /var/log/mongodb/mongodb.log //日志文件
dbpath =/var/lib/mongodb //db存放目录
journal = true //存储模式
nohttpinterface = true //禁用http
directoryperdb=true //一个数据库一个文件夹
logappend=true //追加方式写日志
replSet=repmore //集群名称,自定义
oplogSize=1000 //oplog大小
[root@localhost ~]# cat /etc/mongodb_2.conf |awk '{if($0 !~ /^$/ && $0 !~ /^#/) {print $0}}' //从服务器
port = 27018
fork = true
pidfilepath = /var/run/mongodb/mongodb_2.pid
logpath = /var/log/mongodb/mongodb_2.log
dbpath =/var/lib/mongodb_2
journal = true
nohttpinterface = true
directoryperdb=true
logappend=true
replSet=repmore
oplogSize=1000
[root@localhost ~]# cat /etc/mongodb_3.conf |awk '{if($0 !~ /^$/ && $0 !~ /^#/) {print $0}}' //从服务器
port = 27019
fork = true
pidfilepath = /var/run/mongodb/mongodb_3.pid
logpath = /var/log/mongodb/mongodb_3.log
dbpath =/var/lib/mongodb_3
journal = true
nohttpinterface = true
oplogSize = 1000
directoryperdb=true
logappend=true
replSet=repmore
|
在这里要注意一点,不要把认证开起来了,不然查看rs.status();时,主从服务器间,无法连接,"lastHeartbeatMessage" : "initial sync couldn't connect to 127.0.0.1:27017" 。
3,启动三台服务器 。
1
2
3
|
mongod -f
/etc/mongodb
.conf
mongod -f
/etc/mongodb_2
.conf
mongod -f
/etc/mongodb_3
.conf
|
注意:初次启动时,主服务器比较快的,从服务器有点慢.
二,配置并初始化replica set 1,配置replica set节点 。
1
|
> config = {_id:
"repmore"
,members:[{_id:0,host:
'127.0.0.1:27017'
,priority :2},{_id:1,host:
'127.0.0.1:27018'
,priority:1},{_id:2,host:
'127.0.0.1:27019'
,priority:1}]}
|
2,初始化replica set 。
1
2
3
4
5
|
> rs.initiate(config);
{
"info"
:
"Config now saved locally. Should come online in about a minute."
,
"ok"
: 1
}
|
3,查看replica set各节点状态 。
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
|
repmore:PRIMARY> rs.status();
{
"set"
:
"repmore"
,
"date"
: ISODate(
"2013-12-16T21:01:51Z"
),
"myState"
: 2,
"syncingTo"
:
"127.0.0.1:27017"
,
"members"
: [
{
"_id"
: 0,
"name"
:
"127.0.0.1:27017"
,
"health"
: 1,
"state"
: 1,
"stateStr"
:
"PRIMARY"
,
"uptime"
: 33,
"optime"
: Timestamp(1387227638, 1),
"optimeDate"
: ISODate(
"2013-12-16T21:00:38Z"
),
"lastHeartbeat"
: ISODate(
"2013-12-16T21:01:50Z"
),
"lastHeartbeatRecv"
: ISODate(
"2013-12-16T21:01:50Z"
),
"pingMs"
: 0,
"syncingTo"
:
"127.0.0.1:27018"
},
{
"_id"
: 1,
"name"
:
"127.0.0.1:27018"
,
"health"
: 1,
"state"
: 2,
"stateStr"
:
"SECONDARY"
,
"uptime"
: 1808,
"optime"
: Timestamp(1387227638, 1),
"optimeDate"
: ISODate(
"2013-12-16T21:00:38Z"
),
"errmsg"
:
"syncing to: 127.0.0.1:27017"
,
"self"
:
true
},
{
"_id"
: 2,
"name"
:
"127.0.0.1:27019"
,
"health"
: 1,
"state"
: 2,
"stateStr"
:
"SECONDARY"
,
"uptime"
: 1806,
"optime"
: Timestamp(1387227638, 1),
"optimeDate"
: ISODate(
"2013-12-16T21:00:38Z"
),
"lastHeartbeat"
: ISODate(
"2013-12-16T21:01:50Z"
),
"lastHeartbeatRecv"
: ISODate(
"2013-12-16T21:01:51Z"
),
"pingMs"
: 0,
"lastHeartbeatMessage"
:
"syncing to: 127.0.0.1:27018"
,
"syncingTo"
:
"127.0.0.1:27018"
}
],
"ok"
: 1
}
|
在这里要注意,rs.initiate初始化也是要一定时间的,刚执行完rs.initiate,我就查看状态,从服务器的stateStr不是SECONDARY,而是stateStr" : "STARTUP2",等一会就好了.
三,replica set主,从测试 1,主服务器测试 。
1
2
3
4
5
6
7
|
repmore:PRIMARY> show dbs;
local
1.078125GB
repmore:PRIMARY> use
test
switched to db
test
repmore:PRIMARY> db.
test
.insert({
'name'
:
'tank'
,
'phone'
:
'12345678'
});
repmore:PRIMARY> db.
test
.
find
();
{
"_id"
: ObjectId(
"52af64549d2f9e75bc57cda7"
),
"name"
:
"tank"
,
"phone"
:
"12345678"
}
|
2,从服务器测试 。
1
2
3
4
5
6
7
8
9
10
11
12
13
|
[root@localhost mongodb]
# mongo 127.0.0.1:27018 //连接
MongoDB shell version: 2.4.6
connecting to: 127.0.0.1:27018
/test
repmore:SECONDARY> show dbs;
local
1.078125GB
test
0.203125GB
repmore:SECONDARY> db.
test
.
find
();
//
无权限查看
error: {
"$err"
:
"not master and slaveOk=false"
,
"code"
: 13435 }
repmore:SECONDARY> rs.slaveOk();
//
从库开启
repmore:SECONDARY> db.
test
.
find
();
//
从库可看到主库刚插入的数据
{
"_id"
: ObjectId(
"52af64549d2f9e75bc57cda7"
),
"name"
:
"tank"
,
"phone"
:
"12345678"
}
repmore:SECONDARY> db.
test
.insert({
'name'
:
'zhangying'
,
'phone'
:
'12345678'
});
//
从库只读,无插入权限
not master
|
到这儿,我们的replica set就配置好了.
四,故障测试 前面我说过,mongodb replica set有故障转移功能,下面就模拟一下,这个过程 1,故障转移 1.1,关闭主服务器 。
1
2
3
4
5
6
7
8
9
10
|
[root@localhost mongodb]
# ps aux |grep mongod //查看所有的mongod
root 16977 0.2 1.1 3153692 44464 ? Sl 04:31 0:02 mongod -f
/etc/mongodb
.conf
root 17032 0.2 1.1 3128996 43640 ? Sl 04:31 0:02 mongod -f
/etc/mongodb_2
.conf
root 17092 0.2 0.9 3127976 38324 ? Sl 04:31 0:02 mongod -f
/etc/mongodb_3
.conf
root 20400 0.0 0.0 103248 860 pts
/2
S+ 04:47 0:00
grep
mongod
[root@localhost mongodb]
# kill 16977 //关闭主服务器进程
[root@localhost mongodb]
# ps aux |grep mongod
root 17032 0.2 1.1 3133124 43836 ? Sl 04:31 0:02 mongod -f
/etc/mongodb_2
.conf
root 17092 0.2 0.9 3127976 38404 ? Sl 04:31 0:02 mongod -f
/etc/mongodb_3
.conf
root 20488 0.0 0.0 103248 860 pts
/2
S+ 04:47 0:00
grep
mongod
|
1.2,在主库执行命令 。
1
2
|
repmore:PRIMARY> show dbs;
Tue Dec 17 04:48:02.392 DBClientCursor::init call() failed
|
1.3,从库查看状态,如下图, 。
replica set 故障测试 以前的从库变主库了,故障转移成功 。
2,故障恢复 。
mongod -f /etc/mongodb.conf 启动刚被关闭的主服务器,然后在登录到主服务器,查看状态rs.status();已恢复到最原始的状态了.
最后此篇关于mongodb replica set 配置高性能多服务器详解的文章就讲到这里了,如果你想了解更多关于mongodb replica set 配置高性能多服务器详解的内容请搜索CFSDN的文章或继续浏览相关文章,希望大家以后支持我的博客! 。
谁能解释一下 Server.MapPath(".")、Server.MapPath("~")、Server.MapPath(@"之间的区别\") 和 Server.MapPath("/")? 最佳答案
我不知道,为什么我们要使用 Server.UrlEncode() & Server.UrlDecode()?!在 QueryString 中我们看到 URL 中的任何内容,那么为什么我们要对它们进行编
我已经通过 WHM 在我的一个域上安装了 ssl 证书。网站正在使用 https://xyz.com . 但是它不适用于 https://www.xyz.com .我已经检查了证书,它也适用于 www
我已经使用 WMI 检测操作系统上是否存在防病毒软件,itz 正常工作并通过使用命名空间向我显示防病毒信息,例如 win xp 和 window7 上的名称和实例 ID:\root\SecurityC
我们有 hive 0.10 版本,我们想知道是否应该使用 Hive Server 1 或 Hive Server2。另一个问题是连接到在端口 10000 上运行的 Hive 服务器,使用 3rd 方工
我想在 C++ 中使用 Windows Server API 设置一个 HTTPS 服务器,我使用了示例代码,它在 HTTP 上工作正常,但我就是不能让它在 HTTPS 上工作。 (我不想要客户端 S
我写了一个非常基本的类来发送电子邮件。我用 smtp 服务器对其进行了测试,它工作正常,但是当我尝试使用我公司的交换服务器时,它给出了这个异常: SMTP 服务器需要安全连接或客户端未通过身份验证。服
我的应用程序包含一个“网关”DataSnap REST 服务器,它是所有客户端的第一个访问点。根据客户端在请求中传递的用户名(基本身份验证),请求需要重定向到另一个 DataSnap 服务器。我的问题
我有一个 Tomcat 服务器和一个 Glassfish4 服务器。我的 Servlet 在 Tomcat 服务器上启动得很好,但在 Glassfish4 服务器上给我一个“HTTP Status 4
我在 vmware 上创建了一个 ubuntu 服务器。我用它作为文件服务器。如果我通过托管虚拟机的计算机进行连接,则可以访问它。我无法从同一网络上的其他计算机执行此操作。提前致谢! 最佳答案 首先确
如何重启 Rails 服务器?我从 开始 rails server -d 所以服务器是分离的 我知道的唯一方法就是去做ps 辅助 | grep rails 并 kill -9关于过程#但是像这样杀死进
我实际上正在尝试找到编写一个简单的 XMPP 服务器的最佳方法,或者找到一个占用空间非常小的服务器。我只关心XMPP的核心功能(状态、消息传递、群组消息传递)。目前还在学习 XMPP 协议(proto
我实际上正在尝试找到编写简单 XMPP 服务器的最佳方法,或者找到一个占用空间非常小的方法。我只关心 XMPP 的核心功能(统计、消息、组消息)。目前也在学习 XMPP 协议(protocol),所以
我们正在尝试从 Java JAX-RS 适配器访问 SOAP 1.1 Web 服务。 我们正在使用从 WSDL 生成的 SOAP 客户端。 但是当解码 SOAP 故障时,我们得到以下异常: ... C
目前,我和许多其他人正在多个平台(Windows、OS X 和可能的 Linux)上使用 Python HTTP 服务器。我们正在使用 Python HTTP 服务器来测试 JavaScript 游戏
我有一个连续运行的服务器程序(C#/.NET 2.0 on Linux with mono),我想从 PHP 脚本连接到它以在网站上显示状态信息。 目的是创建一个(某种)实时浏览器游戏(无 Flash
所以我有一个单页客户端应用程序。 正常流程: 应用程序 -> OAuth2 服务器 -> 应用程序 我们有自己的 OAuth2 服务器,因此人们可以登录应用程序并获取与用户实体关联的 access_t
我们刚刚将测试 Web 服务器从 Server 2008 升级到 Server 2012 R2。我们有一个部署我们网站的批处理脚本。当它将站点推送到服务器时,它现在失败了。奇怪的是,我可以使用相同的发
建议一些加载SpagoBI服务器的方法,我尝试了所有方法来解析spagobi服务器。在 Catalina 中,错误是 - * SEVERE: Unable to process Jar entry [
当我们点击应用程序服务器(apache tomcat)时,它会创建一个线程来处理我们的请求并与 tomcat 连接,建立连接,tomcat 创建另一个线程来处理请求并将其传递给连接,连接线程将其传递给
我是一名优秀的程序员,十分优秀!