软件版本64位:
$ wget https://fastdl.mongodb.org/linux/mongodb-linux-x86_64-rhel62-3.2.0.tgz
mongodb-linux-x86_64-rhel62-3.2.0.tgz
服务器3台:
192.168.1.20 (master[PRIMARY])
192.168.1.21 (slave[SECONDARY])
192.168.1.22 (仲裁[ARBITER])
参考:
$ tar -zxvf mongodb-linux-x86_64-rhel62-3.2.0.tgz /opt
$ mv mongodb-linux-x86_64-rhel62-3.2.0 mongodb
$ mkdir -p /opt/mongodb/{conf,data,logs} #解压后创建目录conf data logs
####################mongodb配置文件(/opt/mongodb/conf/mongodb.conf )########
#存放的数据文件目录
dbpath=/opt/mongodb/data
#日志文件目录
logpath=/opt/mongodb/logs/master.log
#加密文件,用户集群连接验证
#keyFile=/opt/mongodb/mongodb.key
#日志追加
logappend=true
#副本集名称
replSet=repset
#绑定
bind_ip=192.168.1.20
#端口号
port=27017
#启动用户名密码验证
#auth=true
#以守护进程的方式运行MongoDB。确保其稳定
fork=true
############################mongodb配置文件######################
#把配置好的mongodb复制到其他两台机器
$ scp -r /opt/mongodb root@172.29.1.21:/opt/
$ scp -r /opt/mongodb root@172.29.1.22:/opt/
$ vim /opt/mondogd/conf/mongodb.conf #依次修改其他两台机器上配置文件绑定的ip
$ /opt/mongodb/bin/mongod -f /opt/mongodb/conf/mongodb.conf #启动mongodb服务(3台上都执行)
#如果是32位,需要在配置文件加上,journal=true storageEngine=mmapv1 oplogSize=128
$ /opt/mongodb/bin/mongo 192.168.1.20:27017 #随便选择一台机器连接mongod
> use admin #切换到数据库admin(相当于mysql的mysql库)
#定义副本集配置,优先级priority值高的为主节点,_id的值repset一定要和配置文件中定义的replSet的值相同.对于仲裁点一定要加上arbiterOnly:true,指定只做仲裁节点
> config = {_id: "repset", members: [{_id:0,host:'192.168.1.20:27017',priority:2},{_id:1,host:'192.168.1.21:27017',priority:1},{_id:2,host:'192.168.1.22:27017',arbiterOnly:true}]}
> rs.initiate(config) #初始化副本集配置,会生成一些文件到data目录,,不能读写.ok是1就成功
> rs.status() #查看副本集集群状态,"health" : 1代表服务器可用,"stateStr" : "PRIMARY"表名自己的身份是master
> rs.isMaster() #查看本机是否是master
> rs.conf() #显示了每个节点的健康状况,名称,启动的时间,节点的类型等。查看当前副本集的配置表
#连接master写入数据,看slave是否能查到,测试slave是否可以写数据(不可以,会提示no master)
$ /opt/mongodb/bin/mongo 192.168.1.20:27017
repset:PRIMARY> db.users.insert({username: "tangwan1", age: 22})
WriteResult({ "nInserted" : 1 })
repset:SECONDARY> show collections
[thread1] Error: listCollections failed: { "ok" : 0, "errmsg" : "not master and slaveOk=false", "code" : 13435 }
#mongodb默认是从主节点读写数据的,副本节点上不允许读,需要设置副本节点可以读.
repset:SECONDARY> rs.slaveOk()
repset:SECONDARY> show collections
users
repset:SECONDARY> db.users.find()
{ "_id" : ObjectId("572ed5c9d7ef239c6064117f"), "username" : "visionwang", "age" : 26 }
#杀掉master,看slave是否切换为master
$ kill -9 `ps -ef|grep mongod|grep -v grep|awk '{print $2}'`
#此时再连接原来的slave(如果已经连着,直接enter.....),看到repset:SECONDARY> 变成repset:PRIMARY>
repset:PRIMARY> db.users.insert({username: "tangwan2", age: 22})
repset:PRIMARY> db.users.insert({username: "tangwan2", age: 22})
WriteResult({ "nInserted" : 1 })
repset:PRIMARY> db.users.find()
{ "_id" : ObjectId("572ed5c9d7ef239c6064117f"), "username" : "tangwan1", "age" : 22 }
{ "_id" : ObjectId("5752973d814ab9878378c719"), "username" : "tangwan2", "age" : 22 }
#再启动刚杀掉的master,可以看到它成了slave了
$ /opt/mongodb/bin/mongod -f /opt/mongodb/conf/mongodb.conf
$ /opt/mongodb/bin/mongo 192.168.1.21:27017
#检查它死后那段时间数据是否也复制过来了
repset:SECONDARY> db.users.find()
#用openssl生成密钥,用于集群间机器的信任,为心跳连接加密
$ yum -y install openssl
$ openssl rand -base64 741 > mongodb.key
#给mongodb添加用户和密码
erp;#数据库名
erp_user#用户名
zgtx123.com#密码
##创建用户前需要修改currentVersion,认证级别
repset:PRIMARY> db.system.version.find()
repset:PRIMARY> db.system.version.update({'_id':'authSchema'},{$set:{'currentVersion':3}})
repset:PRIMARY> db.system.version.find()
##查看,创建,删除用户
repset:PRIMARY> use admin
repset:PRIMARY> db.system.users.find()
repset:PRIMARY> db.system.users.remove({user:"erp_user"})
repset:PRIMARY> use erp
switched to db erp
repset:PRIMARY> db.createUser( {"user":"erp_user","pwd":"zgtx123.com","roles":[{role:"readWrite",db:"erp"}]},{w:"majority",wtimeout:5000})
Successfully added user: {
"user" : "erp_user",
"roles" : [
{
"role" : "readWrite",
"db" : "erp"
}
]
}
##修改3个配置文件auth=true;重启mongodb
$ kill -9 `ps -ef|grep mongod|grep -v grep|awk '{print $2}'`
$ /opt/mongodb/bin/mongod -f /opt/mongodb/conf/mongodb.conf
$ /opt/mongodb/bin/mongo 192.168.1.20:27017/erp -u erp_user -p#输入密码
> db.auth("erp_user", "zgtx123.com") #也是一种认证方式
- Mongodb副本集+分片集群环境部署记录
前面详细介绍了mongodb的副本集和分片的原理,这里就不赘述了.下面记录Mongodb副本集+分片集群环境部署过程: MongoDB Sharding Cluster,需要三种角色: Shard S ...
- Mongodb副本集+分片集群环境部署
前面详细介绍了mongodb的副本集和分片的原理,这里就不赘述了.下面记录Mongodb副本集+分片集群环境部署过程: MongoDB Sharding Cluster,需要三种角色: Shard S ...
- mongodb 3.4 集群搭建:分片+副本集
mongodb是最常用的nodql数据库,在数据库排名中已经上升到了前六.这篇文章介绍如何搭建高可用的mongodb(分片+副本)集群. 在搭建集群之前,需要首先了解几个概念:路由,分片.副本集.配置 ...
- mongodb 3.6 集群搭建:分片+副本集
mongodb是最常用的nosql数据库,在数据库排名中已经上升到了前六.这篇文章介绍如何搭建高可用的mongodb(分片+副本)集群. 在搭建集群之前,需要首先了解几个概念:路由,分片.副本集.配置 ...
- MongoDB 高可用集群副本集+分片搭建
MongoDB 高可用集群搭建 一.架构概况 192.168.150.129192.168.150.130192.168.150.131 参考文档:https://www.cnblogs.com/va ...
- MongoDB和Java(6):Spring Data整合MongoDB副本集、分片集群
最近花了一些时间学习了下MongoDB数据库,感觉还是比较全面系统的,涉及了软件安装.客户端操作.安全认证.副本集和分布式集群搭建,以及使用Spring Data连接MongoDB进行数据操作,收获很 ...
- 关于MongoDB副本集和分片集群有关用户和权限的说明分析
1.MongoDB副本集 可以先创建超管用户,然后再关闭服务,创建密钥文件,修改配置文件,启动服务,使用超管用户登录验证,然后创建普通用户 2.MongoDB分片集群 先关闭服务,创建密钥文件,修改配 ...
- MongoDB副本集学习(一):概述和环境搭建
MongoDB副本集概述 以下图片摘自MongoDB官方文档:http://docs.mongodb.org/manual/core/replication-introduction/ Primary ...
- nodejs+mongoose操作mongodb副本集实例
继上一篇设置mongodb副本集之后,开始使用nodejs访问mongodb副本集: 1:创建项目 express 项目名称 2:npm install mongoose 安装mongo ...
随机推荐
- [PCL]点云渐进形态学滤波
PCL支持点云的形态学滤波,四种操作:侵蚀.膨胀.开(先侵蚀后膨胀).闭(先膨胀后侵蚀) 在#include <pcl/filters/morphological_filter.h>中定义 ...
- C# 与数据库中字段类型 Int16(short), Int32(int), Int64(long)的取值范围、区别 。string长度
一开始看到Int16, Int32, Int64这三种类型就觉得有点怪, 为什么要整个数字结尾的, 挺怪的. 昨天互相想到, ms这么干就是想让大家一眼就知道这个数据类型占多大空间吧. Int8, 等 ...
- 【转】Apache Digest验证
Apache默认使用basic模块验证,都是明文传输,不太安全,所以本文使用Digest来验证,以提高安全性. 1.Apache配置: A.目录权限配置 Alias /nagios "/us ...
- VR原理讲解及开发入门
本文是作者obuil根据多年心得专门为想要入门的VR开发者所写,由52VR网站提供支持. 1. VR沉浸感和交互作用产生的原理: 在之前,我们观看一个虚拟的创造内容是通过平面显示器的,52VR ...
- RabbitMq中的交换机
Rabbitmq的核心概念(如下图所示):有虚拟主机.交换机.队列.绑定: 交换机可以理解成具有路由表的路由程序,仅此而已.每个消息都有一个称为路由键 ...
- Redis不同类型方法整合
1 对value操作的命令 exists(key):确认一个key是否存在 del(key):删除一个key type(key):返回值的类型 keys(pattern):返回满足给定patt ...
- Java注解详解
Java1.5引入了注解,注解作为程序的元数据嵌入到程序中.注解可以被一些解析工具或者编译工具进行解析.我们也可以声明注解在编译过程或者执行时产生作用. 创建Java自定义注解: package co ...
- Struts2下载文件点取消出现的异常解决
struts2点击下载,如果正常下载不会报错,可是如果点击取消就会报如下的错误: Java.lang.IllegalStateException: Cannot call sendError() af ...
- Linux Bond的原理及其不足
http://www.tektea.com/archives/1969.html. 在企业及电信Linux服务器环境上,网络配置都会使用Bonding技术做网口硬件层面的冗余,防止单个网口应用的单点故 ...
- 约在CBD,吃饭
午饭当然是外卖. CBD上班的同仁们不用约,都去了一间叫“大食堂”的餐厅. 它在商业街繁华地段的二楼,有1000平米.你不知道么,餐馆们都躲到找不着的角落,变成了厨房,这里的租金便宜得很.但它不做饭, ...