CentOS 7 安装 MongoDB4.4.3

本教程讲述如何在 Centos 7 系统中使用 Yum 源安装 MongoDB。

配置系统 yum 源

1.创建 .repo 文件,生成 mongodb 的源

vi /etc/yum.repos.d/mongodb-org-4.0.repo

2.添加以下配置信息:

[mongodb-org-4.2]

name=MongoDB Repository

baseurl=https://repo.mongodb.org/yum/redhat/$releasever/mongodb-org/4.2/x86_64/

gpgcheck=1

enabled=1

gpgkey=https://www.mongodb.org/static/pgp/server-4.2.asc

代码详解:

name        # 名称

baseurl      # 获得下载的路径

gpkcheck=1  # 表示对从这个源下载的rpm包进行校验;

enable=1    # 表示启用这个源。

gpgkey      # gpg验证

注意: 需要去官网教程 Install MongoDB Community Edition on Red Hat or CentOS 获取最新的源。

3.保存退出

:wq # 退出保存

使用 yum 安装 MongoDB

1.安装 MongoDB

sudo yum install -y mongodb-org

2.验证安装结果

rpm -qa | grep mongodb

# 输出如下:

# mongodb-org-tools-4.0.19-1.el7.x86_64

# mongodb-org-server-4.0.19-1.el7.x86_64

# mongodb-org-4.0.19-1.el7.x86_64

# mongodb-org-shell-4.0.19-1.el7.x86_64

# mongodb-org-mongos-4.0.19-1.el7.x86_64

rpm -ql mongodb-org-server

启动 MongoDB

1.启动 MongoDB 服务

systemctl start mongod.service

2.查看端口是否开启

MongoDB 默认端口是 27017,使用命令查看是否开启端口

netstat -natp | grep 27017

3.检查数据库进程是否存在

ps -aux | grep mongod    # 查看数据库的进程是否存在

4.验证服务是否开启

mongo

db.version()

常用的命令有:

# 1、开启 MongoDB

sudo service mongod start  # 或者 systemctl start mongod.service  # 开启 MongoDB

sudo chkconfig mongod on  # 加入开机启动

sudo service mongod restart # 重启 MongoDB

# 2、关闭 MongoDB

sudo service mongod stop  # 关闭 MongoDB

# 3、卸载MongoDB

sudo yum erase $(rpm -qa | grep mongodb-org)    # 卸载 MongoDB

sudo rm -r /var/log/mongodb  # 删除日志文件

sudo rm -r /var/lib/mongo    # 删除数据文件

配置远程连接 MongoDB

1.修改配置文件 mongodb.conf

vi /etc/mongod.conf

# network interfaces

net:

  port: 27017

  bindIp: 0.0.0.0  # Enter 0.0.0.0,:: to bind to all IPv4 and IPv6 addresses or, alternatively, use the net.bindIpAll setting.

修改绑定 ip, 默认 127.0.0.1 只允许本地连接,所以修改为 bindIp:0.0.0.0, 退出保存。

2.重启 MongoDB 服务

sudo service mongod restart

3.开放对外端口

在防火墙中放行指定的端口:

systemctl status firewalld  # 查看防火墙状态

firewall-cmd --zone=public --add-port=27017/tcp --permanent # mongodb默认端口号

firewall-cmd --reload  # 重新加载防火墙

firewall-cmd --zone=public --query-port=27017/tcp # 查看端口号是否开放成功,输出yes开放成功,no则失败

4.测试远程连接

mongo 192.168.1.132:27017

db.version()

添加用户名和密码

1.为 admin 数据库创建用户,设置用户名、密码和权限

show dbs # 显示所有的数据库

use admin # 切换到 admin 数据库

db.createUser({user:'root',pwd:'999888',roles:['root']})

db.auth('root','999888')

# 其他常用命令

# db.changeUserPassword("test", "test")    # 修改密码

# db.updateUser("test",{roles:[ {role:"read",db:"testDB"} ]}) # 更新用户权限

# db.dropUser('test') # 删除用户

# db.createUser({user:'cjx',pwd:'999888',roles:['userAdminAnyDatabase']}) # 赋予用户所有数据库的userAdmin权限

2.为其他数据库创建用户,设置用户名、密码和权限

use test

db.createUser({ user:"cjx", pwd:"999888", roles:["readWrite", "dbAdmin"] })

db.auth('cjx','999888')

3.修改 mongodb.conf 文件,启用身份验证

vi /etc/mongod.conf

添加如下内容:

security:

  authorization: enabled  # disable or enabled

4.启 MongoDB 服务

sudo service mongod restart

5.测试远程连接

mongo 192.168.1.132:27017:27017/database -u username -p password

用户权限角色说明 :

规则说明

root只在admin数据库中可用。超级账号,超级权限

Read允许用户读取指定数据库

readWrite允许用户读写指定数据库

dbAdmin允许用户在指定数据库中执行管理函数,如索引创建、删除,查看统计或访问system.profile

userAdmin允许用户向system.users集合写入,可以找指定数据库里创建、删除和管理用户

clusterAdmin只在admin数据库中可用,赋予用户所有分片和复制集相关函数的管理权限

readAnyDatabase只在admin数据库中可用,赋予用户所有数据库的读权限

readWriteAnyDatabase只在admin数据库中可用,赋予用户所有数据库的读写权限

userAdminAnyDatabase只在admin数据库中可用,赋予用户所有数据库的userAdmin权限

dbAdminAnyDatabase只在admin数据库中可用,赋予用户所有数据库的dbAdmin权限

你可能感兴趣的:(CentOS 7 安装 MongoDB4.4.3)