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、新建查询并测试

相关推荐
Coder_Boy_2 分钟前
技术让开发更轻松的底层矛盾
java·大数据·数据库·人工智能·深度学习
helloworldandy9 分钟前
使用Pandas进行数据分析:从数据清洗到可视化
jvm·数据库·python
数据知道2 小时前
PostgreSQL 故障排查:如何找出数据库中最耗时的 SQL 语句
数据库·sql·postgresql
qq_12498707532 小时前
基于SSM的动物保护系统的设计与实现(源码+论文+部署+安装)
java·数据库·spring boot·毕业设计·ssm·计算机毕业设计
枷锁—sha2 小时前
【SRC】SQL注入WAF 绕过应对策略(二)
网络·数据库·python·sql·安全·网络安全
Coder_Boy_2 小时前
基于SpringAI的在线考试系统-考试系统开发流程案例
java·数据库·人工智能·spring boot·后端
Gain_chance2 小时前
35-学习笔记尚硅谷数仓搭建-DWS层最近n日汇总表及历史至今汇总表建表语句
数据库·数据仓库·hive·笔记·学习
此生只爱蛋3 小时前
【Redis】主从复制
数据库·redis
马猴烧酒.3 小时前
【面试八股|JAVA多线程】JAVA多线程常考面试题详解
java·服务器·数据库
天天爱吃肉82183 小时前
跟着创意天才周杰伦学新能源汽车研发测试!3年从工程师到领域专家的成长秘籍!
数据库·python·算法·分类·汽车