本次主要介绍一下我们项目中关于mongodb复制集的搭建过程。

部署三台mongodb,分别是在69,70,71上面。71上面是主节点,69和70是从节点。使用mongodb3.4.0版本。

先看一安装完后的目录结构:

/u04

--mongodb

--data  数据文件目录

--logs

--mongo.log

--mongodb3.4  安装目录

--bin

--keyfile.dat  集群通信的文件

--mongo.conf

--mongodb.pid

--mongoDbStart.log  --启动日志文件

--mongoDbStart.sh  --启动脚本

准备

先su root

再mkdir u04/mongodb -p

chown -R sysadm:sysadm u04

开始

一、将mongodb-linux-x86_64-3.4.0.tgz上传到mongodb目录下面。

解压到当前目录的mongodb3.4目录中。

二、建立data目录

建立logs目录,在logs目录下面创建mongo.log文件。 touch mongo.log

创建mongo.conf文件。Vim mongo.conf文件,输入下面的内容:

#数据库路径

dbpath=/u04/mongodb/data

#日志输出文件路径

logpath=/u04/mongodb/logs/mongo.log

#错误日志采用追加模式

logappend=true

#启用日志文件,默认启用

journal=true

#这个选项可以过滤掉一些无用的日志信息,若需要调试使用请设置为false

quiet=true

#端口号 默认为27017

port=27017

#pidfile文件

pidfilepath=/u04/mongodb/mongodb.pid

#开启权限

#auth=true

#后台运行

fork=true

创建mongoDbStart.sh文件,输入下面的内容:

/u04/mongodb/mongodb3.4/bin/mongod --config /u04/mongodb/mongo.conf

修改mongoDbStart.sh的权限:

chmod 777 mongoDbStart.sh

启动测试

nohup  /u04/mongodb/mongoDbStart.sh >mongoDbStart.log 2>&1 &

测试连接是否成功:mongo ip:port

只要能连接上就行,不要执行其它操作(因为初始化复制集的时候要保证mongodb里面没有数据和用户)

使用命令:/u04/mongodb/mongodb3.4/bin/ mongo  x.x.x.71:27017

使用robo来连接:

关闭mongodb,切记 kill -9 PID

而是使用Kill -2 PID 这样会让mongodb数据库在关闭之前做一下收尾的处理。

重复以上步骤在69和70上面,建立mongodb的从节点,然后测试是否成功连接。切记不要执行创建用户创建数据等任何操作。

创建复制集

修改三个配置文件:复制集名称:gjywset

replSet=gjywset

echo replSet=gjywset >> mongo.conf

(也可以直接将replSet=gjywset提前写入mongo.conf文件中,节省了上面的测试是否能够链接成功一步。)

启动三个mongodb数据库。

1、初始化复制集:

登录到71节点上,/u04/mongodb/mongodb3.4/bin/ mongo  x.x.x.71:27017

(要是一个完全新的mongodb数据库才能初始化,如果已经创建用户或者创建数据库/集合等,就不能初始化成功了)

①:输入:

config = {

_id:"gjywset",

members:[

{_id:0,host:"x.x.x.71:27017","priority":3},

{_id:1,host:"x.x.x.70:27017","priority":2},

{_id:2,host:"x.x.x.69:27017","priority":1}

]

}

参数说明:arbiterOnly表示是一个仲裁节点。(本次没有使用)

priority:表示权重,数据越大越有可能成为主节点

②:执行初始化:rs.initiate(config);

③:使用rs.status()查看状态   显示71上的27017为主节点。

2、测试:

连接71上的27017:

use admin

use yujk

db

db.yjklog.insert({name:"zhangsan",age:11,sex:"男"})

db.yjklog.insert({name:"lisi",age:22,sex:"男"})

db.yjklog.insert({name:"王力宏",age:22,sex:"女",address:"外星移民"})

db.yjklog.insert({name:"花无缺",age:22,address:"广东丰台区nalinanbian"})

db.yjklog.find();

连接69上的27017:

db

show dbs  报错

rs.slaveOk(1);

show dbs;

use yujk;

show tables;

db.yjklog.find();

演示完成。

权限开启:

#########开启角色权限的校验###############root权限包含了any的四个全部的权限,什么权限都有。

开启角色权限:

(1)先创建用户:yjkroot和yjkhost

use admin

db.createUser({user:" yjkroot",pwd:"gjywroot",roles:[{role:"root",db:"admin"},{role:"readWrite",db:"yujk"}]})  #这样设置,要有root的角色

use yujk

db.createUser({user:"yjkhost",pwd:"yjkhost",roles:[{role:"readWrite",db:"yujk"}]})

关掉三个节点。

(2)在配置文件中将author=true打开  三个配置文件都要打开。

(3)连接x.x.x.71:27017主节点,

use admin

db.auth("yjkroot","yjkroot");

rs.status();发现还没有配置keyfile,即不同节点直接是不信任的状态--->>"authenticated" : false

关闭三个节点。Kill -2 mongopid

(4)使用openssl生成密钥文件

cd /u04/mongodb

openssl  rand -base64 30 > keyfile.dat  #30位的长度

修改文件权限:chmod 600 keyfile.dat

(5)将keyfile文件拷贝到69和70服务器的mongodb目录下

(6)修改配置文件启用keyfile文件  keyFile=/u04/mongodb/keyfile.dat

echo keyFile=/u04/mongodb/keyfile.dat >> mongo.conf

(7)启动三个节点:参照上面的方式.

nohup  /u04/mongodb/mongoDbStart.sh >mongoDbStart.log 2>&1 &

至此,mongodb复制集就安装好了。

推荐一个慕课网上面老师讲解mongodb的,

https://www.imooc.com/u/1196301/courses?sort=publish

https://www.cnblogs.com/clsn/p/8214194.html

https://www.cnblogs.com/clsn/p/8214345.html

https://www.cnblogs.com/clsn/p/8244206.html

优先级设置priority和votes:

https://blog.csdn.net/jjwen/article/details/53944503

mongodb3.4.0复制集的搭建的更多相关文章

  1. Redis 5.0.5集群搭建

    Redis 5.0.5集群搭建 一.概述 Redis3.0版本之后支持Cluster. 1.1.redis cluster的现状 目前redis支持的cluster特性: 1):节点自动发现 2):s ...

  2. redis4.0.6集群搭建

    文件环境:CentOS7 + redis4.0.6 先去官网下载redis:https://redis.io/,然后上传到你的虚拟机,我上传到了/mysoft 先解压->然后进入主目录-> ...

  3. mongoDB3.4的sharding集群搭建及JavaAPI的简易使用

    第一部分 在搭建mongoDB之前,我们要考虑几个小问题: 1.我们搭建集群的目的是什么?是多备份提高容错和系统可用性还是横向拓展存储大规模数据还是两者兼有? 如果是为了多备份那么选择replicat ...

  4. redis5.0 Cluster集群搭建

    安装redis sudo apt update sudo apt install build-essential tcl cd ~ mkdir document/ cd document/ curl ...

  5. ubuntu18.04 基于Hadoop3.1.2集群的Hbase2.0.6集群搭建

    前置条件: 之前已经搭好了带有HDFS, MapReduce,Yarn 的 Hadoop 集群 链接: ubuntu18.04.2 hadoop3.1.2+zookeeper3.5.5高可用完全分布式 ...

  6. mongodb3.2.3 复制集安装步骤

    mongodb 复制集 测试 node1: 172.18.20.161 47000 (主)node2: 172.18.20.162 47000 (副)node3: 172.18.20.163 4700 ...

  7. java_redis3.0.3集群搭建

    redis3.0版本之后支持Cluster,具体介绍redis集群我就不多说,了解请看redis中文简介. 首先,直接访问redis.io官网,下载redis.tar.gz,现在版本3.0.3,我下面 ...

  8. Redis 3.0.2集群搭建以及相关问题汇总

    Redis3 正式支持了 cluster,是为了解决构建redis集群时的诸多不便 (1)像操作单个redis一样操作key,不用操心key在哪个节点上(2)在线动态添加.删除redis节点,不用停止 ...

  9. Hadoop2.0 HA集群搭建步骤

    上一次搭建的Hadoop是一个伪分布式的,这次我们做一个用于个人的Hadoop集群(希望对大家搭建集群有所帮助): 集群节点分配: Park01 Zookeeper NameNode (active) ...

随机推荐

  1. java 生成和解析xml

    本文主要使用的是Jdom.jar包(包的下载百度一下)实现了生成xml文件和解析xml文件 下面是生成xml的实现 说明:stuLists集合是一个存放着Student对象的集合 import jav ...

  2. 远程连接Redis服务器

    建立了一个redis服务器,那么其他主机应该怎么连接上呢? /** * * 修改redis.conf配置文件 * */ // 1. 注释掉bind绑定配置 // 2. 搜索并修改为 protected ...

  3. BBS需求分析和orm设计

    一.BBS博客需求分析 首页(现实文章) 文章详情 点赞 文章评论(子评论,评论的展示) 登录功能(图片验证码) 注册功能(基于form验证) 个人站点(不同人不同样式,文章过滤) 后台管理(文章展示 ...

  4. 类中调用界面ActiveX控件报错当前线程不在单线程单元中因此无法实例化 ActiveX 控件的解决办法

    解决办法是Form类中定义一个静态的ActiveX对象,在formload中将界面上的ActiveX对象赋值给新定义的对象,类中访问该静态对象即可. public static AxClientDri ...

  5. easyui window窗口 随body的滚动条 滚动

    问题描述: 当easyui window窗口弹出的时候,依然可以滚动body 的滚动条,而且window窗口也会随它一起滚动 思路:bootstrap 模态框弹出的时候,给body 添加了 .moda ...

  6. 139.00.009提高Github Clone速度

    @(139 - Environment Settings | 环境配置) Method 1 :SS+系统内置代理 用 git 内置代理,直接走系统中运行的代理工具中转,比如,你的 SS 本地端口是 1 ...

  7. c# 修改winform中app.config的配置值

    public bool ChangeConfig(string AppKey,string AppValue) { bool result = true; try { XmlDocument xDoc ...

  8. jq扩展

    方法一(不常用)$.myjq = function(){alert("hello myjQuery);}方法二声明:$.fn.myjq=function(){$(this).text(&qu ...

  9. Microsoft.Exchange 发邮件

    //Microsoft.Exchange.WebServices.dll ExchangeService service = new ExchangeService(); // 获取身份验证, 能够尝 ...

  10. pt-find使用

    查找MySQL的表,并且做一些操作,基本语法就如下: pt-find [OPTIONS] [DATABASES] (1)查找一天前建立的MyISAM 引擎的表 [root@mxqmongodb2 bi ...