linux

Linux系统MongoDB配置有哪些要点

小樊
35
2025-06-09 05:18:22
栏目: 云计算

在Linux系统上配置MongoDB涉及多个要点,以下是一些关键步骤和配置建议:

安装MongoDB

创建数据目录和日志目录

sudo mkdir -p /var/lib/mongodb
sudo mkdir -p /var/log/mongodb
sudo chown -R $(whoami) /var/lib/mongodb
sudo chown -R $(whoami) /var/log/mongodb

配置环境变量

echo 'export PATH=/usr/local/mongodb/bin:$PATH' >> ~/.bashrc
source ~/.bashrc

创建和编辑配置文件

# /etc/mongod.conf 示例配置
storage:
  dbPath: /var/lib/mongodb
  journal:
    enabled: true
systemLog:
  destination: file
  logAppend: true
  path: /var/log/mongodb/mongod.log
net:
  port: 27017
  bindIp: 0.0.0.0
security:
  authorization: enabled

启动MongoDB服务

sudo mongod --config /etc/mongod.conf

设置开机自启

# /etc/systemd/system/mongodb.service 示例配置
[Unit]
Description=High-performance, schema-free document-oriented database
After=network.target

[Service]
User=mongodb
Group=mongodb
ExecStart=/usr/local/mongodb/bin/mongod --config /etc/mongod.conf
Restart=always

[Install]
WantedBy=multi-user.target

重新加载systemd管理器配置并启动MongoDB服务:

sudo systemctl daemon-reload
sudo systemctl start mongodb
sudo systemctl enable mongodb

安全配置

# 启用认证
auth=true

# 创建管理员用户
use admin
db.createUser({
  user: "admin",
  pwd: "yourPassword",
  roles: [ { role: "userAdminAnyDatabase", db: "admin" } ]
})

防火墙和SELinux设置

# 允许MongoDB端口(例如27017)
sudo ufw allow 27017

# 对于CentOS/RHEL
sudo firewall-cmd --permanent --add-port=27017/tcp
sudo firewall-cmd --reload

性能调优

sudo sysctl -w vm.dirty_background_ratio=100
sudo sysctl -w vm.dirty_ratio=100
ulimit -n 20000
echo never | sudo tee /sys/kernel/mm/transparent_hugepage/enabled

备份与恢复

# 备份
mongodump --out /var/backups/mongodb/$(date +%Y%m%d)

# 恢复
mongorestore /var/backups/mongodb/$(date +%Y%m%d)

监控和诊断

通过以上步骤和配置要点,您可以在Linux环境下高效地配置和优化MongoDB服务。根据具体需求和硬件配置,调整相应的配置参数,并定期监控和优化数据库性能。

0
看了该问题的人还看了