
단일 도커 컨테이너에 웹 서버와 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