1、环境准备 

1、Centos7 
2、mongodb3.4.9
3、三台机器IP分别是:10.170.1.16、10.170.1.18、10.170.1.33

2、mongdb数据库的安装

如下操作是分别在三台机器进行

1、首先分别在三台机器上下载好mongodb安装包mongodb-linux-x86_64-amazon-3.4.9.tgz

2、使用tar命令解压安装包然后修改解压后的目录名

tar zxvf mongodb-linux-x86_64-amazon-3.4.9.tgz

mv  mongodb-linux-x86_64-amazon-3.4.9.tgz  mongodb

3、 进入 mongodb目录中新建三个目录conf、logs 、db 

conf存储配置文件目录,logs用来存储日志目录,db用来存储数据目录

cd mongodb

mkdir conf logs db

4、 进入conf目录新建mongodb的配置文件mongodb.conf

cd conf

touch mongodb.conf

5、 编写配置文件mongodb.conf,内容如下 

其中dbpath是数据库文件目录,logpath是日志目录,port是mongodb所占用的端口,fork是true的时候表示在后台启动

dbpath=/data/mongodb/db

logpath=/data/mongodb/log/mongodb.log

port=27017

fork=true

6、 分别在三台机器上启动mongodb 其中–replSet表示副本集群参数 ,mongoTest是副本集名称,这里的名字可以任意取,另外两台机也要和这个一样

/usr/local/mongodb/bin/mongod -f /usr/local/mongodb/conf/mongodb.conf --replSet mongoTest

7、 配置副本集

进入mongodb:

mongo 10.170.1.16:27017/admin -u test -p

输入密码

config_test={_id : 'mongoTest',members : [{_id : 0, host : '10.170.1.16:27017'},{_id : 1, host : '10.170.1.18:27017'},{_id : 2, host : '10.170.1.33:27017'}]}

初始化副本集

rs.initiate(config_test);

查看副本状态

rs.status();

health表示副本集中该节点是否正常,0表示不正常,1表示正常;state表示节点的身份,0表示非主节点,1表示主节点;stateStr用于对节点身份进行字符描述,PRIMARY表示主节点,SECONDARY表示副节点;name是副本集节点的ip和端口信息

查看副本同步状态

db.printSlaveReplicationInfo();

8、主库配置用户

在没有添加权限之前进入到mongodb主库操作页面并添加用户

db.createUser({user:'admin',pwd:'admin',roles:[{role:'userAdminAnyDatabase

',db:'admin'}]})

刚建立了 userAdminAnyDatabase 角色,用来管理用户,可以通过这个角色来创建、删除用户。

9、增加安全认证机制KeyFile

mkdir -p /data/mongo_set/usercenter/27017/

touch mongodb-keyfile

#生成key

openssl rand -base64 745 > /data/mongo_set/usercenter/27017/mongodb-keyfile

chmod 600 /data/mongo_set/usercenter/27017/mongodb-keyfile

# 该key的权限必须是600

注:将该key放到集群中机器的每一台上,记住必须保持一致,权限设置成600;

修改mongodb.conf配置

keyFile=/data/mongo_set/usercenter/27017/mongodb-keyfile

重新启用所有服务器

注:记住重新启动时候,keyfile的指定如果没有在配置文件中配置,就必须启动时候使用参数keyfile指定,关闭顺序注意下,mongodb集群有自动切换主库功能,如果先关主库,主库就切换到其它上面去了,这里预防主库变更,从库关闭后再关闭主库

开启keyfile认证就默认开启了auth认证了,在此可以用之前创建的账号进行登录

10、最后检查主从的状态

rs.status();

11、配置副本集的读写分离

配置副本集的读写分离需要以下两步:

(1)在副本节点上设置setSlaveOk(为了使从机变为可读状态);

通过命令sudo find / -name .mongorc.js找到.mongorc.js

在.mongorc.js中添加rs.slaveOk();

注:一般这个文件都是空的,直接加上去。保存退出。之后退出mongo在进去就可以了。

尽量每台服务器都添加上去。

(2)代码层面,在读操作过程中设置从副本节点读取数据,如下所示:

ReadPreference preference = ReadPreference.secondary();

mongoTemplate.setReadPreference(preference);

配置完后经过测试读操作就会自动分配到从服务器,而写操作则在主服务器进行

这部分可以从控制台查看日志进行分析

附单元测试程序:

package com.sinoway.cisp;

import org.junit.Test;

import org.junit.runner.RunWith;

import org.springframework.beans.factory.annotation.Autowired;

import org.springframework.boot.test.context.SpringBootTest;

import org.springframework.test.context.junit4.SpringRunner;

import com.sinoway.cisp.constant.CollectionEnum;

import com.sinoway.cisp.mongo.collection.BasicReport;

import com.sinoway.cisp.mongo.dao.SinowayReportDao;

@RunWith(SpringRunner.class)

@SpringBootTest(webEnvironment = SpringBootTest.WebEnvironment.RANDOM_PORT)

public class XMLTest {

@Autowired

private SinowayReportDao reportDao;

@Test

public void testSql() {

System.out.println("++++++++++++++++++++++++开始读");

BasicReport historyReport =  reportDao.findOneBySinoCardid("SW-8X760156-20161122",

BasicReport.class, CollectionEnum.HISTORYREPORT_COLLECTION_NAME.getCollectionName());

System.out.println(historyReport);

System.out.println("++++++++++++++++++++++++读结束");

System.out.println("++++++++++++++++++++++++开始写");

BasicReport report = new BasicReport();

report.setSino_cardid("3333");

reportDao.insertOneReport(report);

System.out.println("++++++++++++++++++++++++写结束");

}

}

这些可以从控制台的日志中查看,例如:刚才进行了读操作,

16是从机

下面进行了一次写操作,输出如下

18是主机

可以查看主从状态

经测试,删除操作也在主机进行,所以不属于读操作

经测试:mongodb中upsert方法属于写操作

MongoDB的搭建并配置主从以及读写分离的更多相关文章

  1. 聊聊Mysql主从同步读写分离配置实现

    Hi,各位热爱技术的小伙伴您们好,好久没有写点东西了,今天写点关于mysql主从同步配置的操作日志同大家一起分享.最近自己在全新搭建一个mysql主从同步读写分离数据库简单集群,我讲实际操作步骤整理分 ...

  2. Mysql主从配置,实现读写分离

    大型网站为了软解大量的并发访问,除了在网站实现分布式负载均衡,远远不够.到了数据业务层.数据访问层,如果还是传统的数据结构,或者只是单单靠一台服务器扛,如此多的数据库连接操作,数据库必然会崩溃,数据丢 ...

  3. 黄聪:Mysql主从配置,实现读写分离

    大型网站为了软解大量的并发访问,除了在网站实现分布式负载均衡,远远不够.到了数据业务层.数据访问层,如果还是传统的数据结构,或者只是单单靠一台服务器扛,如此多的数据库连接操作,数据库必然会崩溃,数据丢 ...

  4. DBA 小记 — 分库分表、主从、读写分离

    前言 我在上篇博客 "Spring Boot 的实践与思考" 中比对不同规范的 ORM 框架应用场景的时候提到过主从与读写分离,本篇随笔将针对此和分库分表进行更深入地探讨. 1. ...

  5. mysql数据库主从同步读写分离(一)主从同步

    1.mysql数据库主从同步读写分离 1.1.主要解决的生产问题 1.2.原理 a.为什么需要读写分离? 一台服务器满足不了访问需要.数据的访问基本都是2-8原则. b.怎么做?  不往从服务器去写了 ...

  6. mysql 主从同步-读写分离

    主从同步与读写分离测试 一.  实验环境(主从同步) Master                   centos 7.3              192.168.138.13 Slave     ...

  7. 使用docker 实现MySQL主从同步/读写分离

    1. 利用 docker 实现 mysql 主从同步 / 读写分离 为了保证数据的完整和安全,mysql 设计了主从同步,一个挂掉还可以用另个.最近重构论坛,想来改成主从吧.担心失误,就先拿 dock ...

  8. mysql主从同步--读写分离。

    1.mysql 安装参考 https://www.cnblogs.com/ttzzyy/p/9063737.html 2. 主mysql,从mysql 指定配置文件启动 mysqld --defaul ...

  9. Docker容器启动Mysql,Docker实现Mysql主从,读写分离

    Docker容器启动Mysql,Docker实现Mysql主从,读写分离 一.Docker文件编排 二.配置主从复制 2.1 配置master 2.2 配置slave 三.验证主从复制 3.1 mas ...

随机推荐

  1. SpringCloud系列十二:SpringCloudSleuth(SpringCloudSleuth 简介、SpringCloudSleuth 基本配置、数据采集)

    声明:本文来源于MLDN培训视频的课堂笔记,写在这里只是为了方便查阅. 1.概念:SpringCloudSleuth 2.具体内容 Sleuth 是一种提供的跟踪服务,也就是说利用 sleuth 技术 ...

  2. SpringBoot入门教程(四)MyBatis generator 注解方式和xml方式

    MyBatis 是一款优秀的持久层框架,它支持定制化 SQL.存储过程以及高级映射.MyBatis 避免了几乎所有的 JDBC 代码和手动设置参数以及获取结果集.MyBatis 可以使用简单的 XML ...

  3. Paramiko模块简单使用

    介绍 Paramiko 一个第三方包,需要单独安装我们知道远程批量主机管理,比如ansible.Fabric,不需要安装客户端的远程执行命令等,这些都是基于Python原生的SSH,相当于模拟了一个S ...

  4. webpack无法热加载(__webpack_hmr 502)

    最近本地开发项目代码一直无法热加载,于是就抽空想办法解决 我们线上的地址是:https://aitest.ichuanyi.com/ai-admin/#/  其实ai-admin是线上的一个目录 所以 ...

  5. ELK-安装logstash

    注意:在下载tar包的时候需要注意下安装的es版本号,按照官网的说明版本是对应一致的. $ wget https://artifacts.elastic.co/downloads/logstash/l ...

  6. leetcode — partition-list

    /** * Source : https://oj.leetcode.com/problems/partition-list/ * * * Given a linked list and a valu ...

  7. 一篇文章彻底搞懂es6 Promise

    前言 Promise,用于解决回调地狱带来的问题,将异步操作以同步的操作编程表达出来,避免了层层嵌套的回调函数. 既然是用来解决回调地狱的问题,那首先来看下什么是回调地狱 var sayhello = ...

  8. PHP中的Traits用法详解

    PHP是单继承的语言,在PHP 5.4 Traits出现之前,PHP的类无法同时从两个基类继承属性或方法.php的Traits和Go语言的组合功能有点类似, 通过在类中使用use关键字声明要组合的Tr ...

  9. Java 学习笔记 IO流与File操作

    可能你只想简单的使用,暂时不想了解太多的知识,那么请看这里,了解一下如何读文件,写文件 读文件示例代码 File file = new File("D:\\test\\t.txt" ...

  10. 2019-01-28 [日常]Beyond的歌里最多是"唏嘘"吗? - Python分词+词频

    看了一个Beyond的纪录片, 提到这个. 觉得心有不甘, 于是搜集了24首歌词, 用Python做了简单分词和词频统计. 源码(包括歌词)在: program-in-chinese/study 统计 ...