前后端都用得上的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;
}

相关文章

11《Nginx 入门教程》Nginx反向代理(下)

本小节,我们继续学习 Nginx 在 七层反向代理中的其它几种比较常见的情况,比如 web 服务中的 WebSocket 协议的反向代理和 uwsgi 协议的反向代理。1. WebSocket的反向代...

好使!NAS中傻瓜式配置反向代理及SSL证书,提升网络安全性!

对于有NAS或者有个人主机的朋友来说,将机器映射到外网是基本操作。但是一般来说,能直接从外网访问的往往仅有80和443端口。事实上,运营商一般把家庭宽带的这两个端口都封了,所以如果我们想要从外网访问自...

SpringCloud微服务笔记-Nginx实现网关反向代理

背景当前在SpringCloud微服务架构下,网关作为服务的入口尤为重要,一旦网关发生单点故障会导致整个服务集群瘫痪,为了保证网关的高可用可以通过Nginx的反向代理功能实现网关的高可用。项目源码:h...