1. 准备安装介质
安装介质下载:
mongodb的安装方式,我通常使用二进制包的方式,内网不能配置连接外网的yum源;
官方建议的mongodb下载地址为: Downloads.mongodb.org
但实际上,这个地址,很难找到下载表,正常下载,通常可以用下面的下载地址选择下载:
https://www.mongodb.org/dl/linux/x86_64
我这里下载的是: 3.2.5 版本对应的 mongodb-linux-x86_64-rhel62-3.2.5-20-g07e21d8.tgz
如果将整个mongodb安装过程已经编写了脚本,可以获取安装脚本,用脚本执行安装;
如果手动安装,则可跳过此步;
手工安装mongodb的脚步的执行过程,一般如下:
1
2
3
4
|
mkdir -p /root/{software,scripts} wget -q http://ptmaster.test.cn/files/init/mongodb_install.sh -O /root/scripts/mongodb_install.sh cd /root/scripts ./mongodb_install.sh -p 27117 |
2. 添加mongodb用户和环境变量,修改系统设置
添加用户:
1
2
|
groupadd mongodb useradd -g mongodb mongodb |
创建mongodb脚本目录
1
|
mkdir -p /home/mongodb/scripts/ |
修改目录权限:
1
|
chown -R mongodb:mongodb /home/mongodb/scripts/ |
在 /etc/profile 中添加 mongodb 用户的环境变量:
1
2
|
# MongoDB Environment Variables export PATH=$PATH:$HOME/bin:/usr/ local /mongodb/bin:/home/mongodb/scripts/ |
是上面的变量生效:
source /etc/profile
实际操作过程如下:
1
2
3
4
5
6
7
8
9
10
11
|
[root@yq-mapp-otadb248 etc]# id mongodb id: mongodb: No such user [root@yq-mapp-otadb248 etc]# [root@yq-mapp-otadb248 etc]# [root@yq-mapp-otadb248 etc]# groupadd mongodb useradd -g mongodb mongodb[root@yq-mapp-otadb248 etc]# useradd -g mongodb mongodb [root@yq-mapp-otadb248 etc]# [root@yq-mapp-otadb248 etc]# [root@yq-mapp-otadb248 etc]# id mongodb uid=801(mongodb) gid=801(mongodb) groups=801(mongodb) [root@yq-mapp-otadb248 etc]# |
mongodb要求hugepage设置为禁用,soft limit设置足够大,可以在一开始修改,也可以到后面修改;
1
|
cat /etc/security/limits.d/90-nproc.conf |
修改这个文件中下列的值
1
|
* soft nproc 2048 |
确保: soft nproc 的值至少是 soft nofile 值的一半;
修改后,退出当前用户,重新进入一下,设置就可以生效了;
禁用 hugepage 的值:
1
2
|
# echo "never" > /sys/kernel/mm/transparent_hugepage/enabled # echo "never" > /sys/kernel/mm/transparent_hugepage/defrag |
备注:上面两个警告,现在不修改也不影响安装过程,后面会提示。
3. 安装mongodb软件
上传并解压软件:
1
2
3
4
|
cd /usr/ local rz mongodb-linux-x86_64-rhel62-3.2.5-20-g07e21d8.tgz tar -zxvf mongodb-linux-x86_64-rhel62-3.2.5-20-g07e21d8.tgz ln -sv mongodb-linux-x86_64-rhel62-3.2.5-20-g07e21d8 /usr/ local /mongodb |
修改文件权限:
1
2
|
chown -R mongodb:mongodb mongodb-linux-x86_64-rhel62-3.2.5-20-g07e21d8 chown -R mongodb:mongodb /usr/ local /mongodb |
实际操作过程如下:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
|
[root@yq-mapp-otadb248 src]# rz rz waiting to receive. Starting zmodem transfer. Press Ctrl+C to cancel. Transferring mongodb-linux-x86_64-rhel62-3.2.5.tar.gz... 100% 66999 KB 16749 KB/sec 00:00:04 0 Errors [root@yq-mapp-otadb248 src]# ll total 277792 -rw-r --r-- 1 root root 68607629 Oct 19 11:53 mongodb-linux-x86_64-rhel62-3.2.5.tar.gz -rw-r --r-- 1 root root 215848960 Apr 19 2016 mongodb-linux-x86_64-rhel62-v3.2-latest [root@yq-mapp-otadb248 src]# [root@yq-mapp-otadb248 src]# tar -zxvf mongodb-linux-x86_64-rhel62-3.2.5.tar.gz mongodb-linux-x86_64-rhel62-3.2.5-20-g07e21d8/bin/ mongodb-linux-x86_64-rhel62-3.2.5-20-g07e21d8/bin/mongooplog mongodb-linux-x86_64-rhel62-3.2.5-20-g07e21d8/bin/mongod mongodb-linux-x86_64-rhel62-3.2.5-20-g07e21d8/bin/mongo mongodb-linux-x86_64-rhel62-3.2.5-20-g07e21d8/bin/mongofiles mongodb-linux-x86_64-rhel62-3.2.5-20-g07e21d8/bin/bsondump mongodb-linux-x86_64-rhel62-3.2.5-20-g07e21d8/bin/mongorestore mongodb-linux-x86_64-rhel62-3.2.5-20-g07e21d8/bin/mongos mongodb-linux-x86_64-rhel62-3.2.5-20-g07e21d8/bin/mongoexport mongodb-linux-x86_64-rhel62-3.2.5-20-g07e21d8/bin/mongodump mongodb-linux-x86_64-rhel62-3.2.5-20-g07e21d8/bin/mongoimport mongodb-linux-x86_64-rhel62-3.2.5-20-g07e21d8/bin/mongotop mongodb-linux-x86_64-rhel62-3.2.5-20-g07e21d8/bin/mongostat mongodb-linux-x86_64-rhel62-3.2.5-20-g07e21d8/bin/mongoperf mongodb-linux-x86_64-rhel62-3.2.5-20-g07e21d8/GNU-AGPL-3.0 mongodb-linux-x86_64-rhel62-3.2.5-20-g07e21d8/MPL-2 mongodb-linux-x86_64-rhel62-3.2.5-20-g07e21d8/README mongodb-linux-x86_64-rhel62-3.2.5-20-g07e21d8/THIRD-PARTY-NOTICES [root@yq-mapp-otadb248 src]# [root@yq-mapp-otadb248 src]# ll total 277796 drwxr-xr-x 3 root root 4096 Oct 19 11:54 mongodb-linux-x86_64-rhel62-3.2.5-20-g07e21d8 -rw-r --r-- 1 root root 68607629 Oct 19 11:53 mongodb-linux-x86_64-rhel62-3.2.5.tar.gz -rw-r --r-- 1 root root 215848960 Apr 19 2016 mongodb-linux-x86_64-rhel62-v3.2-latest [root@yq-mapp-otadb248 src]# [root@yq-mapp-otadb248 src]# mv mongodb-linux-x86_64-rhel62-3.2.5-20-g07e21d8 ../ [root@yq-mapp-otadb248 src]# cd .. [root@yq-mapp-otadb248 local ]# [root@yq-mapp-otadb248 local ]# ln -sv mongodb-linux-x86_64-rhel62-3.2.5-20-g07e21d8 /usr/ local /mongodb `/usr/ local /mongodb ' -> `mongodb-linux-x86_64-rhel62-3.2.5-20-g07e21d8' [root@yq-mapp-otadb248 local ]# [root@yq-mapp-otadb248 local ]# chown -R mongodb:mongodb mongodb-linux-x86_64-rhel62-3.2.5-20-g07e21d8 [root@yq-mapp-otadb248 local ]# chown -R mongodb:mongodb /usr/ local /mongodb [root@yq-mapp-otadb248 local ]# [root@yq-mapp-otadb248 local ]# ll total 52 drwxr-xr-x. 2 root root 4096 Apr 24 2014 bin drwxr-xr-x. 2 root root 4096 Sep 23 2011 etc drwxr-xr-x. 2 root root 4096 Sep 23 2011 games drwxr-xr-x. 2 root root 4096 Sep 23 2011 include drwxr-xr-x. 2 root root 4096 Sep 23 2011 lib drwxr-xr-x. 3 root root 4096 Apr 25 2014 lib64 drwxr-xr-x. 2 root root 4096 Sep 23 2011 libexec lrwxrwxrwx 1 root root 25 Mar 6 2015 logstash -> /usr/ local /logstash-1.4.2 drwxrwxr-x 8 logstash logstash 4096 Jun 24 2014 logstash-1.4.2 lrwxrwxrwx 1 mongodb mongodb 45 Oct 19 11:59 mongodb -> mongodb-linux-x86_64-rhel62-3.2.5-20-g07e21d8 drwxr-xr-x 3 mongodb mongodb 4096 Oct 19 11:54 mongodb-linux-x86_64-rhel62-3.2.5-20-g07e21d8 lrwxrwxrwx 1 root root 39 Apr 23 2014 mysql -> /usr/ local /mysql-5.5.19-linux2.6-x86_64 drwxr-xr-x 12 root mysql 4096 Apr 23 2014 mysql-5.5.19-linux2.6-x86_64 drwxr-xr-x. 2 root root 4096 Sep 23 2011 sbin drwxr-xr-x. 6 root root 4096 Apr 25 2014 share drwxr-xr-x. 2 root root 4096 Oct 19 11:54 src [root@yq-mapp-otadb248 local ]# |
4. 创建mongodb实例所需的目录和配置文件
创建mongodb实例所需目录:
1
|
mkdir -p /data/mongo_27117/{db,log,tmp} |
创建mongodb实例配置文件所需目录和文件:
1
2
|
mkdir -p /etc/mongodb touch /etc/mongodb/mongo_27117.conf |
根据需要配置mongodb的启动参数,我的启动参数配置内容如下:
vim /etc/mongodb/mongo_27117.conf
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
|
dbpath=/data/mongo_27117/db logpath=/data/mongo_27117/log/mongo_27117.log pidfilepath = /data/mongo_27117/tmp/mongo_27117.pid storageEngine = wiredTiger wiredTigerCacheSizeGB = 2 syncdelay = 30 wiredTigerCollectionBlockCompressor = zlib port=27117 auth = true directoryperdb = true oplogSize=2048 logappend= true fork= true #rest= true journal = true journalCommitInterval = 50 slowms = 200 |
修改目录、文件的权限和属组:
1
2
|
chown -R mongodb:mongodb /data/mongo_27117/ chown -R mongodb:mongodb /etc/mongodb |
确认目录和配置文件都已经准备完毕:
1
2
3
|
ls -l /data/mongo_27117/ ls -l /etc/mongodb cat /etc/mongodb/mongo_27117.conf |
该步骤实际操作过程如下:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
|
[root@yq-mapp-otadb248 local ]# [root@yq-mapp-otadb248 local ]# mkdir -p /data/mongo_27117/{db,log,tmp} [root@yq-mapp-otadb248 local ]# mkdir -p /etc/mongodb [root@yq-mapp-otadb248 local ]# [root@yq-mapp-otadb248 local ]# [root@yq-mapp-otadb248 local ]# vim /etc/mongodb/mongo_27117.conf dbpath=/data/mongo_27117/db logpath=/data/mongo_27117/log/mongo_27117.log pidfilepath = /data/mongo_27117/tmp/mongo_27117.pid storageEngine = wiredTiger wiredTigerCacheSizeGB = 2 syncdelay = 30 wiredTigerCollectionBlockCompressor = zlib port=27117 auth = true directoryperdb = true oplogSize=2048 logappend= true fork= true #rest= true journal = true journalCommitInterval = 50 slowms = 200 ~ [root@yq-mapp-otadb248 local ]# [root@yq-mapp-otadb248 local ]# chown -R mongodb:mongodb /data/mongo_27117/ [root@yq-mapp-otadb248 local ]# chown -R mongodb:mongodb /etc/mongodb [root@yq-mapp-otadb248 local ]# ls -l /data/mongo_27117/ total 12 drwxr-xr-x 2 mongodb mongodb 4096 Oct 19 12:02 db drwxr-xr-x 2 mongodb mongodb 4096 Oct 19 12:02 log drwxr-xr-x 2 mongodb mongodb 4096 Oct 19 12:02 tmp [root@yq-mapp-otadb248 local ]# [root@yq-mapp-otadb248 local ]# [root@yq-mapp-otadb248 local ]# ls -l /etc/mongodb total 4 -rw-r --r-- 1 mongodb mongodb 392 Oct 19 12:05 mongo_27117.conf [root@yq-mapp-otadb248 local ]# [root@yq-mapp-otadb248 local ]# cat /etc/mongodb/mongo_27117.conf dbpath=/data/mongo_27117/db logpath=/data/mongo_27117/log/mongo_27117.log pidfilepath = /data/mongo_27117/tmp/mongo_27117.pid storageEngine = wiredTiger wiredTigerCacheSizeGB = 2 syncdelay = 30 wiredTigerCollectionBlockCompressor = zlib port=27117 auth = true directoryperdb = true oplogSize=2048 logappend= true fork= true #rest= true journal = true journalCommitInterval = 50 slowms = 200 |
5. 启动mongodb实例,修改管理员密码
使用下面的命令启动mongodb服务:
1
|
/usr/ local /mongodb/bin/mongod --config /etc/mongodb/mongo_27117.conf |
确认密码,mongodb的管理员密码,可以根据各自的规则设置:
1
2
|
echo $MONGODB_ROOT_PASS mongodb_020248_Pass |
修改管理员密码,注意 mongodb 3.2要对admin授予三个角色,这点与之前的版本不同:
1
2
3
4
|
/usr/ local /mongodb/bin/mongo --port=27117 db.createUser({ user : 'useradmin' ,pwd: 'mongodb_020248_Pass' ,roles:[ { "role" : "clusterAdmin" , "db" : "admin" }, { "role" : "userAdminAnyDatabase" , "db" : "admin" }, { "role" : "dbAdminAnyDatabase" , "db" : "admin" } ] }) db.auth( "useradmin" , "mongodb_020248_Pass" ) db.system.users.find(); |
生成密码后,使用新用户和密码登陆mongo,确认状态:
1
|
/usr/ local /mongodb/bin/mongo --port=27117 -u useradmin -p mongodb_020248_Pass --authenticationDatabase admin |
该步骤操作过程如下;
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
|
[root@yq-mapp-otadb248 local ]# [root@yq-mapp-otadb248 local ]# ps -ef|grep mongo root 32295 30115 0 12:12 pts/0 00:00:00 grep mongo [root@yq-mapp-otadb248 local ]# [root@yq-mapp-otadb248 local ]# /usr/ local /mongodb/bin/mongod --config /etc/mongodb/mongo_27117.conf about to fork child process, waiting until server is ready for connections. forked process: 32321 child process started successfully, parent exiting [root@yq-mapp-otadb248 local ]# [root@yq-mapp-otadb248 local ]# ps -ef|grep mongo root 32321 1 1 12:12 ? 00:00:00 /usr/ local /mongodb/bin/mongod --config /etc/mongodb/mongo_27117.conf root 32359 30115 0 12:13 pts/0 00:00:00 grep mongo [root@yq-mapp-otadb248 local ]# [root@yq-mapp-otadb248 local ]# [root@yq-mapp-otadb248 local ]# /usr/ local /mongodb/bin/mongo --port=27117 MongoDB shell version: 3.2.5-20-g07e21d8 connecting to : 127.0.0.1:27117/test Welcome to the MongoDB shell. For interactive help, type "help" . For more comprehensive documentation, see http://docs.mongodb.org/ Questions? Try the support group http://groups.google.com/ group /mongodb- user > > use admin; switched to db admin > db.system.users.find(); Error: error: { "ok" : 0, "errmsg" : "not authorized on admin to execute command { find: \"system.users\", filter: {} }" , "code" : 13 } > > db.createUser({ user : 'useradmin' ,pwd: 'mongodb_020248_@JJMatch' ,roles:[ { "role" : "clusterAdmin" , "db" : "admin" }, { "role" : "userAdminAnyDatabase" , "db" : "admin" }, { "role" : "dbAdminAnyDatabase" , "db" : "admin" } ] }) Successfully added user : { "user" : "useradmin" , "roles" : [ { "role" : "clusterAdmin" , "db" : "admin" }, { "role" : "userAdminAnyDatabase" , "db" : "admin" }, { "role" : "dbAdminAnyDatabase" , "db" : "admin" } ] } > > db.system.users.find(); Error: error: { "ok" : 0, "errmsg" : "not authorized on admin to execute command { find: \"system.users\", filter: {} }" , "code" : 13 } > > db.auth( "useradmin" , "mongodb_020248_@JJMatch" ) 1 > > db.system.users.find(); { "_id" : "admin.useradmin" , "user" : "useradmin" , "db" : "admin" , "credentials" : { "SCRAM-SHA-1" : { "iterationCount" : 10000, "salt" : "6hLx/d97hS+yfoN47QTmXQ==" , "storedKey" : "B0PqwVs3GFKIHQyyQ6mBp1MA370=" , "serverKey" : "xK53AKKAvFCdn5rsEtij5QB9RtU=" } }, "roles" : [ { "role" : "clusterAdmin" , "db" : "admin" }, { "role" : "userAdminAnyDatabase" , "db" : "admin" }, { "role" : "dbAdminAnyDatabase" , "db" : "admin" } ] } > [root@yq-mapp-otadb248 local ]# [root@yq-mapp-otadb248 local ]# /usr/ local /mongodb/bin/mongo --port=27117 -u useradmin -p mongodb_020248_@JJMatch --authenticationDatabase admin MongoDB shell version: 3.2.5-20-g07e21d8 connecting to : 127.0.0.1:27117/test Server has startup warnings: 2016-10-19T12:12:59.096+0800 I CONTROL [initandlisten] 2016-10-19T12:12:59.096+0800 I CONTROL [initandlisten] ** WARNING: The server was started without specifying a --bind_ip 2016-10-19T12:12:59.096+0800 I CONTROL [initandlisten] ** and listens for connections on all available network interfaces. 2016-10-19T12:12:59.097+0800 I CONTROL [initandlisten] ** WARNING: You are running this process as the root user , which is not recommended. 2016-10-19T12:12:59.097+0800 I CONTROL [initandlisten] 2016-10-19T12:12:59.097+0800 I CONTROL [initandlisten] 2016-10-19T12:12:59.097+0800 I CONTROL [initandlisten] ** WARNING: /sys/kernel/mm/transparent_hugepage/enabled is 'always' . 2016-10-19T12:12:59.097+0800 I CONTROL [initandlisten] ** We suggest setting it to 'never' 2016-10-19T12:12:59.097+0800 I CONTROL [initandlisten] 2016-10-19T12:12:59.097+0800 I CONTROL [initandlisten] ** WARNING: /sys/kernel/mm/transparent_hugepage/defrag is 'always' . 2016-10-19T12:12:59.097+0800 I CONTROL [initandlisten] ** We suggest setting it to 'never' 2016-10-19T12:12:59.097+0800 I CONTROL [initandlisten] 2016-10-19T12:12:59.097+0800 I CONTROL [initandlisten] ** WARNING: soft rlimits too low. rlimits set to 2048 processes, 8192 files. Number of processes should be at least 4096 : 0.5 times number of files. 2016-10-19T12:12:59.097+0800 I CONTROL [initandlisten] > > use admin; switched to db admin > > db.system.users.find(); { "_id" : "admin.useradmin" , "user" : "useradmin" , "db" : "admin" , "credentials" : { "SCRAM-SHA-1" : { "iterationCount" : 10000, "salt" : "6hLx/d97hS+yfoN47QTmXQ==" , "storedKey" : "B0PqwVs3GFKIHQyyQ6mBp1MA370=" , "serverKey" : "xK53AKKAvFCdn5rsEtij5QB9RtU=" } }, "roles" : [ { "role" : "clusterAdmin" , "db" : "admin" }, { "role" : "userAdminAnyDatabase" , "db" : "admin" }, { "role" : "dbAdminAnyDatabase" , "db" : "admin" } ] > > |
6. 为应用创建业务账号
创建一个 admin / admin 用户,具有可以自行创建用户和数据库的权限,密码业务自己再修改:
1
|
db.createUser({ user : 'admin' ,pwd: 'admin' ,roles:[{role: 'userAdminAnyDatabase' ,db: 'admin' },{role: 'dbAdminAnyDatabase' ,db: 'admin' }]}) |
验证业务账号登陆:
1
|
/usr/ local /mongodb/bin/mongo --port=27117 -u admin -p admin --authenticationDatabase admin |
该步骤,实际操作过程如下:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
|
> > db.system.users.find().pretty() { "_id" : "admin.useradmin" , "user" : "useradmin" , "db" : "admin" , "credentials" : { "SCRAM-SHA-1" : { "iterationCount" : 10000, "salt" : "6hLx/d97hS+yfoN47QTmXQ==" , "storedKey" : "B0PqwVs3GFKIHQyyQ6mBp1MA370=" , "serverKey" : "xK53AKKAvFCdn5rsEtij5QB9RtU=" } }, "roles" : [ { "role" : "clusterAdmin" , "db" : "admin" }, { "role" : "userAdminAnyDatabase" , "db" : "admin" }, { "role" : "dbAdminAnyDatabase" , "db" : "admin" } ] } { "_id" : "admin.admin" , "user" : "admin" , "db" : "admin" , "credentials" : { "SCRAM-SHA-1" : { "iterationCount" : 10000, "salt" : "snlJe16a2PX3dSwxnOsfAw==" , "storedKey" : "VOoX1e7F0tOme6YuR+iyMLuEWK8=" , "serverKey" : "aSlpI7TzlyJ5Ccbd8GoptNB8khk=" } }, "roles" : [ { "role" : "userAdminAnyDatabase" , "db" : "admin" }, { "role" : "dbAdminAnyDatabase" , "db" : "admin" } ] } > > ^C bye [root@yq-mapp-otadb248 local ]# [root@yq-mapp-otadb248 local ]# [root@yq-mapp-otadb248 local ]# [root@yq-mapp-otadb248 local ]# /usr/ local /mongodb/bin/mongo --port=27117 -u admin -p admin --authenticationDatabase admin MongoDB shell version: 3.2.5-20-g07e21d8 connecting to : 127.0.0.1:27117/test > > show dbs admin 0.000GB local 0.000GB > > |
7. 实例启动时的报警处理
在mongodb启动过程中,有时会提示一些警告,其中常见的两类警告处理过程如下:
警告1:
提示:
2016-10-19T12:12:59.097+0800 I CONTROL [initandlisten] ** WARNING: soft rlimits too low. rlimits set to 2048 processes, 8192 files. Number of processes should be at least 4096 : 0.5 times number of files.
处理方式,根据提示,将 processes 值,由现在的 2048,修改为4096,甚至更高的值。
1
2
3
4
|
ps -ef|grep mongod cat /proc/32321/limits cat /etc/security/limits.d/90-nproc.conf vim /etc/security/limits.d/90-nproc.conf |
该步骤实际操作过程如下:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
|
[root@yq-mapp-otadb248 limits.d]# [root@yq-mapp-otadb248 limits.d]# cat /etc/security/limits.d/90-nproc.conf # 20160621 limit?? #* soft nproc 51200 #* hard nproc 51200 * soft nproc 2048 * hard nproc 16384 * soft nofile 8192 * hard nofile 8192 * soft stack 8192 * hard stack 8192 * soft memlock unlimited * hard memlock unlimited [root@yq-mapp-otadb248 limits.d]# vim /etc/security/limits.d/90-nproc.conf # 20160621 #* soft nproc 51200 #* hard nproc 51200 * soft nproc 8192 * hard nproc 16384 [root@yq-mapp-otadb248 ~]# [root@yq-mapp-otadb248 ~]# ulimt -a -bash: ulimt: command not found [root@yq-mapp-otadb248 ~]# ulimit -a core file size (blocks, -c) 0 data seg size (kbytes, -d) unlimited scheduling priority (-e) 0 file size (blocks, -f) unlimited pending signals (-i) 30422 max locked memory (kbytes, -l) unlimited max memory size (kbytes, -m) unlimited open files (-n) 8192 pipe size (512 bytes, -p) 8 POSIX message queues (bytes, -q) 819200 real - time priority (-r) 0 stack size (kbytes, -s) 8192 cpu time (seconds, -t) unlimited max user processes (-u) 8192 virtual memory (kbytes, -v) unlimited file locks (-x) unlimited |
警告2:
1
2
3
4
5
|
2016-10-19T12:12:59.097+0800 I CONTROL [initandlisten] ** WARNING: /sys/kernel/mm/transparent_hugepage/enabled is 'always' . 2016-10-19T12:12:59.097+0800 I CONTROL [initandlisten] ** We suggest setting it to 'never' 2016-10-19T12:12:59.097+0800 I CONTROL [initandlisten] 2016-10-19T12:12:59.097+0800 I CONTROL [initandlisten] ** WARNING: /sys/kernel/mm/transparent_hugepage/defrag is 'always' . 2016-10-19T12:12:59.097+0800 I CONTROL [initandlisten] ** We suggest setting it to 'never' |
确认:
1
2
|
cat /sys/kernel/mm/transparent_hugepage/enabled cat /sys/kernel/mm/transparent_hugepage/defrag |
处理:
1
2
|
echo "never" > /sys/kernel/mm/transparent_hugepage/enabled echo "never" > /sys/kernel/mm/transparent_hugepage/defrag |
该步骤,实际操作过程如下:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
|
[root@yq-mapp-otadb248 limits.d]# cat /sys/kernel/mm/transparent_hugepage/enabled [always] madvise never [root@yq-mapp-otadb248 limits.d]# cat /sys/kernel/mm/transparent_hugepage/defrag [always] madvise never [root@yq-mapp-otadb248 limits.d]# [root@yq-mapp-otadb248 limits.d]# echo "never" > /sys/kernel/mm/transparent_hugepage/enabled [root@yq-mapp-otadb248 limits.d]# echo "never" > /sys/kernel/mm/transparent_hugepage/defrag [root@yq-mapp-otadb248 limits.d]# [root@yq-mapp-otadb248 limits.d]# cat /sys/kernel/mm/transparent_hugepage/enabled always madvise [never] [root@yq-mapp-otadb248 limits.d]# cat /sys/kernel/mm/transparent_hugepage/defrag always madvise [never] [root@yq-mapp-otadb248 limits.d]# [root@yq-mapp-otadb248 limits.d]# |
8. 创建mongodb实例服务管理脚本
为了方便对mongodb实例的启动和停止,可以先创建mongodb的启动脚本,停止脚本,然后在 /etc/init.d/ 目录下创建一个服务脚本,这样就可以用 service 进行实例管理了。
脚本1:启动脚本:
vim /home/mongodb/scripts/mongodb_start.sh
1
2
3
4
5
|
#!/bin/sh # the scripts is used to start mongodb instance with port 27117. # created by zhaofx on 20161019. echo -n "Starting MongoDB port 27117 ... " /usr/ local /mongodb/bin/mongod --config /etc/mongodb/mongo_27117.conf & |
脚本二:停止脚本:
vim /home/mongodb/scripts/mongodb_stop.sh
1
2
3
4
5
6
7
8
|
#!/bin/bash # the scripts is used to stop mongodb instance with port 27117. # created by zhaofx on 20161019. echo -n "Stopping MongoDB port 27117" pid=`ps -o pid,command ax | grep mongod | awk '!/awk/ && !/grep/ {print $1}' `; if [ "${pid}" != "" ]; then kill -2 ${pid}; fi |
脚本三:服务脚本:
vim /etc/init.d/mongodb
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
|
vim /etc/init.d/mongodb #! /bin/sh # the scripts is used to mange mongodb service with linux service type. # created by zhaofx on 20161019. PATH=/usr/ local /mongodb/bin:/sbin:/bin:/usr/sbin:/usr/bin NAME =mongodb start(){ /home/mongodb/scripts/mongodb_start.sh } stop(){ /home/mongodb/scripts/mongodb_stop.sh } test -x $DAEMON || exit 0 set -e case "$1" in start) start ;; stop) stop ;; *) N=/etc/init.d/$ NAME echo "Usage: $N {start|stop}" >&2 exit 1 ;; esac exit 0 |
修改脚本的属组,添加执行权限:
1
2
3
4
5
|
chown -R mongodb:mongodb /home/mongodb/scripts/ chown mongodb:mongodb /etc/init.d/mongodb chmod +x /home/mongodb/scripts/mongodb_start.sh chmod +x /home/mongodb/scripts/mongodb_stop.sh chmod +x /etc/init.d/mongodb |
最后服务启动和停止mongodb实例的过程为:
1
2
3
4
5
6
7
8
9
10
11
12
|
[root@yq-mapp-otadb248 ~]# [root@yq-mapp-otadb248 ~]# service mongodb stop Stopping MongoDB port 27117 [root@yq-mapp-otadb248 ~]# [root@yq-mapp-otadb248 ~]# [root@yq-mapp-otadb248 ~]# [root@yq-mapp-otadb248 ~]# service mongodb start Starting MongoDB port 27117 ... [root@yq-mapp-otadb248 ~] about to fork child process, waiting until server is ready for connections. forked process: 36088 child process started successfully, parent exiting [root@yq-mapp-otadb248 ~]# |
以上所述是小编给大家介绍的mongodb 3.2.5安装过程详细记录,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对服务器之家网站的支持!
原文链接:http://blog.csdn.net/yumushui/article/details/52859650