本次主要介绍一下我们项目中关于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. express的proxy实现前后端分离

    var express = require('express') var proxy = require('http-proxy-middleware') var app = express() ap ...

  2. java.sql.SQLException: Incorrect string value: '\xF0\x9F\x9A\x80\xF0\x9F...' for column 'name' at row 1

    1.异常提示: 12:59:10.000 [http-nio-8080-exec-40] DEBUG o.s.j.s.SQLStateSQLExceptionTranslator - Extracte ...

  3. Linux基础之-网络配置,主机名设置,ssh登陆,scp传输

    一. 网络配置修改 1.临时修改(ip,dns,netmask,gateway) 临时修改网络配置,只要没有涉及到修改配置文件的,在network服务重启后,所有设置失效 2.永久修改(ip,dns, ...

  4. MySQL--主从数据库同步原理

    主从数据库的复制原理:摘自MySQL官网 1. 异步 * 主在执行sql之后,记录二进制bin-log文件.   * 同时从连接主服务器,并从主获取binlog,存于本地relay-log,并从上次记 ...

  5. Picasso通过URL获取--用户头像的圆形显示

    1.设置布局属性: <ImageView android:scaleType="fitXY"/> 2.BitmapUtils类-- 得到指定圆形的Bitmap对象 pu ...

  6. 使用Mist部署Contract到Rinkeby以太坊网络

    本文使用MyEthWallet新建一个账号,并导入到Mist中,然后部署Contract到Rinkeby网络使用MyEthWallet新建账号的好处是除了JSON文件之外,还能得到一张它生成的pdf( ...

  7. 用CSS写扫描二维码图标

    代码如下: <style>.icon{margin:300px;width:30px;height:30px;position:relative}.icon .b{border:2px s ...

  8. 使用NPOI进行Excel数据的导入导出

  9. Graph 133. Clone Graph in three ways(bfs, dfs, bfs(recursive))

    Clone an undirected graph. Each node in the graph contains a label and a list of its neighbors. OJ's ...

  10. 记录linux查询命令的一个网站

    http://man.linuxde.net/ 另外下面是对常用命令的总结 https://www.cnblogs.com/soyxiaobi/p/9717483.html