前后端都用得上的Nginx 反向代理,具体应用实战
1、nginx 隐藏端口
服务器上的一个端口只能被一个程序使用,要想实现多个程序共用一个端口,可以使用Nginx转发:用 Nginx 监听 80 端口,当有 HTTP 请求到来时,将 HTTP 请求的 HOST 等信息与其配置文件进行匹配并转发给对应的应用
server {
listen 80;
server_name _;
location / {
server_name_in_redirect off;
proxy_set_header Host $host:$server_port;
proxy_set_header X-Real-IP $remote_addr;
proxy_set_header REMOTE-HOST $remote_addr;
proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
proxy_pass http://127.0.0.1:8009;
}
}
http://localhost:80 转发到 http://127.0.0.1:8009
2、nginx 端口转发到指定路径
server {
listen 80;
server_name _;
location /api/ {
proxy_redirect off;
proxy_set_header Host $host:$server_port;
proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
proxy_pass http://127.0.0.1:8086/;
}
}
http://localhost:80/api/ 转发到 http://127.0.0.1:8086/
3、根据请求后缀分发
server {
listen 80;
server_name _;
location ~/dev/ {
proxy_redirect off;
proxy_set_header Host $host:$server_port;
proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
proxy_pass http://127.0.0.1:8086;
}
location ~/prod/ {
proxy_redirect off;
proxy_set_header Host $host:$server_port;
proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
proxy_pass http://127.0.0.1:8087;
}
}
http://localhost:80/dev/ 转发到 http://127.0.0.1:8086/dev/
http://localhost:80/prod/ 转发到 http://127.0.0.1:8087/prod/
4、负责均衡
负载均衡,意思是将负载(工作任务,访问请求)进行平衡、分摊到多个操作单元(服务器、组件)上进行执行,是解决高性能、单点故障(高可用)、扩展性(水平伸缩)的终极解决方案。
如果请求数过大,单个服务器解决不了,我们增加服务器的数量,然后将请求分发到各个服务器上,将原先请求集中到单个服务器的情况改为请求分发到多个服务器上,就是负载均衡。
upstream java_server {
server 192.168.100:8086;
server 192.168.100:8099;
}
server {
listen 80;
server_name _;
location /java/ {
proxy_redirect off;
proxy_set_header Host $host:$server_port;
proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
proxy_pass http://java_server/;
}
}
http://localhost:80/java/ 转发到 http://127.0.0.1:8086/ 和 http://192.168.100:8099/
负载均衡实现的几种策略:
1、轮询(默认):每个请求按时间顺序逐一分配到不同的服务器,如果服务器down了,会自动剔除
upstream java_server {
server 192.168.100:8086;
server 192.168.100:8099;
}
2、权重:默认为1,权重越高,分配的请求越多。
upstream java_server {
server 192.168.100:8086 weight=2; //8086服务可接受请求是8099服务的两倍
server 192.168.100:8099;
}
3、ip_hash: 每个请求按访问ip的hash结果分配,这样每个访客固定访问一个后台服务器, 可以解决 session 的问题。
upstream java_server {
ip_hash;
server 192.168.100:8086;
server 192.168.100:8099;
}
4、fair(第三方):按后端响应时间进行分配,响应时间越短分配的请求越多。
upstream java_server {
fair;
server 192.168.100:8086;
server 192.168.100:8099;
}