Linux上安装MongoDB

目录

一、在Linux系统安装MongoDB服务器

1、下载MongoDB

2、上传MongoDB并解压

3、创建必要目录

4、配置环境变量

5、创建配置文件

6、启动命令

7、验证安装

二、在Linux系统安装MongoDB客户端Shell

[1、下载MongoDB Shell](#1、下载MongoDB Shell)

[2、上传MongoDB Shell并解压](#2、上传MongoDB Shell并解压)

3、配置环境变量

三、MongDB启用认证

1、创建管理员用户

2、修改配置文件:启用认证

3、重启服务

4、验证认证

四、用Navicat连接MongoDB

1、编辑连接并测试

2、新建查询并测试


一、在Linux系统安装MongoDB服务器

1、下载MongoDB

官网下载地址:MongDB DownLoad

选择适合自己的版本

2、上传MongoDB并解压

bash 复制代码
//解压
tar -zxvf 安装包名
bash 复制代码
//改名
mv mongodb-linux-x86_64-rhel70-7.0.20 mongodb-7.0.20

3、创建必要目录

java 复制代码
sudo mkdir -p /data/db        # 数据存储目录
sudo mkdir -p /var/log/mongodb  # 日志目录
sudo chown `whoami` /data/db /var/log/mongodb  # 授权当前用户

4、配置环境变量

bash 复制代码
# 编辑 /etc/profile
echo 'export PATH=/soft/mongodb/mongodb-7.0.20/bin:$PATH' >> /etc/profile
# 立即生效
source /etc/profile

5、创建配置文件

vim /etc/mongod.conf

bash 复制代码
systemLog:
  destination: file
  path: /var/log/mongodb/mongod.log
  logAppend: true
storage:
  dbPath: /data/db
net:
  port: 27017
  bindIp: 0.0.0.0  # 允许远程访问
processManagement:
  fork: true  #启用在后台运行mongos或mongod进程的守护进程模式。

参数 说明

dbpath: 数据库⽬录,默认 /data/db
port: 监听的端⼝,默认 27017
bind_ip: 监听 IP 地址,默认全部可以访问
fork: 是否已后台启动的⽅式登陆
logpath: ⽇志路径
logappend: 是否追加⽇志
auth: 是开启⽤户密码登陆

6、启动命令

bash 复制代码
mongod --config /etc/mongod.conf --fork

7、验证安装

bash 复制代码
# 检查进程
ps aux | grep mongod

网页访问:http://ip:27017/

二、在Linux系统安装MongoDB客户端Shell

1、下载MongoDB Shell

官网下载地址:MongoDB Shell DownLoad

2、上传MongoDB Shell并解压

bash 复制代码
tar -zxvf mongosh-2.5.1-linux-x64.tgz

3、配置环境变量

bash 复制代码
# 编辑 /etc/profile
echo 'export PATH=/soft/mongodb/mongosh-2.5.1-linux-x64/bin:$PATH' >> /etc/profile
# 立即生效
source /etc/profile

三、MongDB启用认证

1、创建管理员用户

连接MongoDB shell:

bash 复制代码
mongosh
复制代码
在MongoDB shell中执行:
bash 复制代码
// 切换到admin数据库
use admin

// 创建管理员用户(替换your-password)
db.createUser({
  user: "admin",
  pwd: "your-strong-password",  // 使用强密码
  roles: [ 
    { role: "userAdminAnyDatabase", db: "admin" },
    "readWriteAnyDatabase"  // 按需分配权限
  ]
})

关键角色说明:

  • userAdminAnyDatabase:用户管理权限

  • dbOwner:数据库完全控制权

  • readWrite:读写权限

2、修改配置文件:启用认证

bash 复制代码
vim /etc/mongod.conf

添加:

bash 复制代码
security:
  authorization: enabled  # 启用认证

3、重启服务

bash 复制代码
# 查看进程
ps aux | grep mongod

# 关闭进程
kill 进程id

# 启动服务
mongod --config /etc/mongod.conf --fork

4、验证认证

bash 复制代码
# 无认证连接测试(应失败)
mongosh
> show dbs  # 返回错误

# 带认证连接
mongo -u "admin" -p "your-strong-password" --authenticationDatabase "admin"

# 验证权限
> use admin
> show users  # 应显示用户信息

四、用Navicat连接MongoDB

1、编辑连接并测试

2、新建查询并测试

相关推荐
IDC02_FEIYA1 小时前
SQL Server 2025数据库安装图文教程(附SQL Server2025数据库下载安装包)
数据库·windows
辞砚技术录2 小时前
MySQL面试题——联合索引
数据库·面试
萧曵 丶2 小时前
MySQL 主键不推荐使用 UUID 的深层原因
数据库·mysql·索引
小北方城市网2 小时前
分布式锁实战指南:从选型到落地,避开 90% 的坑
java·数据库·redis·分布式·python·缓存
毕设十刻2 小时前
基于Vue的人事管理系统67zzz(程序 + 源码 + 数据库 + 调试部署 + 开发环境配置),配套论文文档字数达万字以上,文末可获取,系统界面展示置于文末
前端·数据库·vue.js
TDengine (老段)4 小时前
TDengine Python 连接器入门指南
大数据·数据库·python·物联网·时序数据库·tdengine·涛思数据
萧曵 丶4 小时前
事务ACID特性详解
数据库·事务·acid
kejiayuan5 小时前
CTE更易懂的SQL风格
数据库·sql
kaico20185 小时前
MySQL的索引
数据库·mysql
清水白石0086 小时前
解构异步编程的两种哲学:从 asyncio 到 Trio,理解 Nursery 的魔力
运维·服务器·数据库·python