单台mongodb配置文件:

dbpath=/opt/mongodb/data
logpath=/opt/mongodb/logs/mongodb.log
logappend=true
fork=true
bind_ip=192.168.209.128
port=27017

启动MongoDB

./mongod -f mongodb.cfg


MongoDB 主从搭建

MongoDB 4.0之后不再支持该配置方法:

Master配置文件如下:

dbpath=/opt/mongodb/master-slave/master/data
logpath=/opt/mongodb/master-slave/master/logs/mongodb.log
logappend=true
fork=true
bind_ip=192.168.209.128
port=27001
master=true //4.0后不再支持
//source=192.168.x.x:27002

Slaver配置如下:

..........

slave=true

............

MongoDB 副本集

简单来说就是集群当中包含了多份数据,保证主节点挂掉了,备节点能继续提供数据服务,提供的前提就是数据需要和主节点一致。

Mongodb(M)表示主节点,Mongodb(S)表示备节点,Mongodb(A)表示仲裁节点。
1. 主备节点存储数据,仲裁节点不存储数据。客户端同时连接主节点与备节点,不连接仲裁节点。
默认设置下,主节点提供所有增删查改服务,备节点不提供任何服务。但是可以通过设置使备节点提供查询服务,这样就可以减少主节点的压力,当客户端进行数据查询时,请求自动转到备节点上。这个设置叫做Read Preference Modes,同时Java 客户端提供了简单的配置方式,可以不必直接对数据库进行操作。
2.仲裁节点是一种特殊的节点,它本身并不存储数据,主要的作用是决定哪一个备节点在主节点挂掉之后提升为主节点,所以客户端不需要连接此节点。这里虽然只有一个备节点,但是仍然需要一个仲裁节点来提升备节点级别。

主, 备, 仲裁节点配置文件如下:

dbpath=/opt/mongodb/replset/xx/data
logpath=/opt/mongodb/replset/xx/logs/mongodb.log
logappend=true //注意: 这里是关键, 记录集群的名字
replSet=shard002
bind_ip=192.168.x.x
port=27017
fork=true

启动各节点之后, 配置主,备,仲裁节点

#连接好其中一台主机, 方便配置
mongo 192.168.x.x:27017
use admin
cfg={_id:"shard002",members:[{_id:0,host:'192.168.x.128:27017',priority:9},{_id:1,host:'192.168.x.129:27017',priority:1},{_id:2,host:'192.168.x.130:27017',arbiterOnly:true}]}; #使配置生效
rs.initiate(cfg) rs.status()

注意: 对于仲裁节点,需要有个特别的配置——arbiterOnly:true。这个千万不能少了,不然主备模式就不能生效。


MongoDB 数据分片:

服务器结构图如下:

1). 数据节点配置文件:

dbpath=/opt/mongodb/shard/replset/replica2/data
logpath=/opt/mongodb/shard/replset/replica2/logs/mongodb.log
logappend=true
fork=true
bind_ip=192.168.x.x
port=27002
replSet=shard001
shardsvr=true

使数据节点集群生效

//#连接上其中一台数据服务器,进行其余配置
mongo 192.168.209.128:27001 #ip 和port 是某个节点的地址 cfg={_id:"shard001",members:[{_id:0,host:'192.168.209.x:27001'},{_id:1,host:'192.168.209.x:27002'},{_id:2,host:'192.168.209.x:27003'}]}; //#使配置生效
rs.initiate(cfg)

2). config 集群配置文件如下:

dbpath=/opt/mongodb/shard/configsvr/config2/data
configsvr=true
//此处端口号根据实际应用调整
port=28002
fork=true
logpath=/opt/mongodb/shard/configsvr/config2/logs/mongodb.log
replSet=configrs
logappend=true
bind_ip=192.168.209.x

启动config集群,并使节点集群生效

##连接上其中一台数据服务器,进行其余配置
mongo 192.168.209.x:28001 #先切换到admin
use admin cfg={_id:"configrs",members:[{_id:0,host:'192.168.209.x:28001'},{_id:1,host:'192.168.209.x:28002'},{_id:2,host:'192.168.209.x:28003'}]}; #使配置生效
rs.initiate(cfg)

3). 路由集群配置文件如下:

//此处配置config集群的地址
configdb=configrs/192.168.209.x:28001,192.168.209.x:28002,192.168.209.x:28003
//此处端口号根据实际应用调整
port=29000
fork=true
logpath=/opt/mongodb/shard/routesvr/logs/mongodb.log
logappend=true
bind_ip=192.168.209.x

4). 配置Replica Set 分片信息

//#这里必须连接路由节点
mongo 192.168.209.x:29000 //#连接上数据集群中的其中一台,自动同步集群中其他机器信息
sh.addShard("shard001/192.168.209.x:27001"); //#连接上collection[testdb], 并设置分片
use testdb //#testdb is database name
sh.enableSharding("testdb") sh.shardCollection("testdb.testcon",{"name":”hashed”}) db.collection.status()

MongoDB集群配置笔记二(实战)的更多相关文章

  1. MongoDB集群配置笔记一

    MongoDB 的部署方案有单机部署.复本集(主备)部署.分片部署.复本集与分片混合部署.混合的部署方式如图: 分片集群的构造 (1)mongos :数据路由,和客户端打交道的模块.mongos本身没 ...

  2. MongoDB集群配置笔记

    firewall-cmd --query-port=27017/tcp yum install system-config-firewall-tui firewall-cmd --zone=publi ...

  3. 实例:Mongodb集群配置过程

    最近因为一些项目公司开始采用Mongodb做为大量的数据存储,通过网络上大量的资源自己已经掌握一套可行的Mongodb集群配置过程,Mongodb具有无规则存储.大数据存储.多平台支持.强大的扩展插件 ...

  4. Mongodb集群配置(sharding with replica set)

    转自:http://blog.csdn.net/zhangzhaokun/article/details/6269514 前言 最近在研习MongoDB集群,找到一个不错的例子,加了几句,按照自己的理 ...

  5. mongodb集群配置及备份恢复

    Mongodb安装: 编辑/etc/yum.repos.d/mongodb.repo,添加以下: [MongoDB] name=MongoDB Repository baseurl=https://r ...

  6. zookeeper集群配置与启动——实战

    1,准备: A:三台linxu服务器: 10.112.29.177 10.112.29.172 10.112.29.174 命令 hostname 得到每台机器的 hostname vm-10-112 ...

  7. mongodb集群+分片部署(二)

    机器:10.165.38.68    10.165.38.72 部署包:mongodb-linux-x86_64-rhel55-3.0.2.tgz(百度云盘下载地址:http://pan.baidu. ...

  8. mongodb集群配置副本集

    测试环境 操作系统:CentOS 7.2 最小化安装 主服务器IP地址:192.168.197.21 mongo01 从服务器IP地址:192.168.197.22 mongo02 从服务器IP地址: ...

  9. mongodb集群配置分片集群

    测试环境 操作系统:CentOS 7.2 最小化安装 主服务器IP地址:192.168.197.21 mongo01 从服务器IP地址:192.168.197.22 mongo02 从服务器IP地址: ...

随机推荐

  1. [openjudge-搜索]广度优先搜索之鸣人和佐助

    题目描述 描述 佐助被大蛇丸诱骗走了,鸣人在多少时间内能追上他呢?已知一张地图(以二维矩阵的形式表示)以及佐助和鸣人的位置.地图上的每个位置都可以走到,只不过有些位置上有大蛇丸的手下,需要先打败大蛇丸 ...

  2. 2.scrapy安装

    A.Anaconda如果已安装,那么可以通过 conda 命令安装 Scrapy,安装命令如下: conda install Scrapy   ============================ ...

  3. yum 原理C/S原理结构图

    yum 原理C/S原理结构图

  4. 刨根究底字符编码之—UTF-16编码方式

    在网上已经转悠好几天了, 这篇文章让我知道了UTF-16的前世今生, 感谢作者https://cloud.tencent.com/developer/article/1384687 1. UTF-16 ...

  5. python pymssql 连接数据库

    1)写在前面 远程连接数据库的时候,端口前面都是用的逗号, 因为惯性思维, 就傻傻的把    ip+,+端口 赋值给server了,然后一直报错, pymssql.InterfaceError: Co ...

  6. 设计模式之Builder(建造者)(转)

    Builder模式定义: 将一个复杂对象的构建与它的表示分离,使得同样的构建过程可以创建不同的表示. Builder模式是一步一步创建一个复杂的对象,它允许用户可以只通过指定复杂对象的类型和内容就可以 ...

  7. 【转】求职面试-HR会问你什么问题?

    前言 面试是程序员们经常探讨的话题,只要你通过前面的技术面,最后一面必然是HR面试,基本上到了这关你离Offer的距离应该不会太远了,但有的公司的HR是有刷入的权利,如果你并不能很好的应对HR的问题, ...

  8. Selenium自动化测试,接口自动化测试开发,性能测试从入门到精通

    Selenium自动化测试,接口自动化测试开发,性能测试从入门到精通Selenium接口性能自动化测试基础部分:分层自动化思想Slenium介绍Selenium1.0/2.0/3.0Slenium R ...

  9. docker Dockerfile指令ADD和COPY的区别,添加目录方法

    docker Dockerfile指令ADD和COPY的区别,添加目录方法 ADD指令的功能是将主机构建环境(上下文)目录中的文件和目录.以及一个URL标记的文件 拷贝到镜像中.其格式是: ADD 源 ...

  10. Codeforces 841A - Generous Kefa

    题目链接:http://codeforces.com/problemset/problem/841/A One day Kefa found n baloons. For convenience, w ...