Mongodb重装

一 卸载MongoDB

1 停止 MongoDB 服务

首先停止正在运行的 MongoDB 服务:

bash 复制代码
sudo systemctl stop mongod

2 卸载 MongoDB 包

使用 yum 命令删除 MongoDB 相关的包:

bash 复制代码
sudo yum remove mongodb-org

3 删除数据目录和日志文件(根据实际情况操作,留好备份)

MongoDB 默认会在以下位置创建数据和日志文件的目录:

  • 数据目录:/var/lib/mongo
  • 日志目录:/var/log/mongodb
    如果你希望完全删除数据和日志,可以使用以下命令:
bash 复制代码
sudo rm -r /var/lib/mongo
sudo rm -r /var/log/mongodb

二 重新安装 MongoDB

1 恢复相关目录及其权限

如果这些目录已经删除,你需要手动创建它们。

bash 复制代码
sudo mkdir -p /var/lib/mongo 
sudo mkdir -p /var/log/mongodb

然后确保这些目录的权限和所有权正确:

bash 复制代码
sudo chown -R mongod:mongod /var/lib/mongo 
sudo chown -R mongod:mongod /var/log/mongodb

2 设置 MongoDB 的官方源

如果你还没有设置官方的 MongoDB 源,可以执行以下命令来添加它(以 MongoDB 5.0 为例):

bash 复制代码
cat <<EOF | sudo tee /etc/yum.repos.d/mongodb-org-5.0.repo
[mongodb-org-5.0]
name=MongoDB Repository
baseurl=https://repo.mongodb.org/yum/redhat/\$releasever/mongodb-org/5.0/x86_64/
gpgcheck=1
enabled=1
gpgkey=https://www.mongodb.org/static/pgp/server-5.0.asc
EOF

3 安装及启动

使用以下命令安装最新版本的 MongoDB:

bash 复制代码
sudo yum install -y mongodb-org

安装完成后,启动 MongoDB 并设置为开机启动:

bash 复制代码
sudo systemctl start mongod
sudo systemctl enable mongod

使用以下命令检查 MongoDB 服务状态:

bash 复制代码
sudo systemctl status mongod

三 补充

1配置文件恢复

MongoDB 的配置文件通常位于 /etc/mongod.conf。如果重装后 /etc/mongod.conf 仍然缺失,手动创建默认配置文件:

bash 复制代码
# mongod.conf

# 数据存储
storage:
  dbPath: /var/lib/mongo
  journal:
    enabled: true

# 日志
systemLog:
  destination: file
  logAppend: true
  path: /var/log/mongodb/mongod.log

# 网络配置
net:
  port: 27017
  bindIp: 127.0.0.1

保存文件后,确保配置文件的权限设置正确:

bash 复制代码
sudo chown mongod:mongod /etc/mongod.conf

创建好目录和配置文件后,重新执行上述启动操作:

bash 复制代码
sudo systemctl start mongod
sudo systemctl status mongod

2 检查错误日志

如果重装后仍有问题,可以查看 MongoDB 日志文件 /var/log/mongodb/mongod.log 以排查错误:

bash 复制代码
sudo tail -f /var/log/mongodb/mongod.log
相关推荐
jump_jump2 小时前
Drizzle 凭什么贴着 Go 跑——从设计哲学到热路径源码
数据库·性能优化·orm
jay神2 小时前
基于SpringBoot的宠物生命周期信息管理系统
java·数据库·spring boot·后端·web开发·宠物·管理系统
秋93 小时前
MySQL 8.0.46 与 MySQL 9.7.0在sql语句方面的区别并举例说明
数据库·sql·mysql
一只数据集3 小时前
NVIDIA Nemotron AIQ Agentic Safety Dataset:面向企业级智能体系统的安全与防护评估数据集全面解析
网络·数据库·安全
Amazinqc3 小时前
Mysql数据库数据软隔离的并发死锁情况
数据库·mysql·死锁
DianSan_ERP3 小时前
京东订单接口集成中如何处理消费者敏感信息的安全与合规问题?
前端·数据库·后端·团队开发·运维开发
原来是猿3 小时前
TCP Echo Server 深度解析:从单进程到线程池的演进之路(中)
linux·服务器·数据库
treesforest3 小时前
IP地址段查询完全指南:从单IP查到IPv4段批量归属地查询
网络·数据库·网络协议·tcp/ip·网络安全·运维开发
渣渣灰95874 小时前
基于STM32F03ZET6移植FreeRTOS
数据库·stm32·嵌入式硬件
庞轩px4 小时前
第七篇:Redis分布式锁——从setnx到RedLock的演进之路
数据库·redis·分布式锁·redission·setnx·redlock·可重入锁