mongodb集群部署
一、安装Mongodb(Tarballs)
1、检查依赖文件包:
yum install libcurl openssl
2、解压文件到/usr/local/
tar -zxvf mongodb-linux-x86_64-rhel70-4.0.4.tgz -C /usr/local/
3、配置环境变量 /etc/profile
export PATH=/usr/local/mongodb-linux-x86_64-rhel70-4.0.4/bin:$PATH
使用命令mongod -v
输出信息版本信息验证环境变量是否配置成功
4、配置/etc/selinux/config文件 关闭selinux (配置完重启)
SELINUX=disabled
5、关闭防火墙
systemctl stop firewalld
systemctl disable firewalld
二、配置config server(副本集)
选取三台电脑,做如下操作:一主一副一仲裁
1、 新建目录
mkdir /usr/local/mongodb-linux-x86_64-rhel70-4.0.4/conf
mkdir /var/log/mongodb
2、 在新建的conf目录下创建config.conf 做如下配置(跟python代码一样注意缩进问题)
sharding:
clusterRole: configsvr
replication:
replSetName: configs
net:
port: 27019
bindIp: 0.0.0.0
processManagement:
fork: true
pidFilePath: /var/log/mongodb/config.pid
systemLog:
destination: file
logAppend: true
path: /var/log/mongodb/config.log
3、 创建默认的保存数据的文件位置:
mkdir -p /data/configdb
4、 启动mongod实例
mongod --config /usr/local/mongodb-linux-x86_64-rhel70-4.0.4/conf/config.conf
5、 登陆任意一台服务器—— mongo --port XXX
mongo --port 27019
6、 初始化副本集(键“_id”对应的值必须与配置文件中的replicaction.replSetName一致)
rs.initiate(
{
_id: "configs",
configsvr: true,
members: [
{ _id : 0, host : "192.168.100.101:27019" },
{ _id : 1, host : "192.168.100.102:27019" },
{ _id : 2, host : "192.168.100.103:27019" }
]
}
)
7、查看config副本集状态
rs.status();
三、配置shard server(副本集)
选取三台电脑,做如下操作:
1、 新建目录
mkdir /usr/local/mongodb-linux-x86_64-rhel70-4.0.4/conf
mkdir /var/log/mongodb
2、 在新建目录下创建shard0.conf 做如下配置(跟python代码一样注意缩进问题)
sharding:
clusterRole: shardsvr
replication:
replSetName: shard0
net:
port: 27018
bindIp: 0.0.0.0
processManagement:
fork: true
pidFilePath: /var/log/mongodb/shard0.pid
systemLog:
destination: file
logAppend: true
path: /var/log/mongodb/shard0.log
3、 创建默认的保存数据的文件位置:
mkdir -p /data/db
4、 启动shard0 server实例
mongod --config /usr/local/mongodb-linux-x86_64-rhel70-4.0.4/conf/shard0.conf
5、 启动完三台服务器的实例后,登陆任意一台服务器,初始化副本集
mongo --port 27018
6、 初始化副本集(键“_id”对应的值必须与配置文件中的replicaction.replSetName一致)
rs.initiate(
{
_id : "shard0",
members: [
{ _id : 0, host : "192.168.100.1:27018", priority : 1},
{ _id : 1, host : "192.168.100.6:27018", priority : 2},
{ _id : 2, host : "192.168.100.9:27018", arbiterOnly :true}
]
}
)
7、 查看shard0副本集状态
rs.status();
四、配置mongos
选取一台或多台电脑,做如下操作:
1、 在安装目录下新建目录
mkdir /usr/local/mongodb-linux-x86_64-rhel70-4.0.4/conf
2、 在新建目录下创建mongos.conf 做如下配置(跟python代码一样注意缩进问题)
sharding:
configDB: configs/192.168.100.101:27019,192.168.100.102:27019,192.168.100.103:27019
net:
bindIp:0.0.0.0
port:27017
systemLog:
destination: file
logAppend: true
path: /var/log/mongodb/mongos.log
processManagement:
fork: true
3、 创建默认的保存数据的文件位置:
mkdir -p /data/db
4、 启动mongos server实例
mongos --config /usr/local/mongodb-linux-x86_64-rhel70-4.0.4/conf/mongos.conf
5、 连接到一台mongos
mongo --host 192.168.100.1 --port 27017
6、 串联路由服务器与分片副本集
use admin
sh.addShard("shard0/192.168.100.1:27018, 192.168.100.6:27018, 192.168.100.9:27018")
7、 查看集群状态
sh.status()
mongodb集群部署的更多相关文章
- Mongodb集群部署ReplicaSet+Sharding -摘自网络
网上关于三种集群方式的搭建方式很多,都是分开来介绍的.Replica Set (复制集成)主要是做主从库的,但是没法实现负载均衡的效果,真正实现这个的,是Sharding(分片集群),通过数据分布在每 ...
- MongoDB集群部署 - 带访问控制的分片副本集
1. 前言 Ceilometer将meter.event等数据保存在MongoDB中,之前将MongoDB部署在控制节点上,使用三副本模式,时间长了发现meter数据爆炸式增长,区区2T的磁盘捉襟见肘 ...
- 图解MongoDB集群部署原理(3)
MongoDB的集群部署方案中有三类角色:实际数据存储结点.配置文件存储结点和路由接入结点. 连接的客户端直接与路由结点相连,从配置结点上查询数据,根据查询结果到实际的存储结点上查询和存储数据.Mon ...
- mongodb 集群部署--分片服务器搭建
部署分片服务器 1.分片 为了突破单点数据库服务器的I/O能力限制,对数据库存储进行水平扩展,严格地说,每一个服务器或者实例或者复制集就是一个分片. 2.优势 提供类似现行增·长架构 提高数据可用性 ...
- MongoDB集群与LBS应用系列(二)--与Hadoop集成
长期以来,我每开个系列,只有兴趣写一篇,很难持之与恒.为了克服这个长久以来的性格弱点,以及梳理工作半年的积累.最近一个月会写两篇关于Mongo在地理大数据方面的实践和应用,一篇关于推荐系统的初期准备过 ...
- mongo的集群部署
# MongoDB 集群部署 ## 关键词 * 集群 * 副本集 * 分片 ## MongoDB集群部署 >今天主要来说说Mongodb的三种集群方式的搭建Replica Set副本集 / Sh ...
- centos7下安装部署mongodb集群(副本集模式)
环境需求:Mongodb集群有三种模式: Replica Set, Sharding,Master-Slaver. 这里部署的是Replica Set模式. 测试环境: 这里副本集(Replica ...
- 在Docker中安装和部署MongoDB集群
此文已由作者袁欢授权网易云社区发布. 欢迎访问网易云社区,了解更多网易技术产品运营经验. 在Docker中安装mongodb 采用的mongodb镜像:https://registry.hub.doc ...
- 手把手教你用Docker部署一个MongoDB集群
MongoDB是一个介于关系数据库和非关系数据库之间的产品,是非关系数据库当中最像关系数据库的.支持类似于面向对象的查询语言,几乎可以实现类似关系数据库单表查询的绝大部分功能,而且还支持对数据建立索引 ...
随机推荐
- JDK新特性之可变个数的形参的方法
可变个数的形参的方法:1.格式:对于方法的形参来说:数据类型...形参名2.可变个数的形参的方法与同名的方法之间可以构成重载3.可变个数的形参在调用时,个数从0开始,到无穷都可以(在调用这个方法时,s ...
- Linux 开(关) ICMP 回应(防止被ping)
临时生效的办法 关闭回应: [root@host ~]# echo 1 > /proc/sys/net/ipv4/icmp_echo_ignore_all // 客户端测试 ➜ ~ ping 0 ...
- REST SOAP Thrift 对比
别人的REST SOAP Thrift对比: 单项分数越高越好 项目 REST SOAP Thrift Extensibility 5 3 1 Neutrality 2 4 3 Independenc ...
- node环境下express路由,
1.基本路由概念 路由是指确定应用程序如何响应对特定端点的客户端请求,该请求是URI(或路径)和特定HTTP请求方法(GET,POST等). 每个路由都可以有一个或多个处理函数,这些函数在路由匹配时执 ...
- 利用python破解sqlserver账号密码
一.编写密码测试函数 在用python连接mssql数据库的时候,通常会使用pymssql模板中的connect函数,格式如下: connect(server,user,password,databa ...
- html基础学习笔记1
<!DOCTYPE html> 声明为 HTML5 文档 <html> 元素是 HTML 页面的根元素 <head> 元素包含了文档的元(meta)数据,如 &l ...
- slb
第一章 弹性负载均衡slb概要介绍 第一讲什么是弹性负载均衡slb 互联网应用的服务扩展 负载均衡诞生 slb的引出 slb产品介绍 负载均衡 server load balancer 是对多台云 ...
- 4.认识Angular组件之2
11. 变化监测:Angular提供了数据绑定的功能.所谓的数据绑定就是将组件类的数据和页面的DOM元素关联起来.当数据发生变化时,Angular能够监测到这些变化,并对其所绑定的DOM元素 进行相应 ...
- ES - 处理TooManyClause异常
1.TooManyClause 我们在使用terms query.prefix query.fuzzy query.wildcard query.range query的时候,一不小心就会遇到TooM ...
- ICE框架双工通讯+MVVM框架测试案例
准备 开发工具 VS2015 ICE框架 https://zeroc.com/ MVVMLight框架 ICE接口文件 #include "./Identity.ice" #inc ...