首先前端用 node express 搭建简单服务器
具体参考express官网,npm init先创建出package.json
然后 npm i express -d
新建一个app.js,输入如下内容。
运行 node app.js
const express = require('express')
const app = express()
const port = 3000
app.get('/', (req, res) => {
res.send('Hello World1!')
})
app.get('/test1', (req, res) => {
res.send('Hello World2!')
})
app.get('/test1/dodo1', (req, res) => {
res.send('Hello World5!')
})
app.listen(port, () => {
console.log(`Example app listening on port ${port}`)
})
const express = require('express')
const app = express()
const port = 3001
app.get('/', (req, res) => {
res.send('Hello World3!')
})
app.get('/test1', (req, res) => {
res.send('Hello World4!')
})
app.get('/test1/dodo1', (req, res) => {
res.send('Hello World6!')
})
app.listen(port, () => {
console.log(`Example app listening on port ${port}`)
})
两个服务好了 我们来简单说说负载均衡 网上大多都是复制粘贴,只适配/通配符的 如下:
worker_processes 1;
events {
worker_connections 1024;
}
http {
upstream dalaoyang-server {
server localhost:10001;
server localhost:10002;
}
server {
listen 10000;
server_name localhost;
location / {
proxy_pass http://dalaoyang-server;
proxy_redirect default;
}
}
}
看着挺简单,直接就是把所有的请求统配到 localhost:10001和localhost:10002两个服务器,
没有设置权重weight 也没有ip_hash。但是我们实际应用的时候 可能需要的location不止这一个,
前端的匹配 到了 nginx也不是简单的一个通配符就可以解决的。
形如:
location ~^/doit {
rewrite ^/doit/(.*)$ /$1 break;
proxy_pass http//:192.168.0.1:3001/test1;
}
对此类负载均衡应该如何处理呢,其实大概一想就大概知道,如果我们要访问的是
localhost:8080/doit/dodo1。 到了nginx 会被从doit截断,保留/dodo1 与http//:192.168.0.1:3001/test1
拼接形成http//:192.168.0.1:3001/test1/dodo1;
那么负载均衡nginx进行配置:
upstream abc {
server localhost:3000 weight=10;
server localhost:3001 weight=10;
}
location ~^/doit {
rewrite /doit/(.*) /test1/$1;
proxy_pass http://abc;
}
整体思路:
- 首先启动最先配置的两个express工程
- nginx 配置负载均衡 abc,通过rewrite实现替换中间路径,满足多location的配置;
- 实现负载均衡常用工作配置;
实际效果如图:
效果可见;
欢迎评论区留言!