MongoDB 是一个免费并且开源的文档数据库。它属于一个被称为 NoSQL 的数据库家族。NoSQL 与传统的关系型数据库不同,例如:MySQL 和 PostgreSQL。
在 MongoDB 中,数据被灵活地以类似 JSON 的形式被存储成文档。它不要求预先定义schema,并且数据结构一直都可以改变。
这个指南解释了如何在 CentOS 8 服务器上安装 和 配置 MongoDB 社区版本。
一、 安装 MongoDB
MongoDB 在 CentOS 8 核心软件源上不可用。 我们将会启用 MongoDB 官方软件源,并且安装软件包。
在写本文的时候,MongoDB 官方软件源上最新的 MongoDB 版本是 4.4。 在开始安装之前,访问 MongoDB的文档Install on Red Hat,检查一下是否有更新的发布版本。
以root 或者有 sudo 权限的用户身份执行下面的步骤,在 CentOS 8 系统上安装 MongoDB:
01.在/etc/yum.repos.d/目录下创建一个名为mongodb-org.repo的源文件,启动 MongoDB 源(没明白啥意思):
touch /etc/yum.repos.d/mongodb-org.repo
复制代码
[mongodb-org-4.4]
name=MongoDB Repository
baseurl=https://repo.mongodb.org/yum/redhat/$releasever/mongodb-org/4.4/x86_64/
gpgcheck=1
enabled=1
gpgkey=https://www.mongodb.org/static/pgp/server-4.4.asc
复制代码
如果你想安装 MongoDB 更老的版本,将4.4替换成你想要的版本。
02.安装mongodb-org元软件包:
sudo dnf install mongodb-org
复制代码
在安装过程中,你将会被提示插入 MongoDB GPG key。 输入y并且按Enter回车。
下面的软件包将会在你系统上安装,作为mongodb-org软件包的一部分:
mongodb-org-server – mongod守护进程,相应的初始化脚本和配置。
mongodb-org-mongos – mongos守护进程。
mongodb-org-shell – mongo shell,一个适用于 MongoDB 的交互式JavaScript 界面 ,主要用来通过命令行执行一些管理任务。
mongodb-org-tools – 包含一些 MongoDB 工具,例如:数据导入工具,数据导出工具,数据统计工具等。
03.一旦安装完成,启用并且启动 MongoDB 服务:
sudo systemctl enable mongod --now
复制代码
04.想要验证安装,连接到MongoDB数据库,并且打印出服务器版本:
mongo
复制代码
运行下面的命令,显示 MongoDB版本号:
db.version()
复制代码
输出可能像下面这样:
4.2.3
复制代码
二、 配置 MongoDB
MongoDB配置文件被命名为:mongod.conf,位于 /etc目录。 这个文件是YAML格式。
默认的配置适用于大部分用户场景。无论如何,对于生产环境,我们推荐打开安全章节并且启用用户鉴权: /etc/mongod.conf
security:
authorization: enabled
复制代码
这个authorization选项启用了Role-Based Access Control (RBAC),它规定了用户对数据和操作的访问规则。 如果这个选项被禁用,那么每个用户都可以访问任何数据,执行任何操作。
在对 MongoDB 配置文件做任何修改之后,重启 mongod 服务:
sudo systemctl restart mongod
复制代码
想要了解关于MongoDB配置选项的信息,请浏览 配置文件选项文档页面。
三、创建 MongoDB 管理员
如果你启用了 MongoDB 用户鉴权,你需要创建一个管理员用户,可以访问并且管理 MongoDB 实例。
首先,访问 MongoDB shell:
mongo
复制代码
输入下面的命令,连接admin数据库:
use admin
复制代码
switched to db admin
复制代码
创建一个新用户,名称为mongoAdmin,赋予userAdminAnyDatabase角色:
db.createUser(
{
user: "mongoAdmin",
pwd: "changeMe",
roles: [ { role: "userAdminAnyDatabase", db: "admin" } ]
}
)
复制代码
Successfully added user: {
"user" : "mongoAdmin",
"roles" : [
{
"role" : "userAdminAnyDatabase",
"db" : "admin"
}
]
}
复制代码
退出 Mongo shell:
quit()
复制代码
想要测试修改,使用你之前创建的管理员账号访问 mongo shell:
mongo -u mongoAdmin -p --authenticationDatabase admin
MongoDB shell version v4.2.3
Enter password:
复制代码
use admin
复制代码
switched to db admin
复制代码
现在,打印用户:
show users
复制代码
{
"_id" : "admin.mongoAdmin",
"user" : "mongoAdmin",
"db" : "admin",
"roles" : [
{
"role" : "userAdminAnyDatabase",
"db" : "admin"
}
],
"mechanisms" : [
"SCRAM-SHA-1",
"SCRAM-SHA-256"
]
}
复制代码
mongodb设置后台运行
我们要在mongodb下面创建data目录和logs目录,用于存放data和logs。
设置好了之后,我们通常通过
mongod --dbpath /usr/local/mongo/data
复制代码
让mongodb启动。
但是我们关闭shell,mongodb就停止运行了。如果想在后台运行,启动时只需添加 –fork函数即可。可以在日志路径后面添加–logappend,防止日志被删除。
代码如下:
mongod --fork --dbpath=/usr/local/mongodb/data --logpath=/usr/local/mongodb/logs/mongodb2.log --logappend
复制代码
这样,你关闭shell,在打开shell,照常可以允许mongo了!
mongodb设置开机启动。
当我们把服务器关闭,重启之后,发现mongodb又停止了,有没有开机就启动的方法呢?我们把上面代码放到/etc/rc.local,中,就可以了。
具体操作步骤:
vim /etc/rc.local
复制代码
添加上面启动代码:
/usr/local/mongodb/bin/mongod --fork --dbpath=/usr/local/mongodb/data --logpath=/usr/local/mongodb/logs/mongodb2.log --logappend
复制代码
下次重启就可以直接运行mongodb了!






















![[桜井宁宁]COS和泉纱雾超可爱写真福利集-一一网](https://www.proyy.com/skycj/data/images/2020-12-13/4d3cf227a85d7e79f5d6b4efb6bde3e8.jpg)

![[桜井宁宁] 爆乳奶牛少女cos写真-一一网](https://www.proyy.com/skycj/data/images/2020-12-13/d40483e126fcf567894e89c65eaca655.jpg)