Mongodb集群搭建与介绍

本文详细介绍了MongoDB的集群搭建,从单实例、主从模式、副本集到分片,涵盖了高可用性和水平扩展性的实现。通过实例演示了MongoDB在不同模式下的配置与操作,包括主从模式的自动切换、副本集的容错性以及分片的原理与实践,旨在帮助读者理解MongoDB集群的架构与管理。
摘要由CSDN通过智能技术生成

1、背景与目的

在大数据的时代,传统的关系型数据库要提供更高的服务必须要解决高并发读写、海量数据高效存储、高可扩展性和高可用性这些难题。不过就是因为这些问题Nosql诞生了。
NOSQL有这些优势:

  1. 大数据量,可以通过廉价服务器存储大量的数据,轻松摆脱传统mysql单表存储量级限制。
  2. 高扩展性,Nosql去掉了关系数据库的关系型特性,很容易横向扩展,摆脱了以往老是纵向扩展的诟病。
  3. 高性能,Nosql通过简单的key-value方式获取数据,非常快速。还有NoSQL的Cache是记录级的,是一种细粒度的Cache,所以NoSQL在这个层面上来说就要性能高很多。
  4. 灵活的数据模型,NoSQL无需事先为要存储的数据建立字段,随时可以存储自定义的数据格式。而在关系数据库里,增删字段是一件非常麻烦的事情。如果是非常大数据量的表,增加字段简直就是一个噩梦。
  5. 高可用,NoSQL在不太影响性能的情况,就可以方便的实现高可用的架构。比如mongodb通过mongos、mongo分片就可以快速配置出高可用配置。

在nosql数据库里,大部分的查询都是键值对(key、value)的方式。MongoDB是一个介于关系数据库和非关系数据库之间的产品,是非关系数据库当中最像关系数据库的。支持类似于面向对象的查询语言,几乎可以实现类似关系数据库单表查询的绝大部分功能,而且还支持对数据建立索引。所以这个非常方便,我们可以用sql操作MongoDB,从关系型数据库迁移过来,开发人员学习成本会大大减少。如果再对底层的sql API做一层封装,开发基本可以感觉不到mongodb和关系型数据库的区别。

2、mongodb单实例

这种配置只适合简易开发时使用,生产使用不行,因为单节点挂掉整个数据业务全挂,如下图:
这里写图片描述

  1. 建立mongodb测试目录

登陆主机:

#存放整个mongodb文件
mkdir -p /wls/mongodb/single 
#存放mongodb数据文件
mkdir -p /wls/mongodb/single/data
#日志文件
mkdir -p /wls/mongodb/single/logs
mongodb.conf文件
#配置文件目录
mkdir -p /wls/mongodb/single/conf
#进入mongodb文件夹
cd  /wls/mongodb/single
  1. 安装程序包
#上传安装文件到如下目录
/wls/mongodb/single
#解压下载的压缩包  
tar xvzf mongodb-linux-x86_64-rhel62-3.2.8.tgz
#进入mongodb程序执行文件夹
cd mongodb-linux-x86_64-rhel62-3.2.8/bin/
  1. 启动单实例mongodb
./mongod --config /wls/mongodb/single/conf/mongodb.conf
  1. 启动报错
[root@DEV-L000101 bin]# ./mongod --config /wls/mongodb/single/conf/mongodb.conf
./mongod: /usr/lib64/libcrypto.so.10: no version information available (required by ./mongod)
./mongod: /usr/lib64/libcrypto.so.10: no version information available (required by ./mongod)
./mongod: /usr/lib64/libssl.so.10: no version information available (required by ./mongod)
./mongod: relocation error: ./mongod: symbol TLSv1_1_client_method, version libssl.so.10 not defined in file libssl.so.10 with link time reference

解决方法: yum install openssl-devel
  1. 再次启动单实例mongodb
./mongod --config /wls/mongodb/single/conf/mongodb.conf
输出日志如下,成功!
[initandlisten] db version v3.2.8
……..
[initandlisten] waiting for connections on port 27017
  1. web控制台
    Web控制台开启,增加配置参数 httpinterface=yes
    mongodb默认自带提供了web访问接口,通过 IP + 端口(默认:28017)的形式可以访问。
    http://ip:port

这里写图片描述

3、主从模式

使用mysql数据库时大家广泛用到,采用双机备份后主节点挂掉了后从节点可以接替主机继续服务。所以这种模式比单节点的高可用性要好很多。

一、单个从节点

这里写图片描述

二、多个从节点

现在只是一个数据库服务器又提供写又提供读,机器承载会出现瓶颈。大家还记mysql里的读写分离吗?把20%的写放到主节点,80%的读放到从节点分摊了减少了服务器的负载。但是大部分应用都是读操作带来的压力,一个从节点压力负载不了,可以把一 个从节点变成多个节点。
这里写图片描述

三、主从环境搭建
3.1. 准备两台机器 10.20.8.152 和10.20.14.73。10.20.8.152 当作主节点,10.20.14.73作为从节点。
3.2. 在10.20.8.152上建立文件夹 /wls/mongodb/master, 并创建如下目录:
mkdir -p /wls/mongodb/master/data
mkdir -p /wls/mongodb/master/logs
mkdir -p /wls/mongodb/master/conf
3.3. 在10.20.14.73建立文件夹/wls/mongodb/slave,并创建如下目录:
mkdir -p /wls/mongodb/slave/da

  • 6
    点赞
  • 13
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值