FastAPI가 Docker 내부에서 Apache2를 마스킹하고 있습니다.

FastAPI가 Docker 내부에서 Apache2를 마스킹하고 있습니다.

단일 도커 컨테이너에 웹 서버와 FastAPI를 설정했습니다. Dockerfile의 관련 부분은 다음과 같습니다.

FROM ubuntu/apache2:2.4-22.04_beta
[...]
# Apache conf
RUN echo '<VirtualHost *:80>\n\
            DocumentRoot /var/www/html\n\
            <Directory "/var/www/html">\n\
                Options MultiViews FollowSymLinks\n\
                AddHandler cgi-script .cgi .py\n\
                AllowOverride All\n\
                Options +ExecCGI\n\
                Require all granted\n\
            </Directory>\n\
            ErrorLog /var/log/apache2/error.log\n\
            LogLevel warn\n\
            CustomLog /var/log/apache2/access.log combined\n\
        </VirtualHost>' > /etc/apache2/sites-available/000-default.conf

RUN a2enmod cgi
RUN service apache2 restart

[...]

EXPOSE 80
EXPOSE 8080

ENV PYTHONPATH "${PYTHONPATH}:/var/www/html"
CMD ["uvicorn", "main:app", "--proxy-headers", "--host", "0.0.0.0", "--port", "8080"]

따라서 기본적으로 Apache는 포트 80을 제공하고 API는 포트 8080을 수신합니다.

다음과 같은 docker-compose.yaml 파일이 있습니다.

version: "3.6"
services:
  web:
    build: .
    restart: unless-stopped
    ports:
      - "8090:80"
      - "8092:8080"
    volumes:
      - ./database/:/var/www/html/database

이 컨테이너는 다음을 설정한 Apache2 역방향 프록시 뒤에서 실행됩니다.

[...]
ProxyPass /server/api http://localhost:8092/server/api
ProxyPassReverse /server/api http://localhost:8092/server/api

ProxyPass /server http://localhost:8090/
ProxyPassReverse /server http://localhost:8090/
[...]

문제는 모든 것이 정상적으로 시작되면 API가 제대로 작동하지만 기본 서버가 응답하지 않고 proxy_http호스트 아파치 로그에 다음 오류가 표시된다는 것입니다.

AH01102: error reading status line from remote server localhost:8090

Docker 내부를 확인했는데 Docker를 시작한 후 apache2 서비스가 실행되지 않았습니다. 다음을 실행하여 문제를 해결할 수 있습니다.

docker exec -t web-1 service apache2 restart

uvicorn 명령이 시작되면 어떻게 든 아파치 서버를 가리거나 중지하는 것 같습니다. 다음을 추가할 수 없기 때문에 이 문제를 해결하는 방법을 잘 모르겠습니다.

 RUN service apache2 restart

dockerfile의 마지막 CMD 줄 뒤.

답변1

@Spirit의 제안에 따라 2개의 별도 Dockerfile로 2개의 서비스를 설정하기 위해 docker-compose를 변경했습니다. 이제 포트에 더 이상 문제가 없습니다.

version: "3.6"
services:
  web:
    build:
      dockerfile: Dockerfile
    restart: unless-stopped
    ports:
      - "8090:80"
    volumes:
      - ./database:/var/www/html/database
  
  api:
    build:
      dockerfile: Dockerfile-api
    restart: unless-stopped
    ports:
      - "8092:80"
    volumes:
      - ./database:/var/www/html/database

관련 정보