我具有以下配置:
reverse_proxy
和app_service
通过app_network
由于它们是通过app_network
连接的,所以我可以像app_service
这样在nginx配置中访问http://app_service:8080
,这很好,因为我不需要公开端口应用程序服务本身。
不幸的是,直到我调出应用服务容器,nginx才启动,因为它在启动时会检查主机名app_service
的存在。
如何防止nginx在启动时检查主机名,可能在Bad Gateway
尚未运行时尝试连接时导致app_service
错误?
供参考的配置文件:
# reverse proxy docker-compose.yml
version: '3'
services:
reverse_proxy:
restart: always
container_name: reverse_proxy
image: nginx
ports:
- 80:80
- 443:443
volumes:
- /srv/docker/nginx/config:/etc/nginx
- /srv/ssl:/srv/ssl
networks:
default:
external:
name: app_network
# application service docker-compose.yml
version: '3'
services:
app_service:
restart: always
container_name: app_service
image: <my_app_image>
networks:
default:
external:
name: app_network
# nginx config
server {
listen 443 ssl http2;
listen [::]:443 ssl http2;
server_name app.example.com;
location / {
proxy_pass http://app_service:8080;
include proxy.conf;
}
ssl_certificate /srv/ssl/<mycert>.crt;
ssl_certificate_key /srv/ssl/<mykey>.key;
}
答案 0 :(得分:0)
这是为我工作的一种方式:
# nginx config
server {
listen 443 ssl http2;
listen [::]:443 ssl http2;
server_name app.example.com;
location / {
set $upstream app_service:8080;
proxy_pass $upstream;
include proxy.conf;
}
ssl_certificate /srv/ssl/.crt;
ssl_certificate_key /srv/ssl/.key;
}
如果主机不可用,并且在启动时不检查可用性,则会显示一条502 Bad Gateway
消息。