我正在尝试将nginx容器作为我所有网站和Web服务的主要入口点。我设法将portainer作为容器运行,并且可以从互联网上访问它。现在,我正在尝试访问由另一个nginx容器托管的静态网站,但这样做失败-当我转到URL时,会得到
502 Bad Gateway
我已经尝试将上游部分添加到我的主要Nginx的配置中,但是没有任何变化(每次更改配置后,我都会在容器内重新加载我的主要Nginx服务)。
另一方面,如果可能,添加上游是我要避免的事情,因为产生多个不同的应用程序将需要为每个应用程序添加一个上游-这比我期望的要多得多。
这是我的主要nginx的配置文件:
events {
worker_connections 1024;
}
http {
server {
listen 80;
location /portainer/ {
proxy_pass http://portainer:9000/;
}
location /helicon/ {
proxy_pass http://helicon:8001/;
}
}
}
这是我启动我的主要nginx容器的方式:
docker run -p 80:80 --name nginx -v /var/nginx/conf:/etc/nginx:ro --net=internal-net -d nginx
这是我的静态网站的nginx配置文件:
events {
worker_connections 1024;
}
http {
server {
listen 80;
server_name helicon;
root /var/www/html/helicon;
error_log /var/log/nginx/localhost.error.log;
access_log /var/log/nginx/localhost.access.log;
}
}
这是docker-compose文件创建和启动该容器的方式:
version: '3.5'
services:
helicon:
build: .
image: helicon
ports:
- "127.0.0.1:8001:80"
container_name: helicon
networks:
- internal-net
networks:
internal-net:
external: true
我正在使用internal-net
网络将所有应用保持在同一网络中,而不是不推荐使用--link
的docker run
选项
[转到http://my.server.ip.address/helicon时,我得到502。然后我用docker logs nginx
检查日志,并且有信息
2018/06/24 11:15:28 [error] 848#848: *466 connect() failed (111: Connection refused) while connecting to upstream, client: Y.Y.Y.Y, server: , request: "GET /helicon/ HTTP/1.1", upstream: "http://172.18.0.2:8001/", host: "X.X.X.X"
Helicon容器的IP地址确实为172.18.0.2。
我想念的是什么?也许我的方法应该与使用网络完全不同?
亲切的问候,
丹尼尔
已解决。我花了几个小时思考这是一个nginx配置问题。我不断修改nginx.conf,但无法修复。我收到502错误网关,错误描述为:
failed (111: Connection refused) while connecting to upstream
我看错地方了。原来,我的index.js文件中的http服务器正在侦听url'localhost'。
httpServer.listen(PORT, 'localhost', async err => {
这在您的开发机器上正常工作,但是在容器内运行时,必须将其命名为容器本身的url。我的容器已联网,在我的情况下,该容器名为“后端”
我将网址从“ localhost”更改为“后端”,并且一切正常。
httpServer.listen(PORT, 'backend', async err => {