wget -c https://fastdl.mongodb.org/linux/mongodb-linux-x86_64-rhel70-3.4.4.tgz
下載相對應的測試機爲7.0系統所以使用7的
7|6 安裝以及配置沒有區別linux
二進制的軟件包,解壓即用mongodb
安裝前配置shell
hugepage_transport禁用該項。 echo ''' if test -f /sys/kernel/mm/transparent_hugepage/enabled; then echo never > /sys/kernel/mm/transparent_hugepage/enabled fi if test -f /sys/kernel/mm/transparent_hugepage/defrag; then echo never > /sys/kernel/mm/transparent_hugepage/defrag fi ''' >>/etc/rc.local echo 0 > /proc/sys/vm/zone_reclaim_mode
mongo-config數據庫
systemLog: destination: file path: "/data/logs/mongo-config.log" logAppend: true storage: dbPath: "/data/mongodb/data/mongo-config" journal: enabled: true syncPeriodSecs: 60 engine: wiredTiger wiredTiger: engineConfig: cacheSizeGB: 1 statisticsLogDelaySecs: 0 journalCompressor: snappy collectionConfig: blockCompressor: snappy indexConfig: prefixCompression: true operationProfiling: slowOpThresholdMs: 200 mode: slowOp #security: ##keyFile: /data/mongodb/config/data/keyfile #authorization: enabled processManagement: fork: true pidFilePath: "/home/service/mongodb-3.4.4/mongo-config.pid" net: bindIp: 192.168.233.138,127.0.0.1 port: 30000 replication: replSetName: configRS sharding: clusterRole: configsvr #啓動 #!/bin/bash MONGODB_HOME=/home/service/mongodb-3.4.4 numactl --interleave=all ${MONGODB_HOME}/bin/mongod -f /home/service/mongodb-3.4.4/conf/mongo-config.conf
mongosbash
systemLog: destination: file path: /data/logs/mongos.log logAppend: true processManagement: fork: true pidFilePath: /home/service/mongodb-3.4.4/mongos.pid net: port: 30001 bindIp: 192.168.233.139,127.0.0.1 sharding: configDB: configRS/192.168.233.139:30000,192.168.233.138:30000,192.168.233.135:30000
shard0 (shard1|2同0 僅需更改目錄端口便可,其餘兩臺機器配置同這個 改ip便可)app
systemLog: destination: file path: /data/logs/mongo_logs/shard0.log logAppend: true storage: journal: enabled: true dbPath: /data/mongo_data/shard0 directoryPerDB: true engine: wiredTiger wiredTiger: engineConfig: cacheSizeGB: 10 statisticsLogDelaySecs: 0 journalCompressor: snappy directoryForIndexes: true collectionConfig: blockCompressor: snappy indexConfig: prefixCompression: true net: port: 27017 bindIp: 192.168.233.135,127.0.0.1 replication: oplogSizeMB: 1024 replSetName: "shard0" secondaryIndexPrefetch: "all" #security: #keyFile: /data/mongo_data/keyfile #clusterAuthMode: "keyFile" #authorization: enabled sharding: clusterRole: shardsvr processManagement: fork: true pidFilePath: "/home/service/mongodb-3.2.8/shard0.pid" operationProfiling: slowOpThresholdMs: 10 mode: "slowOp"
啓動config(所有啓動)ide
#!/bin/bash MONGODB_HOME=/home/service/mongodb-3.4.4 numactl --interleave=all ${MONGODB_HOME}/bin/mongod -f /home/service/mongodb-3.4.4/conf/mongo-config.conf
啓動shard012測試
#!/bin/bash MONGODB_HOME=/home/service/mongodb-3.4.4 numactl --interleave=all ${MONGODB_HOME}/bin/mongod -f /home/service/mongodb-3.4.4/conf/shard0.conf
任何一臺便可fetch
mongo --port 30000 # /home/service/mongodb-3.4.4/bin/mongo --port 30000 MongoDB shell version v3.4.4 connecting to: mongodb://127.0.0.1:30000/ MongoDB server version: 3.4.4 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 Server has startup warnings: 2017-05-22T16:55:21.147+0800 I CONTROL [initandlisten] 2017-05-22T16:55:21.147+0800 I CONTROL [initandlisten] ** WARNING: Access control is not enabled for the database. 2017-05-22T16:55:21.147+0800 I CONTROL [initandlisten] ** Read and write access to data and configuration is unrestricted. 2017-05-22T16:55:21.147+0800 I CONTROL [initandlisten] ** WARNING: You are running this process as the root user, which is not recommended. 2017-05-22T16:55:21.147+0800 I CONTROL [initandlisten] 2017-05-22T16:55:21.148+0800 I CONTROL [initandlisten] 2017-05-22T16:55:21.148+0800 I CONTROL [initandlisten] ** WARNING: /sys/kernel/mm/transparent_hugepage/enabled is 'always'. 2017-05-22T16:55:21.148+0800 I CONTROL [initandlisten] ** We suggest setting it to 'never' 2017-05-22T16:55:21.148+0800 I CONTROL [initandlisten] 2017-05-22T16:55:21.148+0800 I CONTROL [initandlisten] ** WARNING: /sys/kernel/mm/transparent_hugepage/defrag is 'always'. 2017-05-22T16:55:21.148+0800 I CONTROL [initandlisten] ** We suggest setting it to 'never' 2017-05-22T16:55:21.148+0800 I CONTROL [initandlisten] > rs.initiate({_id:"configRS0", configsvr: true, members:[ { _id:0,host:"192.168.233.135:30000"}, { _id:1,host:"192.168.233.138:30000"}, { _id:2,host:"192.168.233.139:30000"} ] }); { "ok" : 1 }
# /home/service/mongodb-3.4.4/bin/mongo --port 27017 MongoDB shell version v3.4.4 connecting to: mongodb://127.0.0.1:27017/ MongoDB server version: 3.4.4 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 Server has startup warnings: 2017-05-22T18:22:56.293+0800 I CONTROL [initandlisten] 2017-05-22T18:22:56.294+0800 I CONTROL [initandlisten] ** WARNING: Access control is not enabled for the database. 2017-05-22T18:22:56.294+0800 I CONTROL [initandlisten] ** Read and write access to data and configuration is unrestricted. 2017-05-22T18:22:56.294+0800 I CONTROL [initandlisten] ** WARNING: You are running this process as the root user, which is not recommended. 2017-05-22T18:22:56.294+0800 I CONTROL [initandlisten] 2017-05-22T18:22:56.294+0800 I CONTROL [initandlisten] 2017-05-22T18:22:56.294+0800 I CONTROL [initandlisten] ** WARNING: /sys/kernel/mm/transparent_hugepage/enabled is 'always'. 2017-05-22T18:22:56.294+0800 I CONTROL [initandlisten] ** We suggest setting it to 'never' 2017-05-22T18:22:56.294+0800 I CONTROL [initandlisten] 2017-05-22T18:22:56.294+0800 I CONTROL [initandlisten] ** WARNING: /sys/kernel/mm/transparent_hugepage/defrag is 'always'. 2017-05-22T18:22:56.294+0800 I CONTROL [initandlisten] ** We suggest setting it to 'never' 2017-05-22T18:22:56.294+0800 I CONTROL [initandlisten] > use admin; switched to db admin >config = {_id:"shard0",members:[{_id:0,host:"192.168.233.135:27017",priority:1},{_id:1,host:"192.168.233.139:27017",priority:3},{_id:2,host:"192.168.233.138:27017",arbiterOnly:true}]} { "_id" : "shard0", "members" : [ { "_id" : 0, "host" : "192.168.233.135:27017", "priority" : 1 }, { "_id" : 1, "host" : "192.168.233.139:27017", "priority" : 3 }, { "_id" : 2, "host" : "192.168.233.138:27017", "arbiterOnly" : true } ] } > rs.initiate(config); { "ok" : 1 } 修改priority: shard0:PRIMARY> cfg = rs.config(); { "_id" : "shard0", "version" : 1, "protocolVersion" : NumberLong(1), "members" : [ { "_id" : 0, "host" : "192.168.233.135:27017", "arbiterOnly" : false, "buildIndexes" : true, "hidden" : false, "priority" : 1, "tags" : { }, "slaveDelay" : NumberLong(0), "votes" : 1 }, { "_id" : 1, "host" : "192.168.233.139:27017", "arbiterOnly" : false, "buildIndexes" : true, "hidden" : false, "priority" : 3, "tags" : { }, "slaveDelay" : NumberLong(0), "votes" : 1 }, { "_id" : 2, "host" : "192.168.233.138:27017", "arbiterOnly" : true, "buildIndexes" : true, "hidden" : false, "priority" : 1, "tags" : { }, "slaveDelay" : NumberLong(0), "votes" : 1 } ], "settings" : { "chainingAllowed" : true, "heartbeatIntervalMillis" : 2000, "heartbeatTimeoutSecs" : 10, "electionTimeoutMillis" : 10000, "catchUpTimeoutMillis" : 2000, "getLastErrorModes" : { }, "getLastErrorDefaults" : { "w" : 1, "wtimeout" : 0 }, "replicaSetId" : ObjectId("5922bdcd0ef1a7889bb9056f") } } shard0:PRIMARY> cfg.members[0].priority = 99; 99 shard0:PRIMARY> rs.reconfig(cfg) { "ok" : 1 } 修改完成 135:27017 成爲新的主節點,
副本集shard1,2同0初始化方法同樣,這裏不在演示。(注意priority值越大就越優先成爲主節點)ui
任意一臺登錄mongos 30001端口
# /home/service/mongodb-3.4.4/bin/mongo --port 30001 MongoDB shell version v3.4.4 connecting to: mongodb://127.0.0.1:30001/ MongoDB server version: 3.4.4 Server has startup warnings: 2017-05-22T19:16:52.825+0800 I CONTROL [main] 2017-05-22T19:16:52.825+0800 I CONTROL [main] ** WARNING: Access control is not enabled for the database. 2017-05-22T19:16:52.825+0800 I CONTROL [main] ** Read and write access to data and configuration is unrestricted. 2017-05-22T19:16:52.825+0800 I CONTROL [main] ** WARNING: You are running this process as the root user, which is not recommended. 2017-05-22T19:16:52.825+0800 I CONTROL [main] mongos> db.runCommand({"addShard":"shard2/192.168.233.135:29017,192.168.233.138:29017,192.168.233.139:29017"}); { "shardAdded" : "shard2", "ok" : 1 } mongos> db.runCommand({"addShard":"shard1/192.168.233.135:28017,192.168.233.138:28017,192.168.233.138:29017"}); { "shardAdded" : "shard1", "ok" : 1 } mongos> db.runCommand({"addShard":"shard0/192.168.233.135:27017,192.168.233.138:27017,192.168.233.139:27017"}); { "shardAdded" : "shard0", "ok" : 1 } #分片添加完成
mongos> use admin switched to db admin mongos> db.runCommand({enablesharding :"test"}); { "ok" : 1 } mongos> sh.shardCollection("test.Log", { id: 1}); { "collectionsharded" : "test.Log", "ok" : 1 }
mongo用–auth選項開啓認證,可是在開啓認證以前必須有一個有userAdminAnyDatabase角色的管理員帳戶。
所以首先咱們要建立一個帳戶,而後修改配置文件加上auth選項,重啓mongo。
建立用戶
mongos> use admin; switched to db admin mongos> db.createUser({ ... user: "admin", ... pwd: "admin", ... roles: [{role:"root",db:"admin"}] ... }); Successfully added user: { "user" : "admin", "roles" : [ { "role" : "root", "db" : "admin" } ] }
關閉三臺機器上的mongod和configsvr以及mongos服務
將配置文件註釋的key選項打開
security: keyFile: /data/mongodb/config/data/keyfile authorization: enabled
生成keyfile
openssl rand -base64 753 >keyfile
chmod 600 keyfile
注意權限600
將keyfile 複製到各自的目錄 (全部機器用一個key)
configsrv mongos shard0 shard1 shard2
啓動腳本
#!/bin/sh # #chkconfig: 2345 80 90 #description: mongodb MONGODB_HOME=/home/service/mongodb-3.4.4 start() { numactl --interleave=all ${MONGODB_HOME}/bin/mongod -f ${MONGODB_HOME}/conf/configsvr.conf } stop() { numactl --interleave=all ${MONGODB_HOME}/bin/mongod -f ${MONGODB_HOME}/conf/configsvr.conf --shutdown } case "$1" in start) start ;; stop) stop ;; restart) stop start ;; *) echo $"Usage: $0 {start|stop|restart}" exit 1 esac