但是我有问题。
Dockerfile:
FROM python:3
ENV PYTHONUNBUFFERED 0
RUN mkdir /code
WORKDIR /code
COPY requirements.txt /code/
RUN pip install -r requirements.txt
COPY . /code/
compose.yml:
version: '3'
services:
db:
image: postgres
volumes:
- ./docker/data:/var/lib/postgresql/data
environment:
- POSTGRES_DB=sampledb
- POSTGRES_USER=sampleuser
- POSTGRES_PASSWORD=samplesecret
- POSTGRES_INITDB_ARGS=--encoding=UTF-8
django:
build: .
environment:
- DJANGO_DEBUG=True
- DJANGO_DB_HOST=db
- DJANGO_DB_PORT=5432
- DJANGO_DB_NAME=sampledb
- DJANGO_DB_USERNAME=sampleuser
- DJANGO_DB_PASSWORD=samplesecret
- DJANGO_SECRET_KEY=dev_secret_key
ports:
- "8000:8000"
command:
- python3 manage.py runserver
volumes:
- .:/code
错误:
ERROR: for django Cannot start service django: OCI runtime create failed: container_linux.go:346: starting container process caused "exec: \"python3 manage.py runserver\": executable file not found in $PATH": unknown
起初,我认为Python Manage是错误的。
但是我尝试使用命令ls
,令我惊讶的是,我成功了。
然后我尝试了ls -al命令,但是失败了。
我认为增加写空间的命令会引起问题。
我该如何解决?
答案 0 :(得分:1)
在docker-compose.yml
文件中使用列表语法时,每个项目都被当作一个单词。您正在运行的外壳程序等效于
'python3 manage.py runserver'
您可以自己将其分解为单独的单词
command:
- python3
- manage.py
- runserver
或者让Docker Compose为您完成
command: python3 manage.py runserver
通常,此类映像的固定属性应在Dockerfile中指定,而不是在docker-compose.yml
中指定。每次运行该映像时,您都将要运行相同的命令,并且您将要运行映像中内置的代码。有两种语法,具有相同的基本区别:
# Explicitly write out the words
CMD ["python3", "manage.py", "runserver"]
# Docker wraps in sh -c '...' which splits words for you
CMD python3 manage.py runserver
有了图像中内置的代码并在其中定义了合理的默认命令,您可以从volumes:
文件中删除command:
和docker-compose.yml
。