环境要求:
- MongoDB只支持64位系统
- MongoDB支持持Oracle Linux Red Hat Compatible Kernal(RHCK)内核, 不支持Unbreakable Enterpries Kernel(UEK)内核
- MongoDB版本 Community Edition v4.4
一. 采用.tgz包安装
依赖条件
运行以下命令安装MongoDB的依赖, 如果是离线状态, 请下载rpm包手动安装.
> sudo yum install libcurl openssl xz-libs
参考文档
https://docs.mongodb.com/manual/tutorial/install-mongodb-on-red-hat-tarball/
安装过程
1. 下载tgz文件
下载地址: https://www.mongodb.com/try/download/community?tck=docs_server
2. 解压安装包
$> tar -zxvf mongodb-linux-*-4.4.1.tgz
3. 将二进制文件目录配置到环境变量中
有两种方式可用, 采用哪种都可以, 推荐第一种.
a. 通过创建软连接的方式, 将可执行文件软连接到/usr/local/bin/
$> sudo ln -s /path/to/the/mongodb-directory/bin/* /usr/local/bin/
b.通过拷贝的方式
$> sudo cp /path/to/the/mongodb-directory/bin/* /usr/local/bin/
4. 设置Linux系统的ulimit值
通常Linux系统会限制一个进程可以访问的系统资源数量, 这些限制有时候会影响到mongo db的使用.
参考文档: https://docs.mongodb.com/manual/reference/ulimit/
a. 查看当前系统的资源限制
$> ulimit -a
-t: cpu time (seconds) unlimited
-f: file size (blocks) unlimited
-d: data seg size (kbytes) unlimited
-s: stack size (kbytes) 8192
-c: core file size (blocks) 0
-m: resident set size (kbytes) unlimited
-u: processes 192276
-n: file descriptors 21000
-l: locked-in-memory size (kb) unlimited
-v: address space (kb) unlimited
-x: file locks unlimited
-i: pending signals 192276
-q: bytes in POSIX msg queues 819200
-e: max nice 30
-r: max rt priority 65
-N 15: unlimited
b. 设置资源限制
官方建议的设置标准为
-
-f
(file size):unlimited
-
-t
(cpu time):unlimited
-
-v
(virtual memory):unlimited
[1] -
-l
(locked-in-memory size):unlimited
-
-n
(open files):64000
-
-m
(memory size):unlimited
[1] [2] -
-u
(processes/threads):64000
$> ulimit -f unlimited
$> ulimit -t unlimited
$> ulimit -v unlimited
$> ulimit -l unlimited
$> ulimit -n 64000
$> ulimit -m unlimited
$> ulimit -u 64000
c. 更新/proc,使变更生效
$> source /etc/profile
d. 重新启动mongodb
$> sudo systemctl restart mongod
5. 配置数据目录和日志目录
MongoDB默认的数据目录和日志目录为:
- 数据目录: /var/lib/mongo
- 日志目录: /var/log/mongodb
采用tgz安装的MongoDB没有自动创建目录,也没有将目前权限赋予mongod,依次需要手动创建并赋予mongod权限.
这里没有采用默认的安装目录,将目录配置为/data1/mongo下
a. 创建目录
$> mkdir -p /data1/mongo/data
$> mkdir -p /data1/mongo/log
__b. 配置mongo配置文件,指定目录__
如果没有该配置目录, 手动创建配置文件, 文件内容参考附录1
配置文件在/etc/mongod.conf中,.
修改storage.dbPath指定数据目录
修改systemLog.path指定日志目录
systemLog:
destination: file
path: "/data1/mongo/log/mongodb.log"
logAppend: true
storage:
journal:
enabled: true
dbPath: "/data1/mongo/data"
processManagement:
fork: true
net:
bindIp: 0.0.0.0
port: 27017
setParameter:
enableLocalhostAuthBypass: false
6. 配置SELinux
为了简单操作, 直接关闭SELinux
a. 临时关闭
$> setenforce 0
b. 永久关闭
机器重启后生效
修改/etc/selinux/config
中的SELINUX=disable
即可, 等下次机器启动了,即可生效
7. 配置远程连接
修改/etc/mongod.conf
net:
port: <int>
bindIp: <string>可以指定多个,用逗号分隔. e.g. 192.168.0.1,192.168.0.2 或者指定全部ip 0.0.0.0
bindIpAll: <boolean>
maxIncomingConnections: <int>
wireObjectCheck: <boolean>
ipv6: <boolean>
unixDomainSocket:
enabled: <boolean>
pathPrefix: <string>
filePermissions: <int>
tls:
certificateSelector: <string>
clusterCertificateSelector: <string>
mode: <string>
certificateKeyFile: <string>
certificateKeyFilePassword: <string>
clusterFile: <string>
clusterPassword: <string>
CAFile: <string>
clusterCAFile: <string>
CRLFile: <string>
allowConnectionsWithoutCertificates: <boolean>
allowInvalidCertificates: <boolean>
allowInvalidHostnames: <boolean>
disabledProtocols: <string>
FIPSMode: <boolean>
compression:
compressors: <string>
serviceExecutor: <string>
启动MongoDB
启动mongodb
时, 指定配置文件位置, 建议采用这种方式
$> mongod -f /etc/mongod.conf
启动时指定数据目录和日志目录
$> mongod --dbpath /data1/mongo/data --logpath /data1/mongo/log/mongodb.log --fork
检查是否启动成功
执行mongo
,检查是否可以正常连接,并使用
mongo
二. 采用RPM安装
依赖条件
运行以下命令安装MongoDB的依赖, 如果是离线状态, 请下载rpm包手动安装.
> sudo yum install libcurl openssl xz-libs
安装过程
1.下载RPM文件
下载4.4版本的MongoDB, 从https://repo.mongodb.org/
下载
Centos 8相关下载地址:
- mongodb-org-mongos-4.4.0-1.el8.x86_64.rpm
- mongodb-org-server-4.4.0-1.el8.x86_64.rpm
- mongodb-org-shell-4.4.0-1.el8.x86_64.rpm
- mongodb-org-tools-4.4.0-1.el8.x86_64.rpm
2.安装RPM文件
$> rpm -ivh mongodb-org-4.4.0-1.el8.x86_64.rpm
3.设置Linux系统的ulimit值
参考上文
4.配置数据库目录和日志目录
参考上文
将数据库目录和日志目录的拥有着设置为mongod
$> sudo chown -R mongod:mongod <directory>
5. 配置SELinux
参考上文
6.配置远程连接
参考上文
启动MongoDB
$> systemctl start mongod
三. 采用yum安装
参考文档:
https://docs.mongodb.com/manual/tutorial/install-mongodb-on-red-hat/
安装过程
1. 配置yum
创建/etc/yum.repos.d/mongodb-org-4.4.repo
[mongodb-org-4.4]
name=MongoDB Repository
baseurl=https://repo.mongodb.org/yum/redhat/$releasever/mongodb-org/4.4/x86_64/
gpgcheck=1
enabled=1
gpgkey=https://www.mongodb.org/static/pgp/server-4.4.asc
2. 安装MongoDB 包
$> sudo yum install -y mongodb-org
3. 修改数据目录和日志目录
参考上文
4. 设置Linux系统的ulimit值
参考上文
5. 设置SELinux
参考上文
6. 配置远程连接
参考上文
7. 配置相关目录权限
配置/var/run/mongodb
权限
chown -R mongod:mongod /var/run/mongodb/
配置/tmp
权限
chmod -R 777 /tmp/
8. 配置开机启动服务
sudo systemctl enable mongod
启动MongoDB
sudo systemctl start mongod
如果发现类似以下错误
Failed to start mongod.service: Unit mongod.service not found.
启动以下命令:
sudo systemctl daemon-reload
查看mongod状态
sudo systemctl status mongod
停止mongod
sudo systemctl stop mongod
重启mongod
sudo systemctl restart mongod
如果启动失败, 可以查看mongo的日志, 分析是什么原因导致的. 常见的是文件目录权限不足导致.
Appendix
1. 配置文件
参考资料: https://docs.mongodb.com/manual/reference/configuration-options/
常规配置文件
systemLog:
destination: file
path: "/data1/mongo/log/mongodb.log"
logAppend: true
storage:
journal:
enabled: true
dbPath: "/data1/mongo/data"
processManagement:
fork: true
net:
bindIp: 0.0.0.0
port: 27017
setParameter:
enableLocalhostAuthBypass: false