MongoDB數(shù)據(jù)庫安裝部署警告優(yōu)化

      網(wǎng)友投稿 985 2022-05-30

      MongoDB安裝部署及警告優(yōu)化

      1.軟件下載

      3.6.13版本:https://fastdl.mongodb.org/linux/mongodb-linux-x86_64-3.6.13.tgz

      4.0.14版本:https://fastdl.mongodb.org/linux/mongodb-linux-x86_64-4.0.14.tgz

      官網(wǎng)文檔:https://docs.mongodb.com/manual/

      2.部署MongoDB

      2.1.規(guī)劃部署目錄

      程序目錄 [root@mongodb-1 ~]# mkdir /data/mongodb_cluster/mongodb_27017/{conf,data,logs,pid} -p 軟件目錄 [root@mongodb-1 ~]# mkdir /data/soft [root@mongodb-1 ~]# tree /data/ /data/ ├── mongodb_cluster │ └── mongodb_27017 │ ├── conf │ ├── data │ ├── logs │ └── pid └── soft 7 directories, 0 files

      1

      2

      3

      4

      5

      6

      7

      8

      9

      10

      11

      12

      13

      14

      15

      16

      17

      2.2.下載軟件包

      [root@mongodb-1 ~]# cd /data/soft/ [root@mongodb-1 /data/soft]# wget https://fastdl.mongodb.org/linux/mongodb-linux-x86_64-4.0.14.tgz

      1

      2

      2.3.安裝MongoDB

      MongoDB下載后直接解壓即可使用,不包含配置文件,需要自己創(chuàng)建

      1.解壓MongoDB [root@mongodb-1 /data/soft]# tar xf mongodb-linux-x86_64-4.0.14.tgz -C /data/mongodb_cluster/ 2.制作軟連接 [root@mongodb-1 /data/soft]# cd /data/mongodb_cluster/ [root@mongodb-1 /data/mongodb_cluster]# ln -s mongodb-linux-x86_64-4.0.14/ mongodb 3.創(chuàng)建MongoDB配置文件目錄 [root@mongodb-1 ~]# mkdir /data/mongodb_cluster/mongodb_27017/{conf,data,logs,pid} -p [root@mongodb-1 ~]# tree /data/ -d /data/ ├── mongodb_cluster │ ├── mongodb -> mongodb-linux-x86_64-4.0.14/ │ ├── mongodb_27017 │ │ ├── conf │ │ ├── data │ │ ├── logs │ │ └── pid │ └── mongodb-linux-x86_64-4.0.14 │ └── bin └── soft

      1

      2

      3

      4

      5

      6

      7

      8

      9

      10

      11

      12

      13

      14

      15

      16

      17

      18

      19

      20

      21

      2.4.MongoDB配置文件介紹

      配置文件注解: systemLog: destination: file //Mongodb日志輸出為文件 logAppend: true //當(dāng)實例重啟時,不創(chuàng)建新的日志文件, 在老的日志文件末尾繼續(xù)添加 path: /data/mongodb_cluster/mongodb_27017/logs/mongodb.log //日志路徑 storage: journal: //回滾日志,類似于mysql的binlog enabled: true //開啟回滾日志 dbPath: /data/mongodb_cluster/mongodb_27017/data //數(shù)據(jù)存儲目錄 directoryPerDB: true //默認(rèn),false不適用inmemoryengine wiredTiger: //存儲引擎 engineConfig: cacheSizeGB: 1 //將用于所有數(shù)據(jù)緩存的大小 directoryForIndexes: true //默認(rèn)false索引集合storage.dbPath存儲在數(shù)據(jù)單獨子目錄,這里必須配置為true,否則所有庫的數(shù)據(jù)文件都會存放在一個目錄中 collectionConfig: blockCompressor: zlib //開啟壓縮 indexConfig: prefixCompression: true //開啟索引 processManagement: //系統(tǒng)守護(hù)進(jìn)程控制處理 fork: true //后臺運行 pidFilePath: /data/mongodb_cluster/mongodb_27017/pid/mongod.pid //pid文件路徑 net: port: 27017 //監(jiān)聽端口 bindIp: 127.0.0.1,192.168.81.210 //綁定ip

      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

      2.5.編寫MongoDB配置文件

      [root@mongodb-1 ~]# cd /data/mongodb_cluster/mongodb_27017/ [root@mongodb-1 /data/mongodb_cluster/mongodb_27017]# vim conf/mongodb.yml systemLog: destination: file logAppend: true path: /data/mongodb_cluster/mongodb_27017/logs/mongodb.log storage: journal: enabled: true dbPath: /data/mongodb_cluster/mongodb_27017/data directoryPerDB: true wiredTiger: engineConfig: cacheSizeGB: 1 directoryForIndexes: true collectionConfig: blockCompressor: zlib indexConfig: prefixCompression: true processManagement: fork: true pidFilePath: /data/mongodb_cluster/mongodb_27017/pid/mongod.pid net: port: 27017 bindIp: 127.0.0.1,192.168.81.210

      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

      2.6.啟動MongoDB

      1.啟動MongoDB [root@mongodb-1 ~]# cd /data/mongodb_cluster [root@mongodb-1 /data/mongodb_cluster]# ./mongodb/bin/mongod -f mongodb_27017/conf/mongodb.yml about to fork child process, waiting until server is ready for connections. forked process: 73550 child process started successfully, parent exiting 2.查看進(jìn)程和端口 [root@mongodb-1 /data/mongodb_cluster]# ps aux | grep mongo [root@mongodb-1 /data/mongodb_cluster]# netstat -lnpt | grep mongo

      1

      2

      3

      4

      5

      6

      7

      8

      9

      10

      2.7.如何關(guān)閉MongoDB

      直接用啟動命令后面加一個–shutdown即可關(guān)閉MongoDB

      兩種方式關(guān)閉MongoDB

      1.命令行關(guān)閉MongoDB [root@mongodb-1 ~]# cd /data/mongodb_cluster [root@mongodb-1 /data/mongodb_cluster]# ./mongodb/bin/mongod -f mongodb_27017/conf/mongodb.yml --shutdown killing process with pid: 73550 2.交互式關(guān)閉MongoDB [mongo@mongodb-1 ~]$mongo > use admin switched to db admin > db.shutdownServer() 查看進(jìn)程和端口 [root@mongodb-1 /data/mongodb_cluster]# ps aux | grep mongo [root@mongodb-1 /data/mongodb_cluster]# netstat -lnpt | grep mongo

      1

      2

      3

      4

      5

      6

      7

      8

      9

      10

      11

      12

      13

      14

      2.8.登錄MongoDB

      登錄MongoDB需要使用mongo命令

      1.啟動MongoDB [root@mongodb-1 ~]# cd /data/mongodb_cluster [root@mongodb-1 /data/mongodb_cluster]# ./mongodb/bin/mongod -f mongodb_27017/conf/mongodb.yml 2.登錄MongoDB [root@mongodb-1 /data/mongodb_cluster]# ./mongodb/bin/mongo

      1

      2

      3

      4

      5

      6

      登錄后會有一些警告信息,我們再3里面進(jìn)行優(yōu)化

      3.優(yōu)化MongoDB警告信息

      3.1.優(yōu)化啟動用戶警告

      警告內(nèi)容:2021-02-13T10:44:47.832+0800 I CONTROL [initandlisten] ** WARNING: You are running this process as the root user, which is not recommended.

      這個警告內(nèi)容就提示我們盡量不要用root直接啟動,我們需要用普通用戶啟動

      思路:創(chuàng)建一個普通用戶,將MongoDB的部署目錄賦權(quán)給普通用戶,用普通用戶啟動即可

      1.關(guān)閉MongoDB [root@mongodb-1 /data/mongodb_cluster]# ./mongodb/bin/mongod -f mongodb_27017/conf/mongodb.yml --shutdown 2.創(chuàng)建用戶 [root@mongodb-1 ~]# useradd mongo [root@mongodb-1 ~]# echo "123456" | passwd --stdin mongo 3.賦權(quán) [root@mongodb-1 ~]# chown -R mongo.mongo /data/mongodb_cluster/ 4.登陸普通用戶并配置環(huán)境變量 [root@mongodb-1 ~]# su - mongo [mongo@mongodb-1 ~]$ vim .bashrc export PATH=/data/mongodb_cluster/mongodb/bin/:$PATH [mongo@mongodb-1 ~]$ source .bashrc 5.啟動MongoDB [mongo@mongodb-1 ~]$ mongod -f /data/mongodb_cluster/mongodb_27017/conf/mongodb.yml about to fork child process, waiting until server is ready for connections. forked process: 73835 child process started successfully, parent exiting 6.登陸MongoDB [mongo@mongodb-1 ~]$ mongo

      1

      2

      3

      4

      5

      6

      7

      8

      9

      10

      11

      12

      13

      14

      15

      16

      MongoDB數(shù)據(jù)庫安裝部署及警告優(yōu)化

      17

      18

      19

      20

      21

      22

      23

      24

      25

      可以到啟動用戶的警告信息已經(jīng)消失

      3.2.優(yōu)化大內(nèi)存頁警告

      告警內(nèi)容:** WARNING: /sys/kernel/mm/transparent_hugepage/enabled is 'always'.

      ** We suggest setting it to 'never'

      ** WARNING: /sys/kernel/mm/transparent_hugepage/defrag is 'always'.

      ** We suggest setting it to 'never'

      這是由于大內(nèi)存設(shè)置了always,MongoDB建議使用never

      官方文檔:https://docs.mongodb.com/manual/tutorial/transparent-huge-pages/

      1.準(zhǔn)備init腳本 [root@mongodb-1 ~]# vim /etc/init.d/disable-transparent-hugepages #!/bin/bash ### BEGIN INIT INFO # Provides: disable-transparent-hugepages # Required-Start: $local_fs # Required-Stop: # X-Start-Before: mongod mongodb-mms-automation-agent # Default-Start: 2 3 4 5 # Default-Stop: 0 1 6 # Short-Description: Disable Linux transparent huge pages # Description: Disable Linux transparent huge pages, to improve # database performance. ### END INIT INFO case $1 in start) if [ -d /sys/kernel/mm/transparent_hugepage ]; then thp_path=/sys/kernel/mm/transparent_hugepage elif [ -d /sys/kernel/mm/redhat_transparent_hugepage ]; then thp_path=/sys/kernel/mm/redhat_transparent_hugepage else return 0 fi echo 'never' | tee ${thp_path}/enabled > /dev/null unset thp_path ;; esac 2.賦權(quán)并添加為開機(jī)自啟 [root@mongodb-1 ~]# chmod 755 /etc/init.d/disable-transparent-hugepages [root@mongodb-1 ~]# chkconfig --add disable-transparent-hugepages [root@mongodb-1 ~]# chkconfig --list | grep disa

      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

      3.重啟MongoDB [mongo@mongodb-1 ~]$ mongod -f /data/mongodb_cluster/mongodb_27017/conf/mongodb.yml --shutdown [mongo@mongodb-1 ~]$ mongod -f /data/mongodb_cluster/mongodb_27017/conf/mongodb.yml 4.登陸mongdo查看警告 [mongo@mongodb-1 ~]$ mongo

      1

      2

      3

      4

      5

      6

      1.臨時關(guān)閉內(nèi)存頁 [root@mongodb-1 ~]# echo "never" > /sys/kernel/mm/transparent_hugepage/enabled [root@mongodb-1 ~]# echo "never" > /sys/kernel/mm/transparent_hugepage/defrag [root@mongodb-1 ~]# cat /sys/kernel/mm/transparent_hugepage/enabled always madvise [never] [root@mongodb-1 ~]# cat /sys/kernel/mm/transparent_hugepage/defrag always madvise [never] 2.重啟MongoDB [root@mongodb-1 ~]# su - mongo [mongo@mongodb-1 ~]$ mongod -f /data/mongodb_cluster/mongodb_27017/conf/mongodb.yml --shutdown [mongo@mongodb-1 ~]$ mongod -f /data/mongodb_cluster/mongodb_27017/conf/mongodb.yml 3.登陸MongoDB查看告警 [mongo@mongodb-1 ~]$ mongo

      1

      2

      3

      4

      5

      6

      7

      8

      9

      10

      11

      12

      13

      14

      15

      可以看到大內(nèi)存頁警告已經(jīng)接解決

      3.3.優(yōu)化limit警告

      告警內(nèi)容:** WARNING: soft rlimits too low. rlimits set to 15324 processes, 65535 files. Number of processes should be at least 32767.5: 0.5 times number of files.

      提示的是limt設(shè)置的打開文件數(shù)太低

      1.調(diào)整limit(此方法是不重啟機(jī)器的情況下生效) cat > /etc/profile<

      1

      2

      3

      4

      5

      6

      7

      8

      9

      10

      11

      12

      13

      14

      15

      16

      17

      18

      MongoDB 數(shù)據(jù)庫

      版權(quán)聲明:本文內(nèi)容由網(wǎng)絡(luò)用戶投稿,版權(quán)歸原作者所有,本站不擁有其著作權(quán),亦不承擔(dān)相應(yīng)法律責(zé)任。如果您發(fā)現(xiàn)本站中有涉嫌抄襲或描述失實的內(nèi)容,請聯(lián)系我們jiasou666@gmail.com 處理,核實后本網(wǎng)站將在24小時內(nèi)刪除侵權(quán)內(nèi)容。

      上一篇:關(guān)于前端的碎碎念2-CSS裝修之display
      下一篇:java注解核心知識總結(jié)
      相關(guān)文章
      亚洲精品高清一二区久久| 亚洲福利电影在线观看| 亚洲精品二三区伊人久久| 亚洲国产成人精品不卡青青草原| 中文字幕久久亚洲一区 | 亚洲精品福利视频| 亚洲精品乱码久久久久久久久久久久 | 亚洲AV无码成人精品区大在线| 一本色道久久88—综合亚洲精品| 亚洲一区中文字幕在线观看| 亚洲剧情在线观看| 亚洲av永久无码精品三区在线4| 亚洲性一级理论片在线观看| 亚洲精品视频专区| 亚洲日韩乱码久久久久久| 亚洲成aⅴ人在线观看| 亚洲区视频在线观看| 亚洲人成电影网站久久| 亚洲午夜精品一区二区麻豆| 亚洲国产精品久久久久秋霞小 | 亚洲男人的天堂久久精品| 色偷偷亚洲女人天堂观看欧| 香蕉大伊亚洲人在线观看| 亚洲午夜无码久久久久小说| 亚洲第一第二第三第四第五第六| 理论亚洲区美一区二区三区| 亚洲第一页综合图片自拍| 久久亚洲国产成人影院网站 | 亚洲天堂一区二区三区四区| 亚洲欧洲中文日产| 国产午夜亚洲精品国产| 精品亚洲视频在线| 久久久久无码专区亚洲av| 亚洲成A∨人片在线观看不卡| 亚洲成a人片77777老司机| 亚洲综合图片小说区热久久| 亚洲一区二区三区在线观看蜜桃| 亚洲最大中文字幕无码网站| WWW亚洲色大成网络.COM| 一本久久综合亚洲鲁鲁五月天| 中文字幕亚洲乱码熟女一区二区|