第0部分 業(yè)務(wù)信息
成都創(chuàng)新互聯(lián)成都企業(yè)網(wǎng)站建設(shè)服務(wù),提供成都做網(wǎng)站、網(wǎng)站建設(shè)網(wǎng)站開發(fā),網(wǎng)站定制,建網(wǎng)站,網(wǎng)站搭建,網(wǎng)站設(shè)計(jì),成都響應(yīng)式網(wǎng)站建設(shè),網(wǎng)頁設(shè)計(jì)師打造企業(yè)風(fēng)格網(wǎng)站,提供周到的售前咨詢和貼心的售后服務(wù)。歡迎咨詢做網(wǎng)站需要多少錢:028-86922220業(yè)務(wù)名稱: xyz
端口號(hào): 28017
第1部分 準(zhǔn)備環(huán)境
創(chuàng)建mongodb用戶
# useradd mongodb
創(chuàng)建數(shù)據(jù)目錄
# mkdir -pv /data1/mongodb/28017/data
# chown -R mongodb.mongodb /data1/mongodb/28017/data/
創(chuàng)建配置, 日志文件目錄
# mkdir -pv /home/mongodb/mongodb/xyz/28017/{conf,logs,pid}
準(zhǔn)備配置文件
# cat /home/mongodb/mongodb/xyz/28017/conf/mongodb.conf
##General options
port = 28017
maxConns = 1024
logpath = /home/mongodb/mongodb/xyz/28017/logs/mongodb.log
logappend = false
logRotate = rename
timeStampFormat = iso8601-local
pidfilepath = /home/mongodb/mongodb/xyz/28017/pid/mongodb.pid
#keyFile = /home/mongodb/mongodb/xyz/28017/conf/mongodb.key
httpinterface = false
nounixsocket = true
fork = true
#auth = true
slowms = 100
profile = 1
##Replication options
oplogSize = 5120
##Replica set options
replSet = xyz
##Storage options
storageEngine = wiredTiger
dbpath = /data1/mongodb/28017/data/
directoryperdb = true
journal = true
##WiredTiger options
wiredTigerCacheSizeGB = 5
# chown -R mongodb.mongodb /home/mongodb/mongodb/xyz/28017/{conf,logs,pid}
第2部分 調(diào)整操作系統(tǒng)參數(shù)
切換到mongodb用戶.
# su - mongodb
啟動(dòng)mongodb進(jìn)程.
$ /usr/local/mongodb/bin/mongod --config /home/mongodb/mongodb/xyz/28017/conf/mongodb.conf
根據(jù)日志提示的WARNING, 調(diào)整操作系統(tǒng)參數(shù).
$ cat /home/mongodb/mongodb/xyz/28017/logs/mongodb.log
2018-11-07T17:03:40.974+0800 I CONTROL [initandlisten]
2018-11-07T17:03:40.975+0800 I CONTROL [initandlisten] ** WARNING: You are running on a NUMA machine.
2018-11-07T17:03:40.975+0800 I CONTROL [initandlisten] ** We suggest launching mongod like this to avoid performance problems:
2018-11-07T17:03:40.975+0800 I CONTROL [initandlisten] ** numactl --interleave=all mongod [other options]
2018-11-07T17:03:40.975+0800 I CONTROL [initandlisten]
2018-11-07T17:03:40.975+0800 I CONTROL [initandlisten] ** WARNING: /sys/kernel/mm/transparent_hugepage/enabled is 'always'.
2018-11-07T17:03:40.975+0800 I CONTROL [initandlisten] ** We suggest setting it to 'never'
2018-11-07T17:03:40.975+0800 I CONTROL [initandlisten]
2018-11-07T17:03:40.975+0800 I CONTROL [initandlisten] ** WARNING: /sys/kernel/mm/transparent_hugepage/defrag is 'always'.
2018-11-07T17:03:40.975+0800 I CONTROL [initandlisten] ** We suggest setting it to 'never'
2018-11-07T17:03:40.975+0800 I CONTROL [initandlisten]
2018-11-07T17:03:40.975+0800 I CONTROL [initandlisten] ** WARNING: soft rlimits too low. rlimits set to 32000 processes, 65535 files. Number of processes should be at least 32767.5 : 0.5 times number of files.
2018-11-07T17:03:40.975+0800 I CONTROL [initandlisten]
調(diào)整系統(tǒng)參數(shù)
# echo 'never' > /sys/kernel/mm/transparent_hugepage/enabled
# echo 'never' > /sys/kernel/mm/transparent_hugepage/defrag
# tail -n 4 /etc/security/limits.conf
mongodb soft nofile 64000
mongodb hard nofile 64000
mongodb soft nproc 64000
mongodb hard nproc 64000
關(guān)閉mongodb進(jìn)程.
$ /usr/local/mongodb/bin/mongo --port 28017 --host localhost
MongoDB shell version v3.4.3
connecting to: mongodb://localhost:28017/
MongoDB server version: 3.4.3
> use admin
switched to db admin
> db.shutdownServer()
server should be down...
再次啟動(dòng)mongodb進(jìn)程.
$ numactl --interleave=all /usr/local/mongodb/bin/mongod --config /home/mongodb/mongodb/xyz/28017/conf/mongodb.conf
第3部分 初始化副本集
保持開啟replSet, 關(guān)閉keyFile和auth參數(shù).
$ /usr/local/mongodb/bin/mongo --port 28017 --host localhost
> config = {_id: "xyz", members: [{_id: 0, host: "192.168.1.157:28017"}, {_id: 1, host: "192.168.1.158:28017"}, {_id: 2, host: "192.168.1.159:28017"}]}
{
"_id" : "xyz",
"members" : [
{
"_id" : 0,
"host" : "192.168.1.157:28017"
},
{
"_id" : 1,
"host" : "192.168.1.158:28017"
},
{
"_id" : 2,
"host" : "192.168.1.159:28017"
}
]
}
> rs.initiate(config)
{ "ok" : 1 }
創(chuàng)建管理用戶
xyz:PRIMARY> use admin
switched to db admin
xyz:PRIMARY> db.createUser({user: "root", pwd: "root_password", roles: [{role: "root", db: "admin"}]})
Successfully added user: {
"user" : "root",
"roles" : [
{
"role" : "root",
"db" : "admin"
}
]
}
關(guān)閉mongodb進(jìn)程, 準(zhǔn)備key文件.
$ echo 'L6rE59OEHWGeQAIIZHy3uXNj1cxu9lFuCJxZSejf' > /home/mongodb/mongodb/xyz/28017/conf/mongodb.key
$ chmod 600 /home/mongodb/mongodb/xyz/28017/conf/mongodb.key
開啟keyFile和auth參數(shù), 啟動(dòng)mongodb進(jìn)程, 登陸.
$ /usr/local/mongodb/bin/mongo --port 28017 --host localhost --username root --password root_password --authenticationDatabase admin
第4部分 部署業(yè)務(wù)
創(chuàng)建業(yè)務(wù)用戶
xyz:PRIMARY> use abc
switched to db abc
xyz:PRIMARY> db.createUser({user : "abc_user", pwd : "xyzabc", roles : [{role : "readWrite", db : "abc"}]})
Successfully added user: {
"user" : "abc_user",
"roles" : [
{
"role" : "readWrite",
"db" : "abc"
}
]
}
業(yè)務(wù)用戶abc_user登陸.
$ /usr/local/mongodb/bin/mongo --port 28017 --host localhost --username abc_user --password xyzabc --authenticationDatabase abc
xyz:PRIMARY> db
test
xyz:PRIMARY> use abc
switched to db abc
xyz:PRIMARY> db.tt.insert({"name" : "abc"})
WriteResult({ "nInserted" : 1 })
xyz:PRIMARY> show collections
tt
xyz:PRIMARY> db.tt.find()
{ "_id" : ObjectId("5be3ffb4832bb6db59e4e60f"), "name" : "abc" }
若感興趣可關(guān)注訂閱號(hào)”數(shù)據(jù)庫最佳實(shí)踐”(DBBestPractice).
另外有需要云服務(wù)器可以了解下創(chuàng)新互聯(lián)scvps.cn,海內(nèi)外云服務(wù)器15元起步,三天無理由+7*72小時(shí)售后在線,公司持有idc許可證,提供“云服務(wù)器、裸金屬服務(wù)器、高防服務(wù)器、香港服務(wù)器、美國服務(wù)器、虛擬主機(jī)、免備案服務(wù)器”等云主機(jī)租用服務(wù)以及企業(yè)上云的綜合解決方案,具有“安全穩(wěn)定、簡單易用、服務(wù)可用性高、性價(jià)比高”等特點(diǎn)與優(yōu)勢(shì),專為企業(yè)上云打造定制,能夠滿足用戶豐富、多元化的應(yīng)用場(chǎng)景需求。