
私はしばらくの間、mongo のバインド IP に苦労してきましたが、今こそ助けを求める時だと思います。私はホストオンリー ネットワークを使用しています192.168.56.0/24
。ボックスは 4 つあります。3 つは mongo 用192.168.56.111,192.168.56.112,192.168.56.113
、1 つはアプリ用です192.168.56.114
。
したがって、mongo のバインド パラメータは次のようになります。bind_ip =127.0.0.1,192.168.56.114,192.168.56.113,192.168.56.112,192.168.56.111,10.0.2.1
2015-08-22T12:35:44.547+0000 E NETWORK [initandlisten] listen(): bind() failed errno:99 Cannot assign requested address for socket: 192.168.56.114:27017
2015-08-22T12:35:44.553+0000 I JOURNAL [initandlisten] journal dir=/var/lib/mongodb/journal
2015-08-22T12:35:44.554+0000 I JOURNAL [initandlisten] recover : no journal files present, no recovery needed
2015-08-22T12:35:44.623+0000 I JOURNAL [durability] Durability thread started
2015-08-22T12:35:44.624+0000 I JOURNAL [journal writer] Journal writer thread started
2015-08-22T12:35:44.624+0000 I CONTROL [initandlisten] MongoDB starting : pid=3519 port=27017 dbpath=/var/lib/mongodb 64-bit host=vagrant-ubuntu-trusty-64
2015-08-22T12:35:44.625+0000 I CONTROL [initandlisten] db version v3.0.5
2015-08-22T12:35:44.625+0000 I CONTROL [initandlisten] git version: 8bc4ae20708dbb493cb09338d9e7be6698e4a3a3
2015-08-22T12:35:44.625+0000 I CONTROL [initandlisten] build info: Linux ip-10-183-35-50 3.13.0-24-generic #46-Ubuntu SMP Thu Apr 10 19:11:08 UTC 2014 x86_64 BOOST_LIB_VERSION=1_49
2015-08-22T12:35:44.625+0000 I CONTROL [initandlisten] allocator: tcmalloc
2015-08-22T12:35:44.626+0000 I CONTROL [initandlisten] options: { config: "/etc/mongod.conf", net: { bindIp: "127.0.0.1,192.168.56.114,192.168.56.113,192.168.56.112,192.168.56.111,10.0.2.15", port: 27017 }, storage: { dbPath: "/var/lib/mongodb" }, systemLog: { destination: "file", logAppend: true, path: "/var/log/mongodb/mongod.log" } }
2015-08-22T12:35:44.631+0000 I CONTROL [initandlisten] now exiting
2015-08-22T12:35:44.631+0000 I NETWORK [initandlisten] shutdown: going to close listening sockets...
2015-08-22T12:35:44.632+0000 I NETWORK [initandlisten] removing socket file: /tmp/mongodb-27017.sock
2015-08-22T12:35:44.632+0000 I NETWORK [initandlisten] shutdown: going to flush diaglog...
2015-08-22T12:35:44.632+0000 I NETWORK [initandlisten] shutdown: going to close sockets...
2015-08-22T12:35:44.632+0000 I STORAGE [initandlisten] shutdown: waiting for fs preallocator...
2015-08-22T12:35:44.632+0000 I STORAGE [initandlisten] shutdown: final commit...
2015-08-22T12:35:44.635+0000 I JOURNAL [initandlisten] journalCleanup...
2015-08-22T12:35:44.635+0000 I JOURNAL [initandlisten] removeJournalFiles
2015-08-22T12:35:44.636+0000 I JOURNAL [initandlisten] Terminating durability thread ...
2015-08-22T12:35:44.735+0000 I JOURNAL [journal writer] Journal writer thread stopped
2015-08-22T12:35:44.736+0000 I JOURNAL [durability] Durability thread stopped
2015-08-22T12:35:44.736+0000 I STORAGE [initandlisten] shutdown: closing all files...
2015-08-22T12:35:44.736+0000 I STORAGE [initandlisten] closeAllFiles() finished
2015-08-22T12:35:44.737+0000 I STORAGE [initandlisten] shutdown: removing fs lock...
2015-08-22T12:35:44.737+0000 I CONTROL [initandlisten] dbexit: rc: 48
他の IP に問題があるとは思えません。ループバック、独自の IP、0.0.0.0/0 を除き、他のすべての IP では mongodb の起動に失敗します。
答え1
指令bind_ip
IPアドレスを指定するためのものである同じシステム上でMongoDBが接続を待機するない接続を受信する IP アドレス。
このオプションを設定すると、mongod または mongos プロセスがこのアドレスのアプリケーションにバインドして接続をリッスンするように構成されます。mongod または mongos インスタンスは任意のインターフェースに接続できますが、プロセスをパブリックにアクセス可能なインターフェースに接続する場合は、データベースの整合性を保護するために適切な認証またはファイアウォール制限を実装してください。
したがって、これは存在しない (推奨) か、ローカル接続のみを受け入れるために 127.0.0.1 を含めるか、またはローカル ネットワーク インターフェイスの IP アドレスを含める必要があります。
MongoDB に接続できる IP アドレスを制限する場合は、ファイアウォールを使用する必要があります。