[英]docker-compose issue - Celery container not able to access DB container
Regards I have been working on a Django Application, that runs on Redis, PostgreSQL, Celery, RabbitMQ. 我写了一个 docker-compose 来在它们各自的容器中运行所有这些服务。
这是我的 docker-compose.yml
version: "3.2"
services:
app:
build:
context: .
image: &app app
ports:
- "8000:8000"
env_file: &envfile
- env.env
volumes:
- ./app:/app
environment:
- DB_HOST=db
command: >
sh -c "python manage.py wait_for_db &&
python manage.py migrate &&
python manage.py runserver 0.0.0.0:8000"
depends_on:
- db
- redis
- broker
redis:
restart: always
image: redis:latest
ports:
- "6379:6379"
db:
image: postgres:12-alpine
environment:
- "POSTGRES_HOST_AUTH_METHOD=trust"
worker:
build: .
image: *app
restart: always
env_file: *envfile
command: ["celery", "worker", "--app=worker.worker.app", "--concurrency=1", "--hostname=worker@%h", "--loglevel=INFO"]
volumes:
- ./app:/app
depends_on:
- broker
- redis
- db
broker:
image: rabbitmq:3
env_file: *envfile
ports:
- 5672:5672
flower:
image: zoomeranalytics/flower:0.9.1-4.0.2
restart: "no"
env_file: *envfile
ports:
- "5555:5555"
depends_on:
- broker
我的应用程序工作得很好,容器似乎也在工作,当我将异步作业推送到工作容器时出现问题。 工作容器接手工作,并开始处理,我试图访问工作人员中的数据库,但它给了我以下错误 -
任务 [640127f3-7769-4757-8c33-8de9052ca92c] 引发意外:OperationalError('无法连接到服务器:没有这样的文件或目录\n\t服务器是否在本地运行并接受\n\t Unix 域套接字上的连接"/tmp /.s.PGSQL.5432"?\n')
我知道我的工作容器正在尝试访问它无法找到的数据库,有人可以帮我通过工作容器访问我的数据库容器,对此非常坚持。
我尝试了 depends_on , links ,但似乎没有任何效果。
明白了,感谢我的队友。
我一通过就错过了在工作容器中提供环境变量,瞧!
environment:
- DB_HOST=db
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.