1. 卸载之前的版本(之前未安装可以跳过第一步)
- 停止服务
systemctl stop mongod
# 或者 systemctl stop mongodb
- 卸载服务
apt purge mongodb-org*
apt purge mongodb
- 删除数据库和日志文件
rm -rf /var/log/mongodb
rm -rf /var/lib/mongodb
2. 安装
1. 在终端输入GPK码
wget -qO - https://www.mongodb.org/static/pgp/server-4.2.asc | sudo apt-key add -
2. 添加源
echo "deb [ arch=amd64,arm64 ] https://repo.mongodb.org/apt/ubuntu xenial/mongodb-org/4.2 multiverse" | sudo tee /etc/apt/sources.list.d/mongodb-org-4.2.list
3. 更新源
sudo apt update
4. 安装
sudo apt install libcurl3 mongodb-org=4.2.10 mongodb-org-server=4.2.10 mongodb-org-shell=4.2.10 mongodb-org-mongos=4.2.10 mongodb-org-tools=4.2.10
5. 配置为系统服务
- 新增文件
sudo vim /etc/systemd/system/mongod.service
- 输入以下内容
[Unit]
Description=High-performance, schema-free document-oriented database
After=network.target
[Service]
User=mongodb
ExecStart=/usr/bin/mongod --quiet --config /etc/mongod.conf
[Install]
WantedBy=multi-user.target
- 重新加载配置文件
systemctl daemon-reload
- 载入服务
systemctl enable mongod
如果报错Failed to enable unit: Unit file /etc/systemd/system/mongod.service is masked.
就先执行命令systemctl unmask mongod
再执行命令systemctl enable mongod
- 启动服务
systemctl start mongod
- 查看版本
mongod --version
# db version v4.2.1
# git version: edf6d45851c0b9ee15548f0f847df141764a317e
# OpenSSL version: OpenSSL 1.0.2n 7 Dec 2017
# allocator: tcmalloc
# modules: none
# build environment:
# distmod: ubuntu1604
# distarch: x86_64
# target_arch: x86_64
3. 设置远程访问
- 根据端口号查看状态
lsof -i:27017
# COMMAND PID USER FD TYPE DEVICE SIZE/OFF NODE NAME
# mongod 23650 mongodb 11u IPv4 271201 0t0 TCP localhost:27017 (LISTEN)
- 编辑文件
vim /etc/mongod.conf
- 将bindIp:127.0.0.1 修改为:0.0.0.0
bindIp: 0.0.0.0
- 重启服务
systemctl restart mongod
- 根据端口号查看状态
lsof -i:27017
# COMMAND PID USER FD TYPE DEVICE SIZE/OFF NODE NAME
# mongod 23889 mongodb 11u IPv4 297022 0t0 TCP *:27017 (LISTEN)
4. 设置账户密码
- 连接mongo
mongo
- 切换数据库
use admin
- 新增用户
db.createUser({
user: 'user', // 用户名
pwd: '123456', // 密码
roles:[{
role: 'root', // 角色
db: 'admin' // 数据库
}]
})
- 查看用户是否添加成功
show users
- 编辑配置文件
vim /etc/mongod.conf
- 修改以下内容
#security:
修改为
security:
authorization: enabled
- 重启服务
systemctl restart mongod
- 现在连接需要用户名和密码
// 方式一
mongo
use admin
db.auth('user', '123456')
// 方式二
mongo admin -u admin -p 123456