在Linux系统上配置MongoDB涉及多个要点,以下是一些关键步骤和配置建议:
apt
用于Ubuntu/Debian,yum
用于CentOS/RHEL)安装MongoDB。/var/lib/mongodb
和 /var/log/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
的配置文件。dbpath
)、日志文件路径(logpath
)、端口号(port
)、启用日志追加模式(logappend
)、以守护进程方式运行(fork
)等参数。# /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
mongod --config /etc/mongod.conf
命令启动MongoDB服务。sudo mongod --config /etc/mongod.conf
/etc/systemd/system/mongodb.service
),并配置MongoDB在系统启动时自动运行。# /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
。mongo
命令行工具连接到MongoDB并创建管理员用户,分配适当的角色和权限。# 启用认证
auth=true
# 创建管理员用户
use admin
db.createUser({
user: "admin",
pwd: "yourPassword",
roles: [ { role: "userAdminAnyDatabase", db: "admin" } ]
})
# 允许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
命令进行数据备份。mongorestore
命令进行数据恢复。# 备份
mongodump --out /var/backups/mongodb/$(date +%Y%m%d)
# 恢复
mongorestore /var/backups/mongodb/$(date +%Y%m%d)
mongostat
和 mongotop
监控数据库性能。通过以上步骤和配置要点,您可以在Linux环境下高效地配置和优化MongoDB服务。根据具体需求和硬件配置,调整相应的配置参数,并定期监控和优化数据库性能。