mongodb3.4.4安装副本集,分片和遇到的一些问题(一)

废话不多说

三台机器

host1,host2,host3

查看官方安装文档https://docs.mongodb.com/manual/tutorial/install-mongodb-on-red-hat/

编辑源文件

vim /etc/yum.repos.d/mongodb-org-3.4.repo

[mongodb-org-3.4]
name=MongoDB 
Repositorybaseurl=gpgcheck=1
enabled=1
gpgkey=https://www.mongodb.org/static/pgp/server-3.4.asc

安装

yum install -y mongodb-org

由于我是在3台虚拟机上做的,宿主机其实是一个,所以配置了3个端口,

注意:mongod的配置文件遵循yaml文件格式!

[[email protected] ~]# cat /etc/mongod.conf 
# mongod.conf

# for documentation of all options, see:
#   http://docs.mongodb.org/manual/reference/configuration-options/

# where to write logging data.
systemLog:
  destination: file
  logAppend: true
  path: /var/log/mongodb/mongod.log

# Where and how to store data.
storage:
  dbPath: /var/lib/mongo
  journal:
    enabled: true
#  engine:
#  mmapv1:
#  wiredTiger:

# how the process runs
processManagement:
  fork: true  # fork and run in background
  pidFilePath: /var/run/mongodb/mongod.pid  # location of pidfile

# network interfaces
net:
  port: 27017
#  bindIp: 127.0.0.1  # Listen to local interface only, comment to listen on all interfaces.

#security:
#keyFile = /opt/key/autokey
#operationProfiling:

#replication:
replication:
   oplogSizeMB: 1000
   replSetName: rstest
#sharding:

## Enterprise-Only Options

#auditLog:

#snmp:

基本上是默认配置,dbdata位置和log目录看具体情况,酌情修改,bindip 默认是打开的,注销了,不然mongo只会本地访问

启动

mongod -f /etc/mongod.conf

这时可以随便进入一台mongod 进行副本集的初始化

mongo 进入,默认是27017端口,但是如果改变端口,就要用mongo ip:port的方式了

首先加载配置

config={_id:"rstest",members:[{_id:0,host:"host1:port"},{_id:1,host:"host2:port"},{_id:2,host:"host3:port"}]}
##_id 必须是配置文件中副本集的名字

副本集初始化

rs.initiate(config)

这里有一点要注意,要保证每台mongodb的之间的连通性,和每个mongo都是空数据,不然在建立副本集的时候会报错,如果数据库不是空的,必须要先剔除副本集,然后删除db.dropDatabase()

最后配置生效

rs.reconfig(config)

日常的横向扩展和伸缩,以及手动配置主节点

PRIMARY> rs.add("127.0.0.1:27018");   //添加节点
PRIMARY> rs.remove("127.0.0.1:27018"); //删除节
这两个命令是不需要做rs.reconfig(config)配置生效的
rs.conf()// 查看配置
config=rs.conf() //读取配置
config.members[1].priority = N // N = 1到100 越大越优先变主节点
rs.reconfig(config) //让配置生效,一会就host2 就会变成主节点

选举的算法:

mongodb 集群的选择局算法其实和zookeeper差不多,区别在于用的是bully算法,mongod 会先对比谁是最后一次进行数据操作的,也就是说,谁的数据最新,如果数据一样,那么就会对比谁可以用最短的时间成为主节点,选举过程和zookeeper一样,只是对比k-v不太一样。

另外,在集群的选举过程中,不想让某个从节点变成主节点,可以用

rs.freeze(120) //小括号里的数据是冻结时间,也就是说在120秒内该节点不可以变成主节点,单位秒
时间: 2024-12-12 12:21:06

mongodb3.4.4安装副本集,分片和遇到的一些问题(一)的相关文章

mongodb3.4.4安装副本集,wt引擎配置优化(二)

今天大概研究下wiredtiger引擎,mongo从3.0开始引入,主要为了解决吃内存多,占用大量磁盘空间的问题,其实即使用了wt引擎,在性能上还是比tokuft要差,但是tokuft 在功能上代码迭代的太慢,退而求其次大家还是用了mongo,首先3.0的时候默认还是mmapv1 引擎,所以需要重新指定wt引擎,从3.2版本后就是默认了wt了,我用的现在是3.4  主要是配置上的优化,看了好多人的写的东西,都特么是抄的,我写个官方文档上的吧,以此记录 storage.wiredTiger Opt

Centos6.6搭建mongodb3.2.6副本集分片

1.环境准备centos6.6 x64 3台192.168.0.23192.168.0.24192.168.0.201 2.集群规划每个机器同时启动mongos.config server .shard0.shard2.shard3,config server得ip端口分别为:192.168.0.23:1111,192.168.0.24:1111,192.168.0.201:1111mongos得ip端口分别为:192.168.0.23:2222,192.168.0.24:2222,192.16

Mongodb 副本集+分片集群搭建

环境需求: 在三台机器上搭建副本集,在副本集上做分片 服务器IP: 192.168.1.232/192.168.1.238/192.168.1.241 安装Mongodb all nodes: tar zxvf mongodb-linux-x86_64-rhel62-3.4.4.tgz cp -rvf  mongodb-linux-x86_64-rhel62-3.4.4  /opt/mongodb_3.4.4 cd /opt/mongodb_3.4.4/ mkdir -pv conf logs

搭建mongodb集群(副本集+分片)

完整的搭建mongodb集群(副本集+分片)的例子... 准备四台机器,分别是bluejoe1,bluejoe2,bluejoe3,以及bluejoe0 副本集及分片策略确定如下: 将创建3个副本集,命名为shard1,shard2,shard3: 以上3个副本集作为3个分片: 每个副本集包含2个副本(主.辅): 副本分开存储,即shard1存在bluejoe1和bluejoe2上各一份...以此类推 将创建3个配置库实例,一台机器一个 bluejoe0上配置一个mongos(mongos一般可

MongoDB 副本集+分片 认证方式搭建

MongoDB 副本集+分片 认证方式搭建 参考资料: https://www.cnblogs.com/ityouknow/p/7344005.htmlhttps://jorwen-fang.iteye.com/blog/2031756https://www.cnblogs.com/bjx2020/p/9350232.htmlhttps://www.jb51.net/article/161315.htmhttps://blog.51cto.com/beigai/1751381 环境规划: 服务器

Mongodb 副本集分片(一)---初始化mongodb安装启动

写在前面:mongodb是nosql非关系型数据库中,比较受欢迎的产品.在数据持久化及与关系型数据库的关联上也做的比较好,目前各大公司在存放二进制文件(图片.视频等)中应用也比较广泛.其遵循的key-value的数据模式及面向对象的json语句用法,也比较简单.在之后,会系列的跟大家分享,我在学习及生产应用中,使用到的mongodb的一些心得.希望大家共同学习,共同研究探讨.谢谢. 以下内容,是简单的将整个mongodb的安装过程,进行shell脚本化编辑.很简单的脚本编写.如有任何问题,欢迎大

【未完】mongodb安装+副本集搭建+数据导入

参考文档:1-centos6.5下MongoDB2.6.4安装配置记录 http://blog.csdn.net/ligaofeng/article/details/39374333 2-mongodb中的副本集搭建实践 http://www.cnblogs.com/visionwang/p/3290435.html

MongoDB 高可用集群副本集+分片搭建

MongoDB 高可用集群搭建 一.架构概况 192.168.150.129192.168.150.130192.168.150.131 参考文档:https://www.cnblogs.com/vadim/p/7100683.html mongos mongos    mongos Config   server      Config server  Config serverShared1 server 1 Shared1 server 1 副本 Shared1 server 1 仲裁/隐

mongodb3.6集群搭建:分片+副本集

mongodb是最常用的noSql数据库,在数据库排名中已经上升到了前五.这篇文章介绍如何搭建高可用的mongodb(分片+副本)集群. 在搭建集群之前,需要首先了解几个概念:路由,分片.副本集.配置服务器等.相关概念mongodb集群架构图: 从图中可以看到有四个组件:mongos.config server.shard.replica set.mongos,数据库集群请求的入口,所有的请求都通过mongos进行协调,不需要在应用程序添加一个路由选择器,mongos自己就是一个请求分发中心,它