配置nginx负载均衡


Posted in Servers onMay 06, 2022

前言

nginx作为一款企业级的代理服务器,不管是大中小各类生产项目中,均有广泛的使用,尤其是在前后端分离的项目中,nginx作为路由转发的功能是非常常用的;

在一些流量比较大的项目中,为了应对高并发的场景,后端服务往往采用集群部署,这时候,就需要使用到nginx的负载均衡功能;

实验准备

  • nginx服务器;
  • 两个后端服务;

实验步骤

1、启动两个后端服务

这里准备了两个springboot工程,编写了2个测试使用的接口,以端口号区分

@RestController
@RequestMapping("/api")
public class NginxController1 {
    @GetMapping
    public String test1(){
        return "success test1 8082";
    }
}
@RestController
@RequestMapping("/api")
public class NginxController1 {
    @GetMapping
    public String test1(){
        return "success test1 8081";
    }
}

启动之后,浏览器分别访问一下,确保服务是正常的

配置nginx负载均衡

配置nginx负载均衡

2、nginx.conf进行配置

1)在server中添加一个location,并且配置 proxy_pass

location / {
             #转发到负载服务上
            proxy_pass http://webservers/api/;
 }

2)配置upstream,指向后端服务

upstream webservers{
      server  192.168.9.134:8081;
      server  192.168.9.134:8082;
}

完整的配置参考如下:

#user  nobody;
worker_processes  1;
events {
    worker_connections  1024;
}

http {
    include       mime.types;
    default_type  application/octet-stream;
    sendfile        on;
    keepalive_timeout  65;
   upstream webservers{
      server  192.168.9.134:8081 weight=8;
      server  192.168.9.134:8082 weight=2;
   }
 
    server {
        listen       80;
        server_name  localhost;
        #location / {
         #   root   html;
          #  index  index.html index.htm;
        #}

        location / {
             #转发到负载服务上
            proxy_pass http://webservers/api/;
         }

        error_page   500 502 503 504  /50x.html;
        location = /50x.html {
            root   html;
        }
    }
}

修改完毕后,启动nginx,或者重新加载配置

nginx.exe -s reload

浏览器访问:localhost:80,多刷几次,下面两个展示的界面轮询的出现

配置nginx负载均衡

配置nginx负载均衡

3、负载均衡配置说明

默认情况下,直接按照上面的配置后,如果后端有多个服务,采用的是轮询策略;

常用的可选配置包括:

weight 多台机器,可以配置权重值,权重高的服务将会优先被访问
down 某个服务配置down之后,这台服务将不会被访问
backup 配置了这个参数后,除非其他的服务都挂掉了,否则这台服务将不会被访问到

以weight 为例做简单的说明,在上面的配置中,补充weight参数

upstream webservers{
      server  192.168.9.134:8081 weight=8;
      server  192.168.9.134:8082 weight=2;
   }

重新加载配置,按照上面的测试步骤再次刷新页面,这时候可以发现,8081对于的这个服务将会被更多的访问到;

其他负载均衡配置策略

默认情况下,nginx采用的是轮询策略,nginx还提供了其他几种常用的负载均衡配置

1、ip_hash

每个请求按访问IP的hash结果进行分配,这样每个访客就可以固定访问一个后端服务,一定程度上可以解决session问题;

upstream webservers {<!--{C}%3C!%2D%2D%20%2D%2D%3E--> ip_hash; server 192.168.9.134:8081; server 192.168.9.134:8082;}

2、weight

weight代表权重,默认为1,权重越高,被分配的客户端请求就会越多

upstream webservers{
      server  192.168.9.134:8081 weight=8;
      server  192.168.9.134:8082 weight=2;
   }

3、fair(第三方)

按后端服务器的响应时间来分配请求,响应时间短的将会被优先分配

upstream webservers{
    	server 192.168.9.134:8081;
        server 192.168.9.134:8082;
        fair;
}

4、url_hash

按访问URL的hash结果分配。这样相同的url会被分配到同一个节点,主要为了提高缓存命中率。比如,为了提高访问性能,服务端有大量数据或者资源文件需要被缓存。使用这种策略,可以节省缓存空间,提高缓存命中率

upstream webservers{
	hash &request_uri;
	server 192.168.9.134:8081;
	server 192.168.9.134:8082;
}

5、least_conn

按节点连接数分配,把请求优先分配给连接数少的节点。该策略主要为了解决,各个节点请求处理时间长短不一造成某些节点超负荷的情况。

upstream webservers{
    least_conn;
    server 192.168.9.134:8081;
    server 192.168.9.134:8082;
}

以上不同的负载均衡策略均有各自不同的使用场景,请结合自身的实际情况进行合理的选择,同时,各自配置策略在实际使用的时候也不是孤立的,比如最小连接数可以搭配权重数一起使用

总结

到此这篇关于nginx负载均衡配置的文章就介绍到这了,更多相关nginx负载均衡配置内容请搜索三水点靠木以前的文章或继续浏览下面的相关文章希望大家以后多多支持三水点靠木!


Tags in this post...

Servers 相关文章推荐
Centos7.7 64位利用本地完整安装包安装lnmp/lamp套件教程
Mar 09 Servers
小程序后台PHP版本部署运行 LNMP+WNMP
Apr 01 Servers
nginx的zabbix 5.0安装部署的方法步骤
Jul 16 Servers
nginx从安装到配置详细说明(安装,安全配置,防盗链,动静分离,配置 HTTPS,性能优化)
Feb 12 Servers
Nginx+Tomcat负载均衡多实例详解
Apr 11 Servers
Windows Server 2008 修改远程登录端口以及配置防火墙
Apr 28 Servers
基于docker安装zabbix的详细教程
Jun 05 Servers
Ubuntu安装Mysql+启用远程连接的完整过程
Jun 21 Servers
GPU服务器的多用户配置方法
Jul 07 Servers
nginx七层负载均衡配置详解
Jul 15 Servers
码云(gitee)通过git自动同步到阿里云服务器
Dec 24 Servers
tomcat下部署jenkins的方法
排查Tomcat进程假死的问题
May 06 #Servers
使用Nginx的访问日志统计PV与UV
Tomcat配置访问日志和线程数
May 06 #Servers
tomcat正常启动但网页却无法访问的几种解决方法
May 06 #Servers
tomcat默认最大连接数及相关调整方法
May 06 #Servers
如何Tomcat中使用ipv6地址
May 06 #Servers
You might like
解析关于wamp启动是80端口被占用的问题
2013/06/21 PHP
ThinkPHP3.1新特性之对Ajax的支持更加完善
2014/06/19 PHP
php之Smarty模板使用方法示例详解
2014/07/08 PHP
php实现的CSS更新类实例
2014/09/22 PHP
新浪微博OAuth认证和储存的主要过程详解
2015/03/27 PHP
关于JavaScript的gzip静态压缩方法
2007/01/05 Javascript
JavaScript 不只是脚本
2007/05/30 Javascript
jquery multiSelect 多选下拉框
2010/07/09 Javascript
基于JQuery的类似新浪微博展示信息效果的代码
2012/07/23 Javascript
深入理解JavaScript中的传值与传引用
2013/12/09 Javascript
JavaScript的21条基本知识点
2014/03/04 Javascript
node.js中的url.format方法使用说明
2014/12/10 Javascript
原生JavaScript+LESS实现瀑布流
2014/12/12 Javascript
jquery实现表单验证并阻止非法提交
2015/07/09 Javascript
JavaScript中使用参数个数实现重载功能
2017/09/01 Javascript
jQuery选择器之子元素过滤选择器
2017/09/28 jQuery
jQuery+Cookie实现切换皮肤功能【附源码下载】
2018/03/25 jQuery
简单介绍react redux的中间件的使用
2018/04/06 Javascript
解决vue路由后界面没有变化,但是链接有的问题
2018/09/01 Javascript
微信小程序实现搜索历史功能
2020/03/26 Javascript
Vue中nprogress页面加载进度条的方法实现
2020/11/13 Javascript
[32:47]完美世界DOTA2联赛 GXR vs IO 第二场 11.07
2020/11/09 DOTA
Python 列表排序方法reverse、sort、sorted详解
2016/01/22 Python
python使用pil库实现图片合成实例代码
2018/01/20 Python
对python中的logger模块全面讲解
2018/04/28 Python
Python json解析库jsonpath原理及使用示例
2020/11/25 Python
详解HTML5中的元素与元素
2015/08/17 HTML / CSS
罗马尼亚在线杂货店:Pilulka.ro
2019/09/28 全球购物
意大利和国际最佳时尚品牌:Drestige
2019/12/28 全球购物
应付会计岗位职责
2013/12/12 职场文书
2014年医生工作总结
2014/11/21 职场文书
申报材料格式
2014/12/30 职场文书
二年级语文上册复习计划
2015/01/19 职场文书
教师个人学习总结
2015/02/11 职场文书
民政局未婚证明
2015/06/15 职场文书
maven依赖的version声明控制方式
2022/01/18 Java/Android