2017-06-28 52 views
0

我正在關注如何在本地機器上分割MongoDB數據庫的Youtube tutorial。本教程適用於Mongo 2.2,我在Mongo 3.4上。所以我使用下面的bash腳本來啓動分片,並且配置服務器和分片開始正常,但是我的mongos進程無法連接,沒有打印錯誤。我知道自從Mongo 3.2以來,有一件事情發生了變化,那就是您必須包含副本集連接字符串,我認爲這樣做,但顯然它不起作用。MongoDB分片沒有響應

#!/bin/bash 

# Create the directories that the shards will run in 
# We will have 4 shards, with a replication factor of 3 
mkdir a0 a1 a2 
mkdir b0 b1 b2 
mkdir c0 c1 c2 
mkdir d0 d1 d2 

# Create the three configuration server folders 
mkdir cfg0 cfg1 cfg2 

# Common variables 
replSet="configReplSet" 
hostname="127.0.0.1" 

# Configure the config servers 
mongod --configsvr --replSet ${replSet} --dbpath cfg0 --port 26050 --fork --logpath log.cfg0 --logappend 
mongod --configsvr --replSet ${replSet} --dbpath cfg1 --port 26051 --fork --logpath log.cfg1 --logappend 
mongod --configsvr --replSet ${replSet} --dbpath cfg2 --port 26052 --fork --logpath log.cfg2 --logappend 

# Set up shard servers 
mongod --shardsvr --replSet a --dbpath a0 --logpath log.a0 --port 27000 --fork --logappend --oplogSize 50 
mongod --shardsvr --replSet a --dbpath a1 --logpath log.a1 --port 27001 --fork --logappend --oplogSize 50 
mongod --shardsvr --replSet a --dbpath a2 --logpath log.a2 --port 27002 --fork --logappend --oplogSize 50 

mongod --shardsvr --replSet b --dbpath b0 --logpath log.b0 --port 27100 --fork --logappend --oplogSize 50 
mongod --shardsvr --replSet b --dbpath b1 --logpath log.b1 --port 27101 --fork --logappend --oplogSize 50 
mongod --shardsvr --replSet b --dbpath b2 --logpath log.b2 --port 27102 --fork --logappend --oplogSize 50 

mongod --shardsvr --replSet c --dbpath c0 --logpath log.c0 --port 27200 --fork --logappend --oplogSize 50 
mongod --shardsvr --replSet c --dbpath c1 --logpath log.c1 --port 27201 --fork --logappend --oplogSize 50 
mongod --shardsvr --replSet c --dbpath c2 --logpath log.c2 --port 27202 --fork --logappend --oplogSize 50 

mongod --shardsvr --replSet d --dbpath d0 --logpath log.d0 --port 27300 --fork --logappend --oplogSize 50 
mongod --shardsvr --replSet d --dbpath d1 --logpath log.d1 --port 27301 --fork --logappend --oplogSize 50 
mongod --shardsvr --replSet d --dbpath d2 --logpath log.d2 --port 27302 --fork --logappend --oplogSize 50 

mongos --configdb ${replSet}/${hostname}:26050,${hostname}:26051,${hostname}:26052 --fork --logappend --logpath log.mongos0 --port 27017 
mongos --configdb ${replSet}/${hostname}:26050,${hostname}:26051,${hostname}:26052 --fork --logappend --logpath log.mongos1 --port 26061 
mongos --configdb ${replSet}/${hostname}:26050,${hostname}:26051,${hostname}:26052 --fork --logappend --logpath log.mongos2 --port 26062 
mongos --configdb ${replSet}/${hostname}:26050,${hostname}:26051,${hostname}:26052 --fork --logappend --logpath log.mongos3 --port 26063 

它在第一個mongos命令後停止運行。在log.mongo0我有以下錯誤重複一堆

.841-0400 W NETWORK [mongosMain] Failed to connect to 127.0.0.1:26050, in(checking socket for error after poll), reason: Connection refused 
2017-06-28T15:38:01.841-0400 W NETWORK [mongosMain] Failed to connect to 127.0.0.1:26051, in(checking socket for error after poll), reason: Connection refused 
2017-06-28T15:38:01.841-0400 W NETWORK [mongosMain] No primary detected for set configReplSet 

任何幫助表示讚賞。謝謝

+0

是端口26050和26051,當您運行「netstat的-l」或「SS實際打開 - L「? –

+0

我只是修復了代碼中的錯字 - 我在mkdir命令之間添加了逗號。之後,它現在說有類型STREAM在路徑/tmp/mongodb-26050.sock(及所有其他)上偵聽 – MANA624

+0

在本地地址下有0.0.0.0,然後是26050和26051,監聽 – MANA624

回答

0

所以,事實證明,它必須與錯誤No primary detected for set configReplSet。我加了以下幾行創建配置服務器後:

mongo --port 26050 --eval "printjson(rs.initiate())" 
mongo --port 26050 --eval "printjson(rs.status())" 

從那裏我可以開始創建碎片