Nginx实现反向代理和负载均衡

概述

Nginx 是一款高性能的 http 服务器/反向代理服务器及电子邮件(IMAP/POP3)代理服务器。由俄罗斯的程序设计师伊戈尔·西索夫(Igor Sysoev)所开发,官方测试 nginx 能够支支撑 5 万并发链接,并且 cpu、内存等资源消耗却非常低,运行非常稳定。

Nginx 应用场景:
1、http 服务器。Nginx 是一个 http 服务可以独立提供 http 服务。可以做网页静态服务器。
2、虚拟主机。可以实现在一台服务器虚拟出多个网站。例如个人网站使用的虚拟主机。
3、反向代理,负载均衡。当网站的访问量达到一定程度后,单台服务器不能满足用户的请求时,需要用多台服务器集群可以使用 nginx 做反向代理。并且多台服务器可以平均分担负载,不会因为某台服务器负载高宕机而某台服务器闲置的情况。

安装

首先到官网下载
http://nginx.org/en/download.html
我就使用windows稳定版本的 nginx/Windows-1.14.0
下载解压后.我就放在D:\server
注意:使用管理员打开命令行
使用nginx启动nginx
访问localhost:80
出现如下页面说明启动成功
这里写图片描述

想关闭 nginx有以下两个命令

nginx -s stop
nginx -s quit 

修改nginx.conf文件后,重新加载,使用如下命令

nginx -s reload 

端口映射部署静态文件

接下来使用nginx部署静态文件
在根目录下新建server1 和server2的文件夹,并添加index.html文件
修改D:\server\nginx-1.14.0\conf\nginx.conf文件
添加如下内容,做端口映射静态资源文件

     server {
        listen       81;
        server_name  localhost;
        location / {
            root   server1;
            index  index.html;
        }      
    }
    server {
        listen       82;
        server_name  localhost;
        location / {
            root   server2;
            index  index.html;
        }        
    }

重新加载nginx
访问localhost:81 与localhost:81 即可访问静态文件

反向代理和负载均衡

在springcloud中我们使用Ribbon进行负载均衡,使用zuul进行网关代理
nginx也有反向代理和负载均衡的功能
为了测试方便,启动两个SpringBoot项目,端口分别为8001和8002
暴露RestAPI

@RestController
public class TestController {
    @RequestMapping("/port")
    public String hello(){

        return "server port 8001";
    }
}

@RestController
public class TestController {

    @RequestMapping("/port")
    public String hello(){
        return "server port 8002";
    }
}

接下来在D:\server\nginx-1.14.0\conf\nginx.conf中配置ip:端口映射
并可以设置权重

     upstream tomcat-portal {
       server 127.0.0.1:8001;
       server 127.0.0.1:8002 weight=2;
    }
    server {
        listen       83;
        server_name  localhost;   
        location / {
            proxy_pass   http://tomcat-portal;
        }
    }

不断刷新访问localhost:83/port 可见实现了反向代理与负载均衡

  • 2
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Nginx是一款高性能、轻量级的Web服务器,它可以作为反向代理服务器和负载均衡器。下面是Nginx实现反向代理负载均衡的详细过程: 1. 反向代理 反向代理是指客户端请求的资源不是直接由服务器提供,而是由代理服务器转发请求到后端服务器获取资源并返回给客户端。反向代理可以隐藏后端服务器的真实IP地址,提高了系统的安全性。 Nginx实现反向代理的步骤如下: 1) 在Nginx配置文件中配置反向代理服务器的IP地址和端口号。 2) 配置反向代理的location块,将客户端请求的URL转发到后端服务器。 3) 配置后端服务器的IP地址和端口号。 2. 负载均衡 负载均衡是指将客户端请求均匀地分发到多个后端服务器上,以达到提高系统响应速度和增加系统的可靠性的目的。Nginx实现负载均衡的方式有多种,其中常用的有轮询方式和IP hash方式。 轮询方式是指将客户端请求轮流分配到后端的每台服务器上,每次请求都按照服务器列表的顺序依次分配。轮询方式是Nginx默认的负载均衡方式。 IP hash方式是指根据客户端的IP地址计算出一个hash值,然后将该请求分配到hash值对应的后端服务器上,这样相同IP地址的请求总是被分配到同一台后端服务器上。 Nginx实现负载均衡的步骤如下: 1) 在Nginx配置文件中配置后端服务器的IP地址和端口号。 2) 配置upstream块,将多个后端服务器配置在upstream块中。 3) 配置负载均衡的方式,例如轮询方式或IP hash方式。 总体来说,Nginx作为反向代理负载均衡器,可以提高系统的性能和可靠性,是企业级应用中非常常用的技术之一。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值