JAVA和Nginx 教程大全

网站首页 > 精选教程 正文

前后端都用得上的Nginx 反向代理,具体应用实战

wys521 2024-09-10 23:11:50 精选教程 35 ℃ 0 评论

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;
}

Tags:

本文暂时没有评论,来添加一个吧(●'◡'●)

欢迎 发表评论:

最近发表
标签列表