mongodb分片集群安装教程
mongodb 集群包含副本集群,主从集群以及分片集群,分片集群比较复杂,这里测试我采用了三台机器,交差部署
blog地址:http://www.cnblogs.com/caoguo
一 .环境:
#mongo1:
#172.31.100.97
#mongo2:
#172.31.100.81
#mongo3:
#172.31.100.82
#mongo1 and mongo2,mongo3

二 .基本安装
yum install ntp
#add
#restrict 172.31.100.0//etc/init.d/iptables stop && chkconfig iptables off
setenforce && echo "SELINUX=disabled" >/etc/selinux/config #edit /etc/crontab
*/ * * * * root ntpdate 172.31.100.97 wget http://downloads.mongodb.org/linux/mongodb-linux-x86_64-2.6.7.tgz?_ga=1.235705353.941929558.1425604443
tar zxvf mongodb-linux-x86_64-2.6..tgz
mv mongodb-linux-x86_64-2.6. /usr/local/mongodb
ln -sf /usr/local/mongodb/bin/* /usr/sbin/
ln -sf /usr/local/mongodb/bin/mongod /usr/sbin/mongoc
ln -sf /usr/local/mongodb/bin/mongod /usr/sbin/mongod1
ln -sf /usr/local/mongodb/bin/mongod /usr/sbin/mongod2
ln -sf /usr/local/mongodb/bin/mongod /usr/sbin/mongod3 mkdir -p /data/mongodb/config/{data,log}
mkdir -p /data/mongodb/mongos/log
mkdir -p /data/mongodb/shard{1..3}/{data,log}
mkdir -p /etc/mongod openssl rand -base64 753 >/etc/mongod/keyfile
chmod 600 /etc/mongod/keyfile
echo '#建立mongo1 and mongo2,mongo3配置服务' cat >/etc/mongod/mongoc.conf <<EOF
#bind_ip=192.168.1.201
port=
fork=true
logappend=true
dbpath=/data/mongodb/config/data
pidfilepath=/var/run/mongoc.pid
#keyFile=/etc/mongod/keyfile
logpath=/data/mongodb/config/log/config.log
configsvr=true
EOF echo '#create mongos' cat >/etc/mongod/mongos.conf<<EOF
port=
configdb=172.31.100.97:,172.31.100.82:,172.31.100.81:
fork=true
#keyFile=/etc/mongod/keyfile
logpath=/data/mongodb/mongos/log/mongos.log
EOF echo '#create shard' cat >/etc/mongod/mongod1.conf<<EOF
port=
shardsvr=true
replSet=shard1
dbpath=/data/mongodb/shard1/data
logpath=/data/mongodb/shard1/log/shard1.log
#keyFile=/etc/mongod/keyfile
fork=true
nojournal=true
oplogSize=
EOF cat >/etc/mongod/mongod2.conf<<EOF
port=
shardsvr=true
replSet=shard2
dbpath=/data/mongodb/shard2/data
logpath=/data/mongodb/shard2/log/shard2.log
#keyFile=/etc/mongod/keyfile
fork=true
nojournal=true
oplogSize=
EOF cat >/etc/mongod/mongod3.conf<<EOF
port=
shardsvr=true
replSet=shard3
dbpath=/data/mongodb/shard3/data
logpath=/data/mongodb/shard3/log/shard3.log
#keyFile=/etc/mongod/keyfile
fork=true
nojournal=true
oplogSize=
EOF
touch /etc/init.d/mongoc
touch /etc/init.d/mongos
touch /etc/init.d/mongod{..}
chmod /etc/init.d/mongo*
#/etc/init.d/mongoc stop && \
/etc/init.d/mongos stop && \
/etc/init.d/mongod1 stop && \
/etc/init.d/mongod2 stop && \
/etc/init.d/mongod3 stop && \
netstat -ntlp|grep mongo #/etc/init.d/mongoc start && \
/etc/init.d/mongos start && \
/etc/init.d/mongod1 start && \
/etc/init.d/mongod2 start && \
/etc/init.d/mongod3 start && \
netstat -ntlp|grep mongo #/etc/init.d/mongoc restart && \
/etc/init.d/mongos restart && \
/etc/init.d/mongod1 restart && \
/etc/init.d/mongod2 restart && \
/etc/init.d/mongod3 restart && \
netstat -ntlp|grep mongo
三 .配置
[root@Centos ~]# mongo localhost:/admin
#复本集一(连到主节点上去操作)
> rs.initiate({"_id":"shard1",
"members":[
{"_id":, "host":"172.31.100.97:3100",priority:},
{"_id":, "host":"172.31.100.82:3100"},
{"_id":, "host":"172.31.100.81:3100"}
]
}) > rs.status() #复本集二
[root@Centos ~]# mongo localhost:/admin
> rs.initiate({"_id":"shard2",
"members":[
{"_id":, "host":"172.31.100.97:3200"},
{"_id":, "host":"172.31.100.82:3200",priority:},
{"_id":, "host":"172.31.100.81:3200"}
]
}) > rs.status() #复本集三
[root@Centos ~]# mongo localhost:/admin
> rs.initiate({"_id":"shard3",
"members":[
{"_id":, "host":"172.31.100.97:3300"},
{"_id":, "host":"172.31.100.82:3300"},
{"_id":, "host":"172.31.100.81:3300", priority:}
]
}) > rs.status() #添加副本
shard1:PRIMARY> rs.remove("172.31.100.81:3100")
shard1:PRIMARY> rs.add("172.31.100.81:3100") #移除分片
db.runCommand( { removeshard: "shard1" } ) #mongos加入分片主机
[root@Centos ~]# mongo localhost:/admin
mongos> db.runCommand({ addshard : "shard1/172.31.100.97:3100,172.31.100.82:3100,172.31.100.81:3100"});
mongos> db.runCommand({ addshard : "shard2/172.31.100.97:3200,172.31.100.82:3200,172.31.100.81:3200"});
mongos> db.runCommand({ addshard : "shard3/172.31.100.97:3300,172.31.100.82:3300,172.31.100.81:3300"});
mongos> db.runCommand({ listshards : } ); #允许数据库分片
mongos> db.runCommand({"enablesharding" : "seller"}) #设置集合分片
mongos> db.runCommand({"shardcollection" : "seller.person", "key" : {"_id" : }}) #设置用户验证
mongos> show dbs
admin (empty)
config .016GB
mongos> db
admin
mongos> db.addUser('admin','fffR3q!P97scxxxx')
WARNING: The 'addUser' shell helper is DEPRECATED. Please use 'createUser' instead
Successfully added user: { "user" : "admin", "roles" : [ "root" ] } sed -i 's/^#keyFile/keyFile/g' /etc/mongod/mongoc.conf
sed -i 's/^#keyFile/keyFile/g' /etc/mongod/mongos.conf
sed -i 's/^#keyFile/keyFile/g' /etc/mongod/mongod1.conf
sed -i 's/^#keyFile/keyFile/g' /etc/mongod/mongod2.conf
sed -i 's/^#keyFile/keyFile/g' /etc/mongod/mongod3.conf
grep keyFile /etc/mongod/mongo*
四 .测试
############################
# 数据测试 ###
############################ #插入数据
mongos> use seller > db.person.insert({"name":"jack","age":})
> db.person.insert({"name":"joe","age":}) #批量插入数据
#for (var i = ; i <= ; i++)db.person.save({id:i,name:"username"+i,age:i}); #删除所有数据
#db.person.remove() #查看数据分布
db.person.stats()
db.person.getShardDistribution() #查询数据
> db.person.find({"name":"joe"})
{ "_id" : ObjectId("53150a14d39c963b140c6f6a"), "name" : "joe", "age" : } #更新数据
> db.person.update({"name":"joe"},{"name":"joe","age":})
> db.person.find({"name":"joe"})
{ "_id" : ObjectId("53150a14d39c963b140c6f6a"), "name" : "joe", "age" : } #移除数据
> db.person.remove({"name":"joe"})
> db.person.find()
{ "_id" : ObjectId("53150a0cd39c963b140c6f69"), "name" : "jack", "age" : }
> db.person.remove()
> db.person.find()
> db.person.count() #查看块大小
db.settings.find() #设置块大小
db.settings.save( { _id:"chunksize", value: <sizeInMB> } ) #空间压缩
db.repairDatabase() #压缩指定collection,这最好停止写数据,且只能在副本节点操作
db.person.runCommand("compact");
db.runCommand({compact : 'person');
由于启动脚本比较多我放在最后:
/etc/init.d/mongoc
vi /etc/init.d/mongoc
#!/bin/bash
#
# mongodb This shell script takes care of starting and stopping
#
# chkconfig: -
### END INIT INFO # Source function library.
. /etc/init.d/functions prog=mongoc
lockfile=/var/lock/subsys/$prog
config=/etc/mongod/mongoc.conf
start() { # Start daemons.
echo -n $"Starting $prog: "
daemon $prog --config $config $OPTIONS
RETVAL=$?
echo
[ $RETVAL -eq ] && touch $lockfile
return $RETVAL
} stop() {
echo -n $"Shutting down $prog: "
killproc $prog
RETVAL=$?
echo
[ $RETVAL -eq ] && rm -f $lockfile
return $RETVAL
} # See how we were called.
case "$1" in
start)
start
;;
stop)
stop
;;
status)
status $prog
;;
restart|force-reload)
stop
start
;;
*)
echo $"Usage: $0 {start|stop|status|restart|try-restart|force-reload}"
exit
esac
/etc/init.d/mongos
vi /etc/init.d/mongos
#!/bin/bash
#
# mongodb This shell script takes care of starting and stopping
#
# chkconfig: -
### END INIT INFO # Source function library.
. /etc/init.d/functions prog=mongos
lockfile=/var/lock/subsys/$prog
config=/etc/mongod/mongos.conf
start() { # Start daemons.
echo -n $"Starting $prog: "
daemon $prog --config $config $OPTIONS
RETVAL=$?
echo
[ $RETVAL -eq ] && touch $lockfile
return $RETVAL
} stop() {
echo -n $"Shutting down $prog: "
killproc $prog
RETVAL=$?
echo
[ $RETVAL -eq ] && rm -f $lockfile
return $RETVAL
} # See how we were called.
case "$1" in
start)
start
;;
stop)
stop
;;
status)
status $prog
;;
restart|force-reload)
stop
start
;;
*)
echo $"Usage: $0 {start|stop|status|restart|try-restart|force-reload}"
exit
esac
/etc/init.d/mongod1
vi /etc/init.d/mongod1
#!/bin/bash
#
# mongodb This shell script takes care of starting and stopping
#
# chkconfig: -
### END INIT INFO # Source function library.
. /etc/init.d/functions prog=mongod1
lockfile=/var/lock/subsys/$prog
config=/etc/mongod/mongod1.conf
start() { # Start daemons.
echo -n $"Starting $prog: "
daemon $prog --config $config $OPTIONS
RETVAL=$?
echo
[ $RETVAL -eq ] && touch $lockfile
return $RETVAL
} stop() {
echo -n $"Shutting down $prog: "
killproc $prog
RETVAL=$?
echo
[ $RETVAL -eq ] && rm -f $lockfile
return $RETVAL
} # See how we were called.
case "$1" in
start)
start
;;
stop)
stop
;;
status)
status $prog
;;
restart|force-reload)
stop
start
;;
*)
echo $"Usage: $0 {start|stop|status|restart|try-restart|force-reload}"
exit
esac
/etc/init.d/mongod2
#!/bin/bash
#
# mongodb This shell script takes care of starting and stopping
#
# chkconfig: -
### END INIT INFO # Source function library.
. /etc/init.d/functions prog=mongod2
lockfile=/var/lock/subsys/$prog
config=/etc/mongod/mongod2.conf
start() { # Start daemons.
echo -n $"Starting $prog: "
daemon $prog --config $config $OPTIONS
RETVAL=$?
echo
[ $RETVAL -eq ] && touch $lockfile
return $RETVAL
} stop() {
echo -n $"Shutting down $prog: "
killproc $prog
RETVAL=$?
echo
[ $RETVAL -eq ] && rm -f $lockfile
return $RETVAL
} # See how we were called.
case "$1" in
start)
start
;;
stop)
stop
;;
status)
status $prog
;;
restart|force-reload)
stop
start
;;
*)
echo $"Usage: $0 {start|stop|status|restart|try-restart|force-reload}"
exit
esac
/etc/init.d/mongod3
#!/bin/bash
#
# mongodb This shell script takes care of starting and stopping
#
# chkconfig: -
### END INIT INFO # Source function library.
. /etc/init.d/functions prog=mongod3
lockfile=/var/lock/subsys/$prog
config=/etc/mongod/mongod3.conf
start() { # Start daemons.
echo -n $"Starting $prog: "
daemon $prog --config $config $OPTIONS
RETVAL=$?
echo
[ $RETVAL -eq ] && touch $lockfile
return $RETVAL
} stop() {
echo -n $"Shutting down $prog: "
killproc $prog
RETVAL=$?
echo
[ $RETVAL -eq ] && rm -f $lockfile
return $RETVAL
} # See how we were called.
case "$1" in
start)
start
;;
stop)
stop
;;
status)
status $prog
;;
restart|force-reload)
stop
start
;;
*)
echo $"Usage: $0 {start|stop|status|restart|try-restart|force-reload}"
exit
esac
mongodb分片集群安装教程的更多相关文章
- 搭建MongoDB分片集群
在部门服务器搭建MongoDB分片集群,记录整个操作过程,朋友们也可以参考. 计划如下: 用5台机器搭建,IP分别为:192.168.58.5.192.168.58.6.192.168.58.8.19 ...
- 分布式文档存储数据库之MongoDB分片集群
前文我们聊到了mongodb的副本集以及配置副本集,回顾请参考https://www.cnblogs.com/qiuhom-1874/p/13953598.html:今天我们来聊下mongodb的分片 ...
- MongoDB分片集群原理、搭建及测试详解
随着技术的发展,目前数据库系统对于海量数据的存储和高效访问海量数据要求越来越高,MongoDB分片机制就是为了解决海量数据的存储和高效海量数据访问而生. MongoDB分片集群由mongos路由进程( ...
- mongodb分片集群
第一章 1.mongodb 分片集群解释和目的 一组Mongodb复制集,就是一组mongod进程,这些进程维护同一个数据集合.复制集提供了数据冗余和高等级的可靠性,这是生产部署的基础. 第二章 1. ...
- TiDB和MongoDB分片集群架构比较
此文已由作者温正湖授权网易云社区发布. 欢迎访问网易云社区,了解更多网易技术产品运营经验. 最近阅读了TiDB源码的说明文档,跟MongoDB的分片集群做了下简单对比. 首先展示TiDB的整体架构 M ...
- 网易云MongoDB分片集群(Sharding)服务已上线
此文已由作者温正湖授权网易云社区发布. 欢迎访问网易云社区,了解更多网易技术产品运营经验. MongoDB sharding cluster(分片集群)是MongoDB提供的数据在线水平扩展方案,包括 ...
- MongoDB 分片集群实战
背景 在如今的互联网环境下,海量数据已随处可见并且还在不断增长,对于如何存储处理海量数据,比较常见的方法有两种: 垂直扩展:通过增加单台服务器的配置,例如使用更强悍的 CPU.更大的内存.更大容量的磁 ...
- CentOS7+Docker+MangoDB下部署简单的MongoDB分片集群
简单的在Docker上快速部署MongoDB分片集群 前言 文中使用的环境如下 OS:CentOS Linux release 7.5.1804 (Core) Docker:Docker versio ...
- Windows 搭建MongoDB分片集群(二)
在本篇博客中我们主要讲描述分片集群的搭建过程.配置分片集群主要有两个步骤,第一启动所有需要的mongod和mongos进程.第二步就是启动一个mongos与集群通信.下面我们一步步来描述集群的搭建过程 ...
随机推荐
- Eureka集群的那些坑
今天遇到一个Eureka集群的一个坑. 问题现场类似是这样的:两台Eureka组成的服务注册中心集群,两台服务提供方server1.server2,两个服务调用方client1.client2. 正常 ...
- com.101tec.ZKClient实现中的subscribeDataChanges设置的监听器事件不回调的问题研究
1.如果在Web项目,本身在后台运行,所以注册的事件应该是正常回调的. 2.如果是Application项目,如果是简单的测试,那么运行完之后,整个程序就结束了,程序很快,所以没等到事件回调就关了,解 ...
- subclipse 和 eclipse结合遇到的问题
subclipse是eclipse的一个SVN插件.但是我在使用的时候不断的报出下面的错误: the applet is attempting to access the "exists&q ...
- Cocos2d-x教程(34)-三维物体OBB碰撞检測算法
欢迎增加Cocos2d-x 交流群:193411763 个中心点.1个旋转矩阵和3个1/2边长(注:一个旋转矩阵包括了三个旋转轴,若是二维的OBB包围盒则是一个中心点,两个旋转轴,两个1/2边长). ...
- android开发艺术探索学习 之 结合Activity的生命周期了解Activity的LaunchMode
转载请标明出处: http://blog.csdn.net/lxk_1993/article/details/50749728 本文出自:[lxk_1993的博客]: 首先还是先介绍下Activity ...
- centos命令行安装mysql随机密码查看方法(遇到问题及其解决办法)
mysql初次命令行安装登录时报错: 未输入密码:ERROR 1045 (28000): Access denied for user 'root'@'localhost' (using passwo ...
- ASP.NET_SessionId vs .ASPXAUTH why do we need both of them?
https://stackoverflow.com/questions/23758704/asp-net-sessionid-vs-aspxauth-why-do-we-need-both-of-th ...
- 【HAOI 2008】 糖果传递
[题目链接] https://www.lydsy.com/JudgeOnline/problem.php?id=1045 [算法] 环形均分纸牌问题 [代码] #include<bits/std ...
- [python基础]xml_rpc远程调控supervisor节点进程
supervisor提供的两种管理方式,supervisorctl和web其实都是通过xml_rpc来实现的. xml_rpc其实就是本地可以去调用远端的函数方法,在python中只需要引入xmlrp ...
- Black Rock Shooter
在人气动漫 Black Rock shooter 中,当加贺里对麻陶 说出了"滚回去"以后,与此同时,在另一个心灵世界里, BRS 也遭到了敌人的攻击.此时,一共有 n 个攻击排成 ...