Подтвердить что ты не робот

Докер не может ссылаться на не запущенный контейнер

Мне нужно создать рельсы и контейнеры mysql с компоновкой docker. Когда я пытаюсь создать ссылки между контейнерами с docker-compose up, я получаю

Не удается запустить контейнер 9b271c58cf6aecaf017dadaf5b Нельзя ссылаться на непереработанный контейнер: /puma _db_1 AS/puma_web_1/db

Файлы

Dockerfile

FROM ubuntu:14.04

RUN apt-get -y update
RUN apt-get -y install git curl zlib1g-dev build-essential libssl-dev libreadline-dev libyaml-dev libsqlite3-dev sqlite3 libxml2-dev libxslt1-dev libcurl4-openssl-dev python-software-properties libffi-dev

RUN apt-get -y install libmysqlclient-dev
RUN git clone https://github.com/sstephenson/rbenv.git /root/.rbenv
RUN git clone https://github.com/sstephenson/ruby-build.git /root/.rbenv/plugins/ruby-build
RUN echo 'eval "$(rbenv init -)"' >> $HOME/.profile
RUN echo 'eval "$(rbenv init -)"' >> $HOME/.bashrc

RUN rbenv install 2.1.5
RUN rbenv global 2.1.5
RUN gem install rails -v 4.0.11

ADD app.tar.gz /home/
WORKDIR /home/app

RUN bundle install
EXPOSE 3000
CMD ["rails", "server", "-b", "0.0.0.0"]

Докер-compose.yml

db:  
  image: mysql:latest
  environment:
    MYSQL_DATABASE: app_development
    MYSQL_USER: mysql
    DATABASE_PASSWORD: onetwo
    ROOT_PASSWORD: onetwo
web:
  build: .
  command: bundle exec rails s -p 3000 -b '0.0.0.0'
  ports:
    - "4000:3000"
  links:
    - db
4b9b3361

Ответ 1

Скорее всего, контейнер db не запускается.

Убедитесь, что он работает нормально, запустив только службу db. Вы можете сделать это с помощью следующей команды:

docker-compose up db

Если он появляется, то служба MySQL не запускается после этой команды, тогда вы нашли причину своей проблемы.

Ответ 2

Не определенно связано с MySQL, но больше сообщение ERROR: for <service> Cannot link to a non running container: /b2f21b869ccc_<dependency>_1 AS /<service>_1/<dependency>_1

Я обнаружил, что контейнер зависимостей имел другой идентификатор, чем тот, который указан (b2f21b869ccc в моем примере выше)

Решено просто запустить docker-compose up -d --force-recreate <service>

который заставил его воссоздать зависимость и исправить ссылку на правильный идентификатор докеры

Ответ 3

Для меня это не помогло запустить docker-compose db.

Это сделало трюк для меня:

sudo service docker restart

а затем продолжить с помощью docker-compose up (-d)

Ответ 4

Вы можете попробовать новые функции сетевой сети докеры. Чтобы сделать это, вы должны удалить параметр ссылки в файле docker-compose.yml и инициализировать контейнер с помощью --x-networking option.

docker-compose --x-networking up -d

Чтобы докеры не генерировали случайные имена для контейнеров, которые добавляются в файл /etc/hosts соответствующей сети для каждого контейнера, вы можете использовать container_name: в файле docker-compose.yml

db:  
  container_name: db
  image: mysql:latest
  environment:
    MYSQL_DATABASE: app_development
    MYSQL_USER: mysql
    DATABASE_PASSWORD: onetwo
    ROOT_PASSWORD: onetwo
web:
  container_name: web
  build: .
  command: bundle exec rails s -p 3000 -b '0.0.0.0'
  ports:
    - "4000:3000"

Ответ 5

Вопрос:

  • Я получил эту ошибку всякий раз, когда docker-compose успешно строит набор Images, но один из тех Images не может (например, запуск в свой собственный Container).

  • В этом случае я подозреваю, что Image, лежащий в основе вашего puma_db_1 Container не работает run. Ты можешь найдите имя этого Image, запустив docker ps -a. Тем не менее, его имя, скорее всего, puma_db

Решение:

  • Чтобы понять причину, вы можете попробовать docker-compose up <service_name> или docker-compose up db

  • В качестве альтернативы я нахожу сообщение об ошибке, запустив docker run <image_name> более полезным. В этом случае это будет docker run puma_db

Ответ 6

У меня была та же проблема для mssql.link, поскольку я не использую локальную базу данных (скорее, используя ту, что у нас есть на этапе), все, что мне нужно было сделать, это просто комментарий, выходящий за рамки редактирования Dockerfile script:

# DOCKER_ARGS="${DOCKER_ARGS} --link mssql-server-linux:mssql.link"

Это решение может помочь кому-то или может быть никем, но оно отсортировало его для меня:)