mongodb使用mongos链接复制集
我们知道mongodb现在生产环境大部分还是使用的复制集来作为主流,据我了解。很多公司现在都是使用复制集的方式,而我们通过mongos可以巧妙的解决链接的问题,我们先从环境说起:
server1:mongod primary+mongod config+mongos
server2:mongod primary+mongod config+mongos
server3:mongod primary+mongod config+mongos
其实就是一个分片复制集,只不过这里我们启动了一个分片节点,所有的数据库和集合并没有采用分片的操作,我们的所有链接可以通过三个mongos链接,三个mongos和mongo confir是独立的,目的是为了当其中一组down掉以后出现单点的问题。
server1:mongodb+config+mongos
server2:mongodb+config+mongos
两个mongod是一个复制集,两个config+mongos是各自独立的。
tar -zxvf mongodb-linux-x86_64-rhel62-3.4.2.tgz
mkdir /home/maxiangqian/
mv mongodb-linux-x86_64-rhel62-3.4.2 /home/maxiangqian/
2:加入环境变量
export PATH=/home/maxiangqian/mongodb-linux-x86_64-rhel62-3.4.2/bin:$PATH
3:创建用户和目录
[root@localhost mongodb]# mkdir -p /home/mongodb/db27017/data
[root@localhost mongodb]# mkdir -p /home/mongodb/db27017/log
[root@localhost mongodb]# mkdir -p /home/mongodb/db27017/tmp
[root@localhost mongodb]# mkdir -p /home/mongodb/db27017/key
4:关闭配置SELinux
vi /etc/selinux/config
配置:
[root@localhost log]# /sbin/iptables -I INPUT -p tcp --dport 27017 -j ACCEPT
[root@localhost log]# /sbin/iptables -I INPUT -p tcp --dport 27018 -j ACCEPT
[root@localhost log]# /sbin/iptables -I INPUT -p tcp --dport 27019 -j ACCEPT
[root@localhost log]# /etc/rc.d/init.d/iptables save
查看状态:/etc/init.d/iptables status
vi mongodb27017.conf
6:启动
mongod -f /home/mongodb/db27017/mongodb27017.cnf
7:为主实例配置超级管理员账号:maxiangqian
use admin
db.createUser(
{
user: "maxiangqian",
pwd: "maxiangqian",
roles: [ { role: "root", db: "admin" } ]
}
)
openssl rand -base64 756 > /home/mongodb/db27017/key/autokey
chmod 400 /home/mongodb/db27017/key/autokey
cp /home/mongodb/db27017/key/autokey /home/sa/
scp -P 9880 autokey sa@172.16.16.35:/home/sa/
9:初始化复制集
config = {
_id : "mongodbtestmxq",
members :
[
{ _id : 0, host : "172.16.16.34:27017" },
{ _id : 1, host : "172.16.16.35:27017" }
]
}
创建复制集配置对象,其中id=warringstates是表示复制集的名称
rs.initiate(config)
10:验证复制集
mongodbtestmxq:PRIMARY> use maxiangqian
switched to db maxiangqian
mongodbtestmxq:PRIMARY> db.maxiagnqian.insert({"id":1,"name":"maxiangqian"})
WriteResult({ "nInserted" : 1 })
mongodbtestmxq:PRIMARY> db.maxiagnqian.find()
{ "_id" : ObjectId("58eb1aaddf342c94989755e7"), "id" : 1, "name" : "maxiangqian" }
从节点验证:
mongodbtestmxq:SECONDARY> use maxiangqian
switched to db maxiangqian
mongodbtestmxq:SECONDARY> db.maxiagnqian.find()
{ "_id" : ObjectId("58eb1aaddf342c94989755e7"), "id" : 1, "name" : "maxiangqian" }
发现这个认证复制集搭建是OK的。
mongod -f /home/mongodb/config/mongoconfig27018.conf
然后我们看一下配置文件:
[root@localhost config]# cat mongoconfig27018.conf
dbpath=/home/mongodb/config/data/
configsvr=true
port=27018
keyFile=/home/sa/autokey
fork = true
logpath = /home/mongodb/config/log/mongo.logi
replSet=configmxq
初始化复制集,也要加认证,添加管理员账号:
config = {
_id : "configmxq",
members :
[
{ _id : 0, host : "172.16.16.34:27018" },
{ _id : 1, host : "172.16.16.35:27018" }
]
}
rs.initiate(config)
12:启动mongos
[root@localhost mongos]# cat mongos27019.conf
port=27019
configdb=configmxq/172.16.16.34:27018,172.16.16.35:27018
keyFile=/home/sa/autokey
fork = true
logpath = /home/mongodb/mongos/log/mongo.log
然后直接进行启动:
mongos -f /home/mongodb/mongos/mongos27019.conf
13:进入mongos进行分片的设置:
mongos> use admin
switched to db admin
mongos> db.auth("maxiangqian","maxiangqian")
1
mongos> show dbs
admin 0.000GB
config 0.000GB
maxiangqian 0.000GB
mongos> db.maxiangqian.find()
mongos> use maxiangqian
switched to db maxiangqian
mongos> db.maxiangqian.find()
mongos> db.maxiangqian.insert({"id":2,"name":"maxiangqian2"})
WriteResult({ "nInserted" : 1 })
从主库直接插入一条数据:
mongodbtestmxq:PRIMARY> db.maxiangqian.insert({"id":3,"name":"maxiangqian3"})
然后返回mongos直接进行查看:
mongos> db.maxiangqian.find()
{ "_id" : ObjectId("58eb34a9289626fe9f9c2586"), "id" : 2, "name" : "maxiangqian2" }
{ "_id" : ObjectId("58eb35516c6683eeb8a72b9a"), "id" : 3, "name" : "maxiangqian3" }
看到数据是没问题的。应该是配置好了。到这里,也算配置结束了。
下面还是贴一下基本的配置文件吧,方便大家查阅:
dbpath = /home/mongodb/db27017/data/
logpath = /home/mongodb/db27017/log/mongo.log
pidfilepath = /home/mongodb/db27017/tmp/mongo.pid
keyFile = /home/sa/autokey
directoryperdb = true
logappend = true
smallfiles = true
fork = true
auth = true
port = 27017
replSet = mongodbtestmxq
maxConns = 10240
shardsvr=true
2:config配置文件
dbpath=/home/mongodb/config/data/
configsvr=true
port=27018
keyFile=/home/sa/autokey
fork = true
logpath = /home/mongodb/config/log/mongo.log
replSet=configmxq
3:mongos配置文件
port=27019
configdb=configmxq/172.16.16.34:27018,172.16.16.35:27018
keyFile=/home/sa/autokey
fork = true
logpath = /home/mongodb/mongos/log/mongo.log
mongodb使用mongos链接复制集的更多相关文章
- Studio 3T for MongoDB连接51.212复制集
Studio 3T for MongoDB连接51.212复制集 [ #DirectConection Authentication Mode - Basic(MONGODB-CR or SCEAM- ...
- mongodb 3.4分片复制集配置
1:启动三个实例 mongod -f /home/mongodb/db27017/mongodb27017.conf mongod -f /home/mongodb/db27018/mongodb27 ...
- MongoDB之Replica Set(复制集复制)
MongoDB支持两种复制模式: 主从复制(Master/Slave) 复制集复制(Replica Set) 下面主要记录我在centos虚拟机上安装replica set,主要参考:http://d ...
- Mongodb Manual阅读笔记:CH8 复制集
8 复制 Mongodb Manual阅读笔记:CH2 Mongodb CRUD 操作Mongodb Manual阅读笔记:CH3 数据模型(Data Models)Mongodb Manual阅读笔 ...
- MongoDB复制集高可用选举机制(三)
复制集高可用选举机制 在上一章介绍了MongoDB的架构,复制集的架构直接影响着故障切换时的结果.为了能够有效的故障切换,请确保至少有一个节点能够顺利升职为主节点.保证在拥有核心业务系统的数据中心中拥 ...
- MongoDB之分片集群与复制集
分片集群 1.1.概念 分片集群是将数据存储在多台机器上的操作,主要由查询路由mongos.分片.配置服务器组成. ●查询路由根据配置服务器上的元数据将请求分发到相应的分片上,本身不存储集群的元数据, ...
- 【MongoDB】windows平台搭建Mongo数据库复制集(类似集群)(转)
原文链接:[MongoDB]windows平台搭建Mongo数据库复制集(类似集群)(一) Replica Sets(复制集)是在mongodDB1.6版本开始新增的功能,它可以实现故障自动切换和自 ...
- MongoDB复制集成员及状态转换
此文已由作者温正湖授权网易云社区发布. 欢迎访问网易云社区,了解更多网易技术产品运营经验. 复制集(Replica Set)是MongoDB核心组件,相比早期版本采用的主从(Master-Slave) ...
- MongoDB学习笔记(六)--复制集+sharding分片 && 总结
复制集+sharding分片 背景 主机 IP 服务及端口 Server A ...
随机推荐
- linux vi文本编辑器三种模式切换及常用操作
初学者刚进入vi不要乱点键盘,vi的三种模式和各种命令很容易弄混@@ vi编辑器是Unix系统最初的编辑器.它使用控制台图形模式来模拟文本编辑窗口,允许查看文件中的行.在文件中移动.插入.编辑和替换文 ...
- 递归demo
递归算法就是直接或间接调用自己的算法 public static void main(String[] args) { int m = sum(9); System.out.println(m); } ...
- golang mcall
// func mcall(fn func(*g)) // Switch to m->g0's stack, call fn(g). // Fn must never return. It sh ...
- Java框架-mybatis02基本的crud操作
1.搭建mybatis框架 1)导入相关jar包 2)编写核心配置文件(配置数据库连接的相关信息以及配置mapper映射文件) 3)编写dao操作 4)编写mapper映射文件 5)编写实体类 2.执 ...
- 游戏开发者注意!这个音频SDK可以完美兼容所有主流游戏引擎
欢迎大家前往腾讯云+社区,获取更多腾讯海量技术实践干货哦~ 本文由腾讯游戏云 发表于云+社区专栏 在网络游戏中,无论是大逃杀.棋牌类.电子竞技类还是娱乐休闲类小游戏,玩家和玩家之间的互动.语音聊天是一 ...
- OGNL与值栈
一.OGNL入门 1.什么是OGNL OGNL的全称是对象图导航语言(Object-Graph Navigation Language),它是一种功能强大的开源表达式语言.使用这种表达式语言,可以通过 ...
- HTTP传输内容的压缩
最近在看尤大的ssr项目的demo,看他的项目里有用到compression,完全看不懂这是什么鬼,然后百度了一下,文档也都是英文的,看着有点吃力,隐约的觉得这是压缩http请求的,做前端的都知道,在 ...
- AngularJS的日期格式化有两种形式
AngularJS的日期格式化有两种形式,一种是在HTML页面,一种是在JS代码里,都是用到AngularJS的过滤器$filter. HTML: date_expression 即 你在$scope ...
- 在线课程笔记—.NET基础
关于学习北京理工大学金旭亮老师在线课程的笔记. 介绍: 在线课程网址:http://mooc.study.163.com/university/BIT#/c 老师个人网站:http://jinxuli ...
- tr设置display属性时,在FF中td合并在第一个td中显示的问题
今天用firefox测试页面的时候,发现用javascript控制 tr 的显示隐藏时,当把tr的显示由“display:none”改为“display:block”时,该tr下的td内容合并到了 ...