centos7搭建MongoDB以及MongoDB复制集

本文涉及的产品
云数据库 MongoDB,通用型 2核4GB
简介: centos7搭建MongoDB以及MongoDB复制集

搭建mongodb

这里直接将的是搭建mongodb的复制集,一主两从

1️⃣:下载mongodb4.2.23并解压缩到任意目录下

#这里可以是你服务器的任意目录
wget https://fastdl.mongodb.org/linux/mongodb-linux-x86_64-rhel70-4.2.23.tgz
tar -zxvf mongodb-linux-x86_64-rhel70-4.2.23.tgz

2️⃣:创建相关文件夹

mkdir -p /home/M/mongodb/data/db{1,2,3}

3️⃣:编写配置文件

systemLog:
  destination: file
  path: /home/M/mongodb/data/db1/mongodb.log   #log path
  logAppend: true
storage:
  dbPath: /home/M/mongodb/data/db1  #data directory
net:
  bindIp: 0.0.0.0
  port: 28817 #port
security:
  authorization: enabled
  keyFile: /home/M/mongodb/mongo.key
replication:
  replSetName: rs0
processManagement:
  fork: true

这里的keyFile文件主要是秘钥,可以使用如下命令生成

openssl rand -base64 90 -out ./mongo.key

这里配置文件分别置于db{1,2,3}下

4️⃣:编辑/ect/profile文件,末尾加入如下语句

export PATH=$PATH:/home/M/mongodb-linux-x86_64-rhel70-4.2.23/bin
#保存退出后执行如下命令
source /etc/profile

5️⃣:执行如下命令配置复制集

mongo 10.0.4.7:28817
rs.config({_id:"rs0",members:[{_id:0,host:"127.0.0.1:28817"},{_id:1,host:"127.0.0.1:28818"},{_id:2,host:"127.0.0.1:28819"}]})
#这里切记登录别用自己的hostname,否则外部是不能访问的,如果想外部访问用外网ip,另外如果是单机的话内网ip也行

6️⃣:设计账号密码并在主节点配置权限

use admin
db.createUser({ user:'admin',pwd:'bkwEtSrIA3EXQWgo',roles:[ { role:'userAdminAnyDatabase', db: 'admin'}]});
db.auth('admin','bkwEtSrIA3EXQWgo')
db.grantRolesToUser( "admin" , [ { role: "dbOwner", db: "admin" },{ "role": "clusterAdmin", "db": "admin" },
{ "role": "userAdminAnyDatabase", "db": "admin" },
{ "role": "dbAdminAnyDatabase", "db": "admin" }])
#创建root用户
db.createUser({user:"root",pwd:"bYBBkcZkliadV6M6",roles:[{role:"root",db:"admin"}]});
#赋予root用户操作命令的权限,不然会提示报错没有权限
Error: error: {
        "operationTime" : Timestamp(1670313676, 1),
        "ok" : 0,
        "errmsg" : "not authorized on base_bo to execute command { find: \"test\", filter: {}, lsid: { id: UUID(\"39276352-9b03-48b7-8586-44d7b7714e32\") }, $clusterTime: { clusterTime: Timestamp(1670313666, 1), signature: { hash: BinData(0, B91D68894743B2DFE5C5BA0AA4B8E5F23741B0E3), keyId: 7173561399774281733 } }, $db: \"base_bo\" }",
        "code" : 13,
        "codeName" : "Unauthorized",
        "$clusterTime" : {
                "clusterTime" : Timestamp(1670313676, 1),
                "signature" : {
                        "hash" : BinData(0,"VYwnvDNG39YupihA7Jsri923qE8="),
                        "keyId" : NumberLong("7173561399774281733")
                }
        }
}
db.grantRolesToUser ( "root", [ { role: "__system", db: "admin" } ] )

另外给大家安利一个软件,具体页面如下,它的功能很强大

相关实践学习
MongoDB数据库入门
MongoDB数据库入门实验。
快速掌握 MongoDB 数据库
本课程主要讲解MongoDB数据库的基本知识,包括MongoDB数据库的安装、配置、服务的启动、数据的CRUD操作函数使用、MongoDB索引的使用(唯一索引、地理索引、过期索引、全文索引等)、MapReduce操作实现、用户管理、Java对MongoDB的操作支持(基于2.x驱动与3.x驱动的完全讲解)。 通过学习此课程,读者将具备MongoDB数据库的开发能力,并且能够使用MongoDB进行项目开发。   相关的阿里云产品:云数据库 MongoDB版 云数据库MongoDB版支持ReplicaSet和Sharding两种部署架构,具备安全审计,时间点备份等多项企业能力。在互联网、物联网、游戏、金融等领域被广泛采用。 云数据库MongoDB版(ApsaraDB for MongoDB)完全兼容MongoDB协议,基于飞天分布式系统和高可靠存储引擎,提供多节点高可用架构、弹性扩容、容灾、备份回滚、性能优化等解决方案。 产品详情: https://www.aliyun.com/product/mongodb
相关文章
|
2天前
|
监控 NoSQL 安全
【MongoDB 专栏】MongoDB 的复制集:高可用性配置
【5月更文挑战第10天】MongoDB的复制集是实现数据高可用性的重要机制,由主节点和次节点构成,主节点处理写操作,次节点同步数据确保一致。在主节点故障时,次节点自动提升接替,保证服务不间断。通过复制集,可实现数据保护、持续服务,适用于关键业务系统和数据备份。配置时需关注网络稳定性、节点性能和数据一致性。案例显示,复制集能有效保障服务高可用,防止数据丢失和业务中断,是现代数据库管理的关键工具。在数据驱动的世界,复制集为高可用性提供了坚实保障。
【MongoDB 专栏】MongoDB 的复制集:高可用性配置
|
2天前
|
监控 NoSQL 容灾
MongoDB复制集原理:高可用性与数据一致性的保障
【4月更文挑战第30天】MongoDB复制集提供高可用性和数据一致性,通过在多个服务器间复制数据。复制集包含主节点和从节点,写操作在主节点执行,然后异步复制到从节点。优势包括故障切换、数据冗余、负载均衡和容灾备份。当主节点故障,其他节点会选举新主节点,确保服务连续性。配置复制集涉及规划节点、配置复制集、初始化和监控维护。复制集是实现数据库可靠性的核心。
|
2天前
|
NoSQL Linux 网络安全
【专栏】在 RHEL 8 或者 CentOS 8 上顺利安装并运行MongoDB,以处理非结构化数据和扩展技术栈
【4月更文挑战第28天】本文档介绍了如何在RHEL或CentOS 8上安装MongoDB,包括环境准备(系统更新、依赖安装、硬件需求和sudo用户)、导入MongoDB GPG公钥、创建Yum仓库、安装MongoDB社区版,以及后续的基本配置和验证(启动服务、防火墙设置和连接验证)。通过这些步骤,用户可以顺利安装并运行MongoDB,以处理非结构化数据和扩展技术栈。
|
2天前
|
存储 NoSQL Linux
CentOS7安装MongoDB
CentOS7安装MongoDB
19 0
|
2天前
|
NoSQL 应用服务中间件 Linux
CentOS7搭建MySQL+Redis+MongoDB+FastDF
CentOS7搭建MySQL+Redis+MongoDB+FastDF
142 0
|
2天前
|
NoSQL 安全 Linux
百度搜索:蓝易云【CentOS7安装MongoDB教程】
这些是在CentOS 7上安装MongoDB的基本步骤。根据您的需求和具体环境,可能还需要进行其他配置和调整。请确保在进行任何与网络连接和安全相关的操作之前,详细了解您的网络环境和安全需求,并采取适当的安全措施。
140 0
|
6月前
|
监控 NoSQL MongoDB
轻松掌握组件启动之MongoDB(番外篇):高可用复制集架构环境搭建-mtools
mtools是一个基于Python实现的MongoDB工具集,旨在提供一系列功能,包括MongoDB日志分析、报表生成以及简易的数据库安装等。它由MongoDB原生的工程师单独发起并进行开源维护。mtools包含了一些常用的组件,如mlaunch、mlogfilter、mplotqueries和mlogvis等,可以帮助我们更方便地启动和创建MongoDB数据库。
127 1
|
6月前
|
监控 NoSQL 安全
轻松掌握组件启动之MongoDB(下):高可用复制集架构环境搭建
本章介绍了MongoDB复制集的配置和使用方法,如何初始化和添加节点到复制集,验证主节点的写入和从节点的读取功能。了解如何查询复制集的状态,包括成员的健康状况、同步信息和角色等。最后,我们介绍了如何配置复制集的安全认证,包括创建用户和生成keyFile文件,并演示了使用认证信息连接复制集的方式。通过本章的学习,你将掌握MongoDB复制集的基本使用和配置方法。
|
6月前
|
存储 NoSQL 容灾
轻松掌握组件启动之MongoDB(上):高可用复制集架构环境搭建
本文介绍了MongoDB复制集的架构和特点,强调了使用复制集提供数据的高可用性和冗余性的重要性。复制集由Primary节点和Secondary节点组成,确保数据一致性。复制集还具有数据分发、读写分离和异地容灾等附加功能。使用MongoDB复制集可以提供稳定可靠的数据存储和高可用性。
轻松掌握组件启动之MongoDB(上):高可用复制集架构环境搭建
|
2天前
|
存储 NoSQL MongoDB
MongoDB如何创建数据库
MongoDB如何创建数据库