[英]Is this Docker / NGINX / Node setup actually load balancing as expected?
[英]docker nginx load balancing not working with Azure
好的,现在已经尝试了一整天了。 我无法让Nginx将azure
给我的域名连接到我的node
docker
容器。
我正在使用Azure
创建VM
。 DNS name
是scout-1j013s34.cloudapp.net
virtual IP address
是191.237.66.86
我可以ssh
到VM
与ssh monty@scout-1j013s34.cloudapp.net -p 61777
。 我不确定为什么需要指定端口?
VM
正在运行Ubuntu 14.04
。 我自己安装了docker
。
我找到并遵循了以下教程A sample Docker workflow with Nginx, Node.js and Redis
我构建并运行了容器,如下所示。
这是我的nginx.conf
文件
worker_processes 4;
events { worker_connections 1024; }
http {
##
# Logging Settings
##
access_log /var/log/nginx/access.log;
error_log /var/log/nginx/error.log;
upstream node-app {
least_conn;
server node1:1337 weight=10 max_fails=3 fail_timeout=30s;
server node2:1337 weight=10 max_fails=3 fail_timeout=30s;
server node3:1337 weight=10 max_fails=3 fail_timeout=30s;
}
server {
listen 80;
server_name 191.237.66.86 scout-1j013s34.cloudapp.net www.scout-1j013s34.cloudapp.net;
location / {
proxy_pass http://node-app;
proxy_http_version 1.1;
proxy_set_header Upgrade $http_upgrade;
proxy_set_header Connection 'upgrade';
proxy_set_header Host $host;
proxy_cache_bypass $http_upgrade;
}
}
}
当我在浏览器地址栏中输入http://scout-1j013s34.cloudapp.net/
时,它超时了。
更新:我有EXPOSE 1337
在我Dockerfile
揭露1337个端口,每个节点的容器。
对于每个节点容器,我都docker run -it --name node1 --link mongo:MONGODB -v /home/monty/scout/backend-api/:/scout-sails mlennie/scout-sails bash
将名称更改为node2并接下来的2个node3,然后我进入每个容器,并用sails.js
sails lift
启动了sails.js
应用程序。
然后我启动了nginx容器,并使用命令docker run -d --name nginx -p 80:80 --link node1:node1 --link node2:node2 --link node3:node3 mlennie/nginx
将其链接到3个节点容器docker run -d --name nginx -p 80:80 --link node1:node1 --link node2:node2 --link node3:node3 mlennie/nginx
好的,我可以正常工作了,我需要通过Azure管理门户手动添加一个端口为80的终结点。
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.