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) ...
随机推荐
- mysql if函数使用例子
1.场景一 有时查询数量a 同时查询过滤后的数量b 2. 代码 SELECT count(id) as total_count, count( IF ( date(order_time) = DATE ...
- html+css 布局篇
float 做了float后有一些不好的影响. 1.背景不能显示 由于浮动产生,如果对父级设置了(CSS background背景)CSS背景颜色或CSS背景图片,而父级不能被撑开,所以导致CSS背景 ...
- 纯css模仿天猫首页
<style> *{margin:0;padding:0} li{list-style:none} a{text-decoration:none} #wrapper{font: 12px/ ...
- 购物车动画(Android)
购物车动画(Android) 前言:当我们写商城类的项目的时候,一般都会有加入购物车的功能,加入购物车的时候会有一些抛物线动画,最近做到这个功能,借助别人的demo写了一个. 效果: 开发环境:And ...
- restful知识点之二restframework视图
restful协议理解:面向资源开发 restful协议 ---- 一切皆是资源,操作只是请求方式 ----book表增删改查 /books/ books /books/add/ addbook /b ...
- Echarts实现隐藏x轴,y轴,刻度线,网格
"yAxis": [ { //就是一月份这个显示为一个线段,而不是数轴那种一个点点 "show" : true, "boundaryGap" ...
- HTML 水平线hr
HTML 水平线 <hr /> 标签在 HTML 页面中创建水平线. hr 元素可用于分隔内容. 实例 <p>This is a paragraph</p> < ...
- undo表空间不足,ORA-30036: unable to extend segment by 8 in undo tablespace 'UNDOTBS2'
故障现象:UNDO表空间越来越大,长此下去最终数据因为磁盘空间不足而崩溃: 问题分析:本问题在ORACLE系统管理中属于比较正常的一现象,产生问题的原因主要以下两点: 1. 有较大的事务量让Oracl ...
- PHP实现无限分类
PHP实现无限分类 无限分类 递归 无限级分类是一种设计技巧,在开发中经常使用,例如:网站目录.部门结构.文章分类.笔者觉得它在对于设计表的层级结构上面发挥很大的作用,比如大家在一些平台上面,填写邀请 ...
- Memory Leak Detection in C++
原文链接:http://www.linuxjournal.com/article/6556?page=0,0 An earlier article [“Memory Leak Detection in ...