У меня есть проект Docker, в котором есть локальный модуль Python, который используется двумя службами в контейнере Docker. Я пытаюсь использовать поле дополнительных контекстов в файле компоновки, чтобы обе службы могли скопировать этот модуль в свой образ.
Структура проекта Docker выглядит следующим образом
├── docker-compose-aws.yml
├── docker-compose.override.yml
├── docker-compose.yml
├── ecs-params.yml
├── model_server
│ └── app
│ ├── Dockerfile
│ ├── app
│ │ └── run_model_server.py
│ └── requirements.txt
├── shared
│ └── models.py
└── web_server
└── app
├── Dockerfile
├── app
│ └── main.py
└── requirements.txt
Файл создания сообщения выглядит следующим образом:
name: my_docker
services:
model-server:
build:
context: ./model_server/app
additional_contexts:
assets: ./shared
dockerfile: Dockerfile
args:
INSTALL_DEV: "true"
command:
- python
- run_model_server.py
environment:
ENVIRONMENT: dev
REDIS_HOST: redis
image: template-model-server:latest
networks:
default: null
volumes:
- type: bind
source: ./model_server/app
target: /app
bind:
create_host_path: true
working_dir: /app/app
redis:
image: redis:alpine
networks:
default: null
ports:
- mode: ingress
target: 6379
published: "6379"
protocol: tcp
web:
build:
context: ./web_server/app
additional_contexts:
assets: ./shared
dockerfile: Dockerfile
args:
INSTALL_DEV: "true"
command:
- python
- main.py
- serve
depends_on:
model-server:
condition: service_started
required: true
environment:
ENVIRONMENT: dev
REDIS_HOST: redis
RELOAD: "True"
image: template-web-server:latest
networks:
default: null
ports:
- mode: ingress
target: 5042
published: "5042"
protocol: tcp
volumes:
- type: bind
source: ./web_server/app
target: /app
bind:
create_host_path: true
working_dir: /app/app
networks:
default:
name: my_docker_default
Файл докера выглядит так:
FROM python:3.10-slim-bullseye
RUN apt-get update && apt-get install -y gcc build-essential cmake \
git python3-dev gcc && rm -rf /var/lib/apt/lists/*
COPY requirements.txt dev-requirements.txt ./
RUN pip install --no-cache-dir --upgrade pip
ARG INSTALL_DEV=false
RUN bash -c "if [ $INSTALL_DEV == 'true' ] ; then pip install --no-cache-dir -r dev-requirements.txt && pip install --no-cache-dir -r requirements.txt ; else pip install --no-cache-dir -r requirements.txt --upgrade ; fi"
COPY app app/
COPY --from=assets ./shared app/shared
COPY scripts scripts/
Когда я пытаюсь импортировать общий модуль Python с помощью команды import Shared.models, я получаю ошибку ModuleNotFoundError.
Использование docker Compose build. Я получаю немного больше информации об ошибке:
failed to solve: shared: failed to resolve source metadata for docker.io/library/shared:latest: pull access denied, repository does not exist or may require authorization: server message: insufficient_scope: authorization failed
Подробнее здесь: https://stackoverflow.com/questions/789 ... al-context
Доступ к локальному модулю Python из двух отдельных сервисов с дополнительными контекстами в Docker ⇐ Python
-
- Похожие темы
- Ответы
- Просмотры
- Последнее сообщение