nginx系列之实现简单的负载均衡

一、前言

负载均衡,个人理解,旨在于把客户端的请求均匀地发到后端服务器来处理,以解决单机处理能力有限的问题,同时又不让某个服务器负担过重。

百度一下“负载均衡”,文章一大把,不过别人怎么说与自己怎么做是两回事。通常使用的负载均衡的软件有LVS、HAProxy和nginx,其中nginx配置比较简单,手边也正好有这个软件,于是想用nginx来练习下。

用nginx实现负载均主要使用upstream和proxy这个两个模块。目前nginx的负载均衡有轮询、ip _hash(按照客户段ip地址来分配)、least_conn(优先选择活动连接数最少的上游服务器)、least_time(优先选择处理时间最短的上游服务器)这4种方法,默认是轮询,可以带权重。

二、环境搭建与测试

笔者用的是OpenResty,主要是因为第三方模块众多,其中用echo模块的echo指令可以直接向客户端输出内容,使得调试方便不少。

环境搭建得益于nginx命令的 -c 选项,该选项可以让nginx以不同的配置文件启动。本次测试在一台个人笔记本中进行,共开启4个nginx服务主进程,其中1个监听在80端口,作为负载均衡器。另外3个分别监听8001、8002、8003端口,分别命名为server-8001、server-8002、server-8003,作为上游服务器。

2.1 轮询方法
  • 负载均衡器的配置
    upstream @backend {
        server 127.0.0.1:8001;
        server 127.0.0.1:8002;
        server 127.0.0.1:8003;
    }

将该配置置于http上下文中。
该配置定义了一组服务器组,命名为@backend。默认是轮询方式,请求是平均分给每一个上游服务器的。

location / {
   proxy_set_header Host $host;
   proxy_set_header X-Real-IP $remote_addr;
   proxy_pass http://@backend;
}

将该配置置

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值