Используя официальный mongo
изображение из концентратора докеров, я запускаю следующую команду, чтобы запустить его:
docker run --name api -p 127.0.0.1:27017:27017 -p 127.0.0.1:28017:28017 -d mongo
Затем из другой оболочки терминала я запускаю mongo
Однако я продолжаю получать следующую ошибку:
MongoDB shell version: 3.2.3
connecting to: test
2016-02-18T13:52:08.110-0700 I NETWORK [thread1] Socket recv() errno:104 Connection reset by peer 127.0.0.1:27017
2016-02-18T13:52:08.110-0700 I NETWORK [thread1] SocketException: remote: (NONE):0 error: 9001 socket exception [RECV_ERROR] server [127.0.0.1:27017]
2016-02-18T13:52:08.110-0700 E QUERY [thread1] Error: network error while attempting to run command 'isMaster' on host '127.0.0.1:27017' :
connect@src/mongo/shell/mongo.js:224:14
@(connect):1:6
exception: connect failed
Я проверил логи контейнера, и все оказалось правильно:
2016-02-18T20:51:20.538+0000 I CONTROL [initandlisten] MongoDB starting : pid=1 port=27017 dbpath=/data/db 64-bit host=73334e5089e1
2016-02-18T20:51:20.538+0000 I CONTROL [initandlisten] db version v3.2.3
2016-02-18T20:51:20.538+0000 I CONTROL [initandlisten] git version: b326ba837cf6f49d65c2f85e1b70f6f31ece7937
2016-02-18T20:51:20.538+0000 I CONTROL [initandlisten] OpenSSL version: OpenSSL 1.0.1e 11 Feb 2013
2016-02-18T20:51:20.538+0000 I CONTROL [initandlisten] allocator: tcmalloc
2016-02-18T20:51:20.538+0000 I CONTROL [initandlisten] modules: none
2016-02-18T20:51:20.538+0000 I CONTROL [initandlisten] build environment:
2016-02-18T20:51:20.538+0000 I CONTROL [initandlisten] distmod: debian71
2016-02-18T20:51:20.538+0000 I CONTROL [initandlisten] distarch: x86_64
2016-02-18T20:51:20.538+0000 I CONTROL [initandlisten] target_arch: x86_64
2016-02-18T20:51:20.538+0000 I CONTROL [initandlisten] options: {}
2016-02-18T20:51:20.542+0000 I STORAGE [initandlisten] wiredtiger_open config: create,cache_size=8G,session_max=20000,eviction=(threads_max=4),config_base=false,statistics=(fast),log=(enabled=true,archive=true,path=journal,compressor=snappy),file_manager=(close_idle_time=100000),checkpoint=(wait=60,log_size=2GB),statistics_log=(wait=0),
2016-02-18T20:51:20.615+0000 I CONTROL [initandlisten]
2016-02-18T20:51:20.615+0000 I CONTROL [initandlisten] ** WARNING: /sys/kernel/mm/transparent_hugepage/enabled is 'always'.
2016-02-18T20:51:20.615+0000 I CONTROL [initandlisten] ** We suggest setting it to 'never'
2016-02-18T20:51:20.615+0000 I CONTROL [initandlisten]
2016-02-18T20:51:20.615+0000 I CONTROL [initandlisten] ** WARNING: /sys/kernel/mm/transparent_hugepage/defrag is 'always'.
2016-02-18T20:51:20.615+0000 I CONTROL [initandlisten] ** We suggest setting it to 'never'
2016-02-18T20:51:20.615+0000 I CONTROL [initandlisten]
2016-02-18T20:51:20.616+0000 I FTDC [initandlisten] Initializing full-time diagnostic data capture with directory '/data/db/diagnostic.data'
2016-02-18T20:51:20.616+0000 I NETWORK [HostnameCanonicalizationWorker] Starting hostname canonicalization worker
2016-02-18T20:51:20.633+0000 I NETWORK [initandlisten] waiting for connections on port 27017
Что не так с докером или монго? Я везде искал ответ, и пока ничего не помогло. Докер или монго сломан?
Редактировать: Я провел еще небольшое расследование и обнаружил, что не могу получить доступ к Интернету изнутри контейнера. Я подключаюсь к нему, запустив docker exec -ti api /bin/bash
а затем попробуйте пинговать гугл или что-то в этом роде, и команда просто зависает.
Мне кажется, что я могу получить подключение к Интернету из контейнера во внешний мир только с помощью --net=host
в docker run
команда.
Вы должны указать контейнеру использовать собственный IP-адрес вместо localhost.
Например, предположим, что вы сгенерировали код скаффолда с expressjs
, ты должен написать в routes/index.js
var mongodb = require('mongodb');
router.get('/thelist', function(req, res){
// Get a Mongo client to work with the Mongo server
var MongoClient = mongodb.MongoClient;
// Define where the MongoDB server is
var url = 'mongodb://172.17.0.5:27017/dbname';
// Connect to the server
MongoClient.connect(url, function (err, db) {
.........
где 172.17.0.5
это $CONTAINER_IP
вы можете найти IP-адрес контейнера через
$ docker inspect $CONTAINER_NAME | grep IPAddress
Открыть с помощью sudo sudo vim /etc/NetworkManager/NetworkManager.conf
и закомментируйте строку dns=dnsmasq
, так что теперь у вас будет:
[main]
plugins=ifupdown,keyfile,ofono
#dns=dnsmasq
[ifupdown]
managed=false
Теперь вы можете использовать наименование услуги вместо IP-адреса контейнера, например:
// Define where the MongoDB server is
var url = 'mongodb://api:27017/dbname';
Проблема здесь - если контейнер слушает 127.0.0.1, тогда хост не может сопоставить ему порты.
Тебе нужно слушать 0.0.0.0
или подобное, а затем -p
может достичь интерфейса контейнера.
У меня была такая же проблема, но я нашел другой способ решить эту проблему. Вы можете просто передать сетевой параметр при запуске образа докера, и таким образом докер указывает на исправление localhost.
docker run --network="host" ....