mongodb3.4.0复制集的搭建
本次主要介绍一下我们项目中关于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复制集的搭建的更多相关文章
- Redis 5.0.5集群搭建
Redis 5.0.5集群搭建 一.概述 Redis3.0版本之后支持Cluster. 1.1.redis cluster的现状 目前redis支持的cluster特性: 1):节点自动发现 2):s ...
- redis4.0.6集群搭建
文件环境:CentOS7 + redis4.0.6 先去官网下载redis:https://redis.io/,然后上传到你的虚拟机,我上传到了/mysoft 先解压->然后进入主目录-> ...
- mongoDB3.4的sharding集群搭建及JavaAPI的简易使用
第一部分 在搭建mongoDB之前,我们要考虑几个小问题: 1.我们搭建集群的目的是什么?是多备份提高容错和系统可用性还是横向拓展存储大规模数据还是两者兼有? 如果是为了多备份那么选择replicat ...
- redis5.0 Cluster集群搭建
安装redis sudo apt update sudo apt install build-essential tcl cd ~ mkdir document/ cd document/ curl ...
- ubuntu18.04 基于Hadoop3.1.2集群的Hbase2.0.6集群搭建
前置条件: 之前已经搭好了带有HDFS, MapReduce,Yarn 的 Hadoop 集群 链接: ubuntu18.04.2 hadoop3.1.2+zookeeper3.5.5高可用完全分布式 ...
- mongodb3.2.3 复制集安装步骤
mongodb 复制集 测试 node1: 172.18.20.161 47000 (主)node2: 172.18.20.162 47000 (副)node3: 172.18.20.163 4700 ...
- java_redis3.0.3集群搭建
redis3.0版本之后支持Cluster,具体介绍redis集群我就不多说,了解请看redis中文简介. 首先,直接访问redis.io官网,下载redis.tar.gz,现在版本3.0.3,我下面 ...
- Redis 3.0.2集群搭建以及相关问题汇总
Redis3 正式支持了 cluster,是为了解决构建redis集群时的诸多不便 (1)像操作单个redis一样操作key,不用操心key在哪个节点上(2)在线动态添加.删除redis节点,不用停止 ...
- Hadoop2.0 HA集群搭建步骤
上一次搭建的Hadoop是一个伪分布式的,这次我们做一个用于个人的Hadoop集群(希望对大家搭建集群有所帮助): 集群节点分配: Park01 Zookeeper NameNode (active) ...
随机推荐
- 使用QQ第三方登录 并在父页面跳转刷新
<html> <head> <title>QQ登录跳转</title> <script src="http://lib.sinaapp. ...
- bzoj2119 [ZJOI2010]base基站选址
传送门 n年前的考试题,今天才填上…… 听说你们会决策单调性+主席树?然而我多年不写决策单调性,懒得写了……于是就写了一发线段树. 其实线段树应该不难想,毕竟转移是分层转移,并且这个题的转移函数可以快 ...
- C#——Visual Studio项目中的AssemblyInfo.cs文件包含的配置信息
Visual Studio程序集项目中的AssemblyInfo.cs文件中的内容 using System.Reflection; using System.Runtime.CompilerServ ...
- chengfa
public class ddddd{ public static void main(String[] args) { ; ; i <= m; i++) { ; j <= i; j++) ...
- C#网易云音乐播放器
效果图: •实现教程: 打开VStudio 2015 #新建一个windows界面工程然后按我的界面来添加控件代码如下 namespace NeteaseMuisc { partial class M ...
- 函数arguments对象
一.arguments对象 arguments 是一个对应于传递给函数的参数的类数组对象. 二.语法 arguments 三.描述 arguments对象是所有(非箭头)函数中都可用的局部变量.你可以 ...
- 第三次Scrum
1.小组成员 周 斌舒 溢许嘉荣唐 浩黄欣欣廖帅元刘洋江薛思汝 2.小组第三次冲刺完成情况 github仓库小组的第三次任务是完成体系结构环境图和系统原型图.在体系结构设计中,分为上级系统----把目 ...
- apache2 tomat https 变成http的解决方案
1.apache2 设置 RequestHeader set X-Forwarded-Proto "https" 2.springboot 设置 server.tomcat.p ...
- Azure 中 Linux 虚拟机的大小
本文介绍可用于运行 Linux 应用和工作负荷的 Azure 虚拟机的可用大小与选项. 此外,还提供在计划使用这些资源时要考虑的部署注意事项. 本文也适用于 Windows 虚拟机. 类型 大小 说明 ...
- How I explained OOD to my wife
Introduction My wife Farhana wants to resume her career as a software developer (she started her car ...