一、安装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集群部署的更多相关文章

  1. Mongodb集群部署ReplicaSet+Sharding -摘自网络

    网上关于三种集群方式的搭建方式很多,都是分开来介绍的.Replica Set (复制集成)主要是做主从库的,但是没法实现负载均衡的效果,真正实现这个的,是Sharding(分片集群),通过数据分布在每 ...

  2. MongoDB集群部署 - 带访问控制的分片副本集

    1. 前言 Ceilometer将meter.event等数据保存在MongoDB中,之前将MongoDB部署在控制节点上,使用三副本模式,时间长了发现meter数据爆炸式增长,区区2T的磁盘捉襟见肘 ...

  3. 图解MongoDB集群部署原理(3)

    MongoDB的集群部署方案中有三类角色:实际数据存储结点.配置文件存储结点和路由接入结点. 连接的客户端直接与路由结点相连,从配置结点上查询数据,根据查询结果到实际的存储结点上查询和存储数据.Mon ...

  4. mongodb 集群部署--分片服务器搭建

    部署分片服务器 1.分片 为了突破单点数据库服务器的I/O能力限制,对数据库存储进行水平扩展,严格地说,每一个服务器或者实例或者复制集就是一个分片. 2.优势 提供类似现行增·长架构 提高数据可用性 ...

  5. MongoDB集群与LBS应用系列(二)--与Hadoop集成

    长期以来,我每开个系列,只有兴趣写一篇,很难持之与恒.为了克服这个长久以来的性格弱点,以及梳理工作半年的积累.最近一个月会写两篇关于Mongo在地理大数据方面的实践和应用,一篇关于推荐系统的初期准备过 ...

  6. mongo的集群部署

    # MongoDB 集群部署 ## 关键词 * 集群 * 副本集 * 分片 ## MongoDB集群部署 >今天主要来说说Mongodb的三种集群方式的搭建Replica Set副本集 / Sh ...

  7. centos7下安装部署mongodb集群(副本集模式)

    环境需求:Mongodb集群有三种模式:  Replica Set, Sharding,Master-Slaver.  这里部署的是Replica Set模式. 测试环境: 这里副本集(Replica ...

  8. 在Docker中安装和部署MongoDB集群

    此文已由作者袁欢授权网易云社区发布. 欢迎访问网易云社区,了解更多网易技术产品运营经验. 在Docker中安装mongodb 采用的mongodb镜像:https://registry.hub.doc ...

  9. 手把手教你用Docker部署一个MongoDB集群

    MongoDB是一个介于关系数据库和非关系数据库之间的产品,是非关系数据库当中最像关系数据库的.支持类似于面向对象的查询语言,几乎可以实现类似关系数据库单表查询的绝大部分功能,而且还支持对数据建立索引 ...

随机推荐

  1. web前端调试的消除缓存对更改页面的影响

    平时调试网页的时候经常会短时间多次修改html和css文件,已达到最好的体验效果,但是有时候因为浏览器缓存的原因就导致虽然代码修改了,但是 页面还是没什么变化, 经常以为是自己代码修改的不对, 之后发 ...

  2. Mac OS X L2TP Client Setup

    原文链接:http://www.softether.org/4-docs/2-howto/9.L2TPIPsec_Setup_Guide_for_SoftEther_VPN_Server/5.Mac_ ...

  3. 部署activiti 5.15.1的Activiti Explorer

    1.从官网下载activiti包,将其中的activiti-explorer.war文件拷贝到tomcat的webapps目录下: 2.将mysql驱动包文件mysql-connector-java- ...

  4. NFC 大电池 高性价比手机

    NFC 大电池 高性价比手机三星 Galaxy A60元气版 黑瞳全视屏 3200万超广角拍照手机 骁龙675 6GB+64GB 丹宁黑 全网通4G 双卡双待 1499 https://item.jd ...

  5. delphi 多线程之 TEvent 和 TLightweightEvent

    unit Unit1; interface uses Winapi.Windows, Winapi.Messages, System.SysUtils, System.Variants, System ...

  6. redis订阅发布消息操作本地缓存

    Redis 本地缓存+远程缓存方案 使用纯java的ehcache作为本地缓存 Reids 作为远程分布式缓存 解决redis缓存压力过大,提高缓存速度,以及缓存性能. Redis和ehcache缓存 ...

  7. nginx配置备份

    server { listen 80; server_name localhost; set $expires_duration "30d"; if ($uri ~* \.html ...

  8. mpt2sas0: log_info(0x31120100): originator(PL), code(0x12), sub_code(0x0100)及同类问题的追踪

    做存储或者磁盘阵列的经常会遇到linux kernel打印如下信息或者类似的信息,这是什么原因导致的呢? mpt2sas0: log_info(0x31120100): originator(PL), ...

  9. 浏览器打开aspx文件 ,提示:XML 解析错误:找不到根元素

    在使用VS2013这个IDE创建aspx文件后,在浏览器打开后居然发现了以下错误:XML 解析错误:找不到根元素         详细查看里面的信息,发现了这么一个链接位置:http://localh ...

  10. [蓝桥杯]PREV-15.历届试题_格子刷油漆

    题目描述: 代码如下: #include <stdio.h> #include <stdlib.h> #include <string.h> #define MOD ...