Ubuntu 安装和配置MongoDB4.2

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
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。