使用systemctl命令确认MongoDB服务是否正在运行,若未运行则尝试启动:
sudo systemctl status mongod # 查看服务状态
sudo systemctl start mongod # 启动服务
sudo systemctl enable mongod # 设置开机自启(可选)
若启动失败,需结合日志进一步分析原因。
MongoDB的默认日志路径为/var/log/mongodb/mongod.log,通过以下命令实时查看最新日志或搜索关键词(如“error”):
sudo tail -f /var/log/mongodb/mongod.log # 实时查看日志
sudo grep "error" /var/log/mongodb/mongod.log # 搜索错误信息
日志中通常包含服务启动失败、连接拒绝、查询超时等具体错误描述,是故障定位的关键依据。
MongoDB的主配置文件为/etc/mongod.conf,需检查以下核心配置项是否正确:
storage.dbPath:数据存储目录(如/var/lib/mongodb),需确保目录存在;systemLog.path:日志文件路径(如/var/log/mongodb/mongod.log),需确保目录可写;net.bindIp:绑定的IP地址(如127.0.0.1仅本地访问,0.0.0.0允许远程访问);net.port:监听端口(默认27017)。sudo systemctl restart mongod
MongoDB需要对其数据目录(storage.dbPath指定的路径)有读写权限。默认数据目录为/var/lib/mongodb,执行以下命令确保权限正确:
sudo mkdir -p /var/lib/mongodb # 若目录不存在则创建
sudo chown -R mongodb:mongodb /var/lib/mongodb # 修改所有者为mongodb用户
sudo chmod -R 755 /var/lib/mongodb # 设置目录权限(可选,755通常足够)
权限问题常导致服务无法启动或数据无法写入。
netstat或ss命令确认MongoDB端口(默认27017)未被其他进程占用:sudo netstat -tulnp | grep 27017 # 查看端口占用情况
sudo ss -tulnp | grep 27017 # 替代命令(更现代)
若端口被占用,需停止冲突进程或修改MongoDB的net.port配置。27017端口通过防火墙(如ufw):sudo ufw allow 27017/tcp # 允许TCP协议的27017端口
sudo ufw reload # 重新加载防火墙规则
mongostat:监控数据库性能指标(如插入、查询、更新操作的QPS),实时查看系统负载:mongostat # 默认每秒刷新一次
mongotop:分析集合级别的读写时间,定位慢操作的热点集合:mongotop # 默认每秒刷新一次
explain()命令:分析查询性能,查看查询计划(如是否使用了索引):use your_database;
db.your_collection.find({field: "value"}).explain("executionStats");
通过分析executionStats中的executionTimeMillis(执行时间)、winningPlan(执行计划)等字段,可优化查询语句或索引。MongoDB的性能受系统资源限制,需检查以下指标:
free -h查看内存剩余情况,若内存不足可能导致频繁交换(swap),影响性能;df -h查看磁盘剩余空间,若磁盘空间不足(如小于10%),可能导致写入失败;top或htop查看CPU占用率,若CPU过高可能导致查询延迟。若使用较旧的MongoDB版本(如3.x或4.x),可能存在已知bug(如连接泄漏、性能问题)。建议升级到最新稳定版本(如6.x),升级前需备份数据并参考官方升级指南:
# 示例:卸载旧版本(谨慎操作,先备份)
sudo apt remove mongodb-org
# 安装新版本(参考官方文档)
wget -qO - https://www.mongodb.org/static/pgp/server-6.0.asc | sudo apt-key add -
echo "deb [ arch=amd64,arm64 ] https://repo.mongodb.org/apt/debian $(lsb_release -sc)/mongodb-org/6.0 multiverse" | sudo tee /etc/apt/sources.list.d/mongodb-org-6.0.list
sudo apt update
sudo apt install -y mongodb-org
若以上步骤无法解决问题,可参考MongoDB官方文档的故障排除指南(如Connection Issues、Performance Issues),或在社区论坛(如Stack Overflow、MongoDB Community)搜索类似问题的解决方案。