도커 실행 중이 아닌 컨테이너에 연결할 수 없습니다.
도커 컴포지트로 Rails와 Mysql 컨테이너를 만들어야 합니다.컨테이너 간 링크를 작성하려고 하면docker-compose up
, 나는 이해하다
컨테이너 9b271c58cf6aecaf017dadaf5b를 시작할 수 없음 실행 중이 아닌 컨테이너에 연결할 수 없음: /puma_db_1 AS /puma_web_1/db
파일
도커 파일
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"]
docker-param.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
가장 가능성이 높은 것은db
컨테이너가 시작되지 않습니다.
정상적으로 동작하고 있는 것을 확인합니다.db
서비스.이 작업은 다음 명령을 사용하여 수행할 수 있습니다.
docker-compose up db
이 명령어 이후에 MySQL 서비스가 실행되지 않는 것으로 나타나면 문제의 원인을 찾은 것입니다.
MySQL과 특별히 관련된 것은 아니지만 더 많은 메시지ERROR: for <service> Cannot link to a non running container: /b2f21b869ccc_<dependency>_1 AS /<service>_1/<dependency>_1
종속 컨테이너의 ID가 지정된 것과 다르다는 것을 발견했습니다(b2f21b869ccc
위의 예에서는)
실행으로 간단하게 해결 docker-compose up -d --force-recreate <service>
이로 인해 의존관계가 다시 생성되어 링크가 올바른 도커 ID로 수정되었습니다.
도커 컴포지트업 db 실행에는 도움이 되지 않았습니다.
이게 날 속였어
sudo service docker restart
그 후 도커백업(-d)으로 계속 진행합니다.
도커 네트워킹의 신기능을 시험해 보겠습니다.이를 수행하려면 docker-compose.yml에서 link 파라미터를 삭제하고 컨테이너를 로 초기화해야 합니다.
docker-compose --x-networking up -d
도커가 컨테이너의 랜덤 이름을 생성하지 않도록 하려면 docker-compose.yml의 키를 사용하여 각 컨테이너에 대한 각 네트워크의 /etc/hosts 파일에 추가됩니다.
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"
문제:
이 에러는, 항상 발생하고 있습니다.
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
저도 같은 고민을 했어요mssql.link
로컬 데이터베이스를 사용하지 않기 때문에(스테이징에 있는 데이터베이스를 사용하는 것이 아니라) Dockerfile 스크립트를 편집하여 해당 줄에 코멘트만 하면 됩니다.
# DOCKER_ARGS="${DOCKER_ARGS} --link mssql-server-linux:mssql.link"
이 솔루션은 도움이 될 수도 있고 도움이 되지 않을 수도 있지만, 저를 위해 해결되었습니다.
을 걸었을 .lets say X
" " " 를 --link keen_visvesvaraya
후, 한번은X
만, 「」는 정지되어 있습니다.X
계속 뛰었습니다..docker exec
X
당신은 이 오류를 얻는다.
Yah 해결책을 다시 시작하는 것이다.
나는 elasticsearch-symfony-docker과 같은 문제가 있었다.
Can not link to a non-running container:/43c1d3b410db_myindex_elasticsearch_1 AS /myindex_apache_1/elasticsearch
이 솔루션은 데이터 양의 컨텐츠를 삭제하는 것이다.
elasticsearch: image: docker.elastic.co/elasticsearch/elasticsearch:5.5.2 Volumes: - ./docker/volume/elasticsearch: /usr/share/elasticsearch/data
를 실행합니다.docker-composer up -d
왜냐하면 그것은 날 위해 일하는 당신은 명령 아래 사용할 수 있다.
docker run --name standlone-mysql -e MYSQL_ROOT_PASSWORD=password -e MYSQL_DATABASE=test -e MYSQL_USER=root -e MYSQL_ROOT_PASSWORD=root -d mysql:5.6
당신은 환경 섹션에서"POSTGRES_HOST_AUTH_METHOD"을 포함하도록yml 파일에 있는 db:수정할 필요가 있다.
db:
environment:
POSTGRES_HOST_AUTH_METHOD: trust
언급URL:https://stackoverflow.com/questions/32147554/docker-cannot-link-to-a-non-running-container
'programing' 카테고리의 다른 글
사용자에게 백업 상태를 표시하는 mysqldump 진행 표시줄이 있습니까? (0) | 2022.09.25 |
---|---|
날짜 및 시간에 따라 내림차순으로 정렬하시겠습니까? (0) | 2022.09.25 |
mysql과 mysql2 gem의 차이점은 무엇입니까? (0) | 2022.09.25 |
개체 키 배열 가져오기 (0) | 2022.09.25 |
java.sql ?에 해당하는 날짜/시간(java.sql.datetime이 있습니까?) (0) | 2022.09.25 |