我尝试使用相同的 Nodejs 应用程序在两个容器之间建立 nginx 反向代理负载平衡。
目录结构:
.
+-- docker-compose.yml
+-- nginx
+-- nodejs
| +-- index.js
| +-- …
+-- php
docker-compose.yml:
version: "3.1"
services:
nginx-proxy:
image: nginx:alpine
ports:
- "8000:80"
volumes:
- ./nginx/default.conf:/etc/nginx/conf.d/default.conf
links:
- php:php-app
- nodejs:nodejs-app
nodejs:
image: node:alpine
environment:
NODE_ENV: production
working_dir: /home/app
restart: always
volumes:
- ./nodejs:/home/app
command: ["node", "index.js"]
php:
image: php:apache
volumes:
- ./php:/var/www/html
index.js
在端口监听8080
nginx 配置default.conf
:
upstream nodejs-upstream {
server nodejs-app:8080;
}
server {
listen 80;
root /srv/www;
location / {
try_files $uri @nodejs;
}
location @nodejs {
proxy_pass http://nodejs-upstream:8080;
proxy_set_header Host $host;
}
location /api {
proxy_pass http://php-app:80/api;
proxy_set_header Host $host;
}
}
现在我启动应用程序
docker-compose up --scale nodejs=2
负载均衡吗?
- 我不这么认为,因为 Nodejs 应用程序的两个实例侦听同一端口
8080
.
如何使 nginx 服务器在 Nodejs 应用程序的两个实例之间实现负载平衡?
有一个更好的方法吗?
EDIT 1
我仍然很好奇如何在没有 jwilder/nginx-proxy 的情况下做到这一点。谢谢
EDIT 2
我有一些可以使用的东西:
default.conf
:
upstream nodejs-upstream {
server nodejs_1:8080;
server nodejs_2:8080;
}
这在两个 Nodejs 容器启动时有效。当我docker stop nodejs_2
,应用程序仍然可用(负载平衡似乎可以工作),但请求结束的速度可能非常慢(在本地主机上最多需要 1 分钟)。如果我重新启动这个容器,它会再次正常工作......