012.Nginx负载均衡
一 负载均衡概述
1.1 负载均衡介绍
二 Nginx负载均衡
2.1 优点
2.2 主要均衡机制
2.3 负载均衡策略
2.4 负载均衡内置变量
2.5 负载均衡健康检查
2.6 负载均衡状态码
状态
|
概述
|
max_fails
|
允许请求失败的次数,默认为1。
|
max_conns
|
限制最大接受的连接数。
|
fail_timeout
|
在经历了max_fails次失败后,暂停服务的时间。
|
backup
|
预留的备份机器。
|
down
|
表示当前的server暂时不参与负载均衡。
|
三 默认轮询负载均衡
3.1 环境预设
主机
|
IP
|
备注
|
nginx01
|
172.24.10.21
|
Nginx负载均衡
|
nginx02
|
172.24.10.22
|
后端RS 01
|
nginx03
|
172.24.10.23
|
后端RS 02
|
nginx04
|
172.24.10.24
|
后端RS 03
|
1 [root@nginx02 ~]# mkdir /usr/share/nginx/balanc/
2 [root@nginx02 ~]# echo '<h1>Rs_172.24.10.22</h1>' > /usr/share/nginx/balanc/index.html
1 [root@nginx02 ~]# cat > /etc/nginx/conf.d/rs.conf <<EOF
2 server {
3 listen 9090;
4 server_name 172.24.10.22;
5 location / {
6 root /usr/share/nginx/balanc;
7 index index.html;
8 access_log /var/log/nginx/rs.access.log main;
9 error_log /var/log/nginx/rs.error.log warn;
10 }
11 }
12 EOF
1 [root@nginx02 ~]# nginx -t -c /etc/nginx/nginx.conf #检查配置文件
2 [root@nginx02 ~]# nginx -s reload #重载配置文件
1 [root@nginx03 ~]# mkdir /usr/share/nginx/balanc/
2 [root@nginx03 ~]# echo '<h1>Rs_172.24.10.23</h1>' > /usr/share/nginx/balanc/index.html
1 [root@nginx03 ~]# cat > /etc/nginx/conf.d/rs.conf <<EOF
2 server {
3 listen 9090;
4 server_name 172.24.10.23;
5 location / {
6 root /usr/share/nginx/balanc/;
7 index index.html;
8 access_log /var/log/nginx/rs.access.log main;
9 error_log /var/log/nginx/rs.error.log warn;
10 }
11 }
12 EOF
1 [root@nginx03 ~]# nginx -t -c /etc/nginx/nginx.conf #检查配置文件
2 [root@nginx03 ~]# nginx -s reload #重载配置文件
1 [root@nginx04 ~]# mkdir /usr/share/nginx/balanc/
2 [root@nginx04 ~]# echo '<h1>Rs_172.24.10.24</h1>' > /usr/share/nginx/balanc/index.html
1 [root@nginx04 ~]# cat > /etc/nginx/conf.d/rs.conf <<EOF
2 server {
3 listen 9090;
4 server_name 172.24.10.24;
5 location / {
6 root /usr/share/nginx/balanc/;
7 index index.html;
8 access_log /var/log/nginx/rs.access.log main;
9 error_log /var/log/nginx/rs.error.log warn;
10 }
11 }
12 EOF
1 [root@nginx04 ~]# nginx -t -c /etc/nginx/nginx.conf #检查配置文件
2 [root@nginx04 ~]# nginx -s reload #重载配置文件
3 [root@client ~]# curl 172.24.10.22:9090
4 <h1>Rs_172.24.10.22</h1>
5 [root@client ~]# curl 172.24.10.23:9090
6 <h1>Rs_172.24.10.23</h1>
7 [root@client ~]# curl 172.24.10.24:9090
8 <h1>Rs_172.24.10.24</h1>
3.2 默认轮询方式配置
1 [root@nginx01 ~]# vi /etc/nginx/conf.d/balance.conf
2 upstream mybalance01 {
3 server 172.24.10.22:9090;
4 server 172.24.10.23:9090;
5 server 172.24.10.24:9090;
6 }
7
8 server {
9 listen 80;
10 server_name balance.linuxds.com;
11 access_log /var/log/nginx/mybalance.access.log main;
12 error_log /var/log/nginx/mybalance.error.log warn;
13 location / {
14 proxy_pass http://mybalance01;
15 index index.html;
16 proxy_redirect off;
17 proxy_set_header Host $host;
18 proxy_set_header X-Real-IP $remote_addr;
19 proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
20 client_max_body_size 10m; #允许客户端请求的最大单文件字节数
21 client_body_buffer_size 128k; #缓冲区代理缓冲用户端请求的最大字节数
22 proxy_connect_timeout 300; #nginx跟后端服务器连接超时时间(代理连接超时)
23 proxy_send_timeout 300; #后端服务器数据回传时间(代理发送超时)
24 proxy_read_timeout 300; #连接成功后,后端服务器响应时间(代理接收超时)
25 proxy_buffer_size 4k; #设置代理服务器(nginx)保存用户头信息的缓冲区大小
26 proxy_buffers 4 32k; #proxy_buffers缓冲区,网页平均在32k以下的话,这样设置
27 proxy_busy_buffers_size 64k; #高负荷下缓冲大小(proxy_buffers*2)
28 proxy_temp_file_write_size 64k; #设定缓存文件夹大小,大于这个值,将从upstream服务器传
29 }
30 }
1 [root@balance ~]# nginx -t -c /etc/nginx/nginx.conf #检查配置文件
2 [root@balance ~]# nginx -s reload #重载配置文件
3.3 确认测试

四 加权轮询负载均衡
4.1 环境预设
4.2 加权轮询方式配置
1 [root@balance ~]# vi /etc/nginx/conf.d/balance.conf
2 upstream mybalance01 {
3 server 172.24.9.11:9090 weight=1 max_fails=1 fail_timeout=2;
4 server 172.24.9.12:9090 weight=8 max_fails=2 fail_timeout=2;
5 server 172.24.9.13:9090 backup; #配置为备份服务器
6 }
7
8 server {
9 listen 80;
10 server_name balance.linuxds.com;
11 access_log /var/log/nginx/mybalance.access.log main;
12 error_log /var/log/nginx/mybalance.error.log warn;
13 location / {
14 proxy_pass http://mybalance01;
15 index index.html;
16 proxy_redirect off;
17 proxy_set_header Host $host;
18 proxy_set_header X-Real-IP $remote_addr;
19 proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
20 client_max_body_size 10m;
21 client_body_buffer_size 128k;
22 proxy_connect_timeout 300;
23 proxy_send_timeout 300;
24 proxy_read_timeout 300;
25 proxy_buffer_size 4k;
26 proxy_buffers 4 32k;
27 proxy_busy_buffers_size 64k;
28 proxy_temp_file_write_size 64k;
29 }
30 }
4.3 确认测试
五 最小连接负载均衡
5.1 环境预设
5.2 最小连接方式配置
1 [root@balance ~]# vi /etc/nginx/conf.d/balance.conf
2 upstream mybalance01 {
3 least_conn;
4 server 172.24.10.21:9090;
5 server 172.24.10.22:9090;
6 server 172.24.10.23:9090;
7 }
8
9 server {
10 listen 80;
11 server_name balance.linuxds.com;
12 access_log /var/log/nginx/mybalance.access.log main;
13 error_log /var/log/nginx/mybalance.error.log warn;
14 location / {
15 proxy_pass http://mybalance01;
16 index index.html;
17 }
18 }
5.3 确认测试
六 IP hash负载均衡
6.1 环境预设
6.2 ip hash方式配置
1 [root@balance ~]# vi /etc/nginx/conf.d/balance.conf
2 upstream mybalance01 {
3 ip_hash;
4 server 172.24.10.21:9090;
5 server 172.24.10.22:9090;
6 server 172.24.10.23:9090;
7 }
8
9 server {
10 listen 80;
11 server_name balance.linuxds.com;
12 access_log /var/log/nginx/mybalance.access.log main;
13 error_log /var/log/nginx/mybalance.error.log warn;
14 location / {
15 proxy_pass http://mybalance01;
16 index index.html;
17 }
18 }
6.3 确认测试
七 fair负载均衡
7.1 环境预设
7.2 fair方式配置
1 [root@balance ~]# vi /etc/nginx/conf.d/balance.conf
2 upstream mybalance01 {
3 fair;
4 server 172.24.10.21:9090;
5 server 172.24.10.22:9090;
6 server 172.24.10.23:9090;
7 }
8
9 server {
10 listen 80;
11 server_name balance.linuxds.com;
12 access_log /var/log/nginx/mybalance.access.log main;
13 error_log /var/log/nginx/mybalance.error.log warn;
14 location / {
15 proxy_pass http://mybalance01;
16 index index.html;
17 }
18 }
7.3 确认测试
八 url_hash负载均衡
8.1 环境预设
8.2 ip hash方式配置
1 [root@balance ~]# vi /etc/nginx/conf.d/balance.conf
2 upstream mybalance01 {
3 hash $request_uri;
4 hash_method crc32;
5 server 172.24.10.21:9090;
6 server 172.24.10.22:9090;
7 server 172.24.10.23:9090;
8 }
9
10 server {
11 listen 80;
12 server_name balance.linuxds.com;
13 access_log /var/log/nginx/mybalance.access.log main;
14 error_log /var/log/nginx/mybalance.error.log warn;
15 location / {
16 proxy_pass http://mybalance01;
17 index index.html;
18 }
19 }
8.3 确认测试
012.Nginx负载均衡的更多相关文章
- 对比Haproxy和Nginx负载均衡效果
为了对比Hproxy和Nginx负载均衡的效果,分别在测试机上(以下实验都是在单机上测试的,即负载机器和后端机器都在一台机器上)做了这两个负载均衡环境,并各自抓包分析.下面说下这两种负载均衡环境下抓包 ...
- nginx负载均衡集群
nginx负载均衡集群 0.前言:nginx 负载均衡,属于网络7层模型中的应用层,说白了就是一个代理,要用 upstrem 模块实现,代理则用proxy模块 1.可以针对域名做转发,lvs只能针对 ...
- 手把手教你玩转nginx负载均衡(二)----安装虚拟机操作系统
引言 在上一篇,我们组装好了虚拟机的硬件部分,那么现在我们就要把操作系统装上了,既然是服务器,那么安装linux操作系统是个比较好的选择,如果你喜欢的话,安装windows也是没有任何问题的 我这里选 ...
- nginx负载均衡基于ip_hash的session粘帖
nginx负载均衡基于ip_hash的session粘帖 nginx可以根据客户端IP进行负载均衡,在upstream里设置ip_hash,就可以针对同一个C类地址段中的客户端选择同一个后端服务器,除 ...
- Net分布式系统之二:CentOS系统搭建Nginx负载均衡
一.关于CentOS系统介绍 CentOS(Community Enterprise Operating System,中文意思是:社区企业操作系统)是Linux发行版之一,它是来自于Red Hat ...
- Net分布式系统之三:Keepalived+LVS+Nginx负载均衡之高可用
上一篇写了nginx负载均衡,此篇实现高可用(HA).系统整体设计是采用Nginx做负载均衡,若出现Nginx单机故障,则导致整个系统无法正常运行.针对系统架构设计的高可用要求,我们需要解决Nginx ...
- 配置nginx负载均衡
配置nginx负载均衡 执行命令:vi /usr/local/nginx/sbin/nginx/conf/nginx.conf 修改为: worker_processes 2; events { ...
- 烂泥:nginx负载均衡
本文由秀依林枫提供友情赞助,首发于烂泥行天下. 今天我们来学习下有关nginx的负载均衡配置.nginx的负载均衡是通过nginx的upstream模块和proxy_pass反向代理来实现的. 说明: ...
- nginx负载均衡集群中的session共享说明
在网站使用nginx+php做负载均衡情况下,同一个IP访问同一个页面会被分配到不同的服务器上,如果session不同步的话,就会出现很多问题,比如说最常见的登录状态. 下面罗列几种nginx负载均衡 ...
随机推荐
- 基于SSM框架的新生报到可视化系统
1.本课题的目的及意义 新生报到数据一直是困扰着各大高校的管理性问题,人数多.工作量大,这无疑是一个挑战,也因此加快了高校的信息化建设步伐.随着互联网的普及与发展,日常生活中人们接触到的数据正以惊人的 ...
- Java内存溢出OutOfMemoryError的产生与排查
在java的虚拟机异常中,有两个异常是大家比较关心的,一个是StackOverflowError,另一个是OutOfMemoryError.今天我们就来看看OutOfMemoryError是怎么产生的 ...
- 4.WebPack-Loader
一.什么是Loader WebPack默认只"认识"以*.js结尾的文件,如果想处理其他类型的文件,就必须添加Loader,有各种各样的Loader,每个Loader可处理不同类型 ...
- 《Java核心技术》笔记:第7章 异常、断言和日志
1. 异常 (P 280)异常处理需要考虑的问题: 用户输入错误 设备错误 物理限制 代码错误 (P 280)传统的处理错误的方法是:返回一个特殊的错误码,常见的是返回-1或者null引用 (P 28 ...
- redis基础二----操作set数据类型
set集合是无序的,不能存在重复元素 bbb吃重复元素,是不能添加成功的 2 接下来分析zset,是有序的,你在添加的时候要指定元素的序列号 上面的 3 4 5 6 就是指定的元素的序列号 withs ...
- MyBatis学习笔记(2)--缓存
一.什么是缓存 --存在于内存中的临时数据. 为什么使用缓存?--减少和数据库的交互次数,提高执行效率. 适用于缓存的数据: 1.经常查询并且不经常改变的数据. 2.数据的正确与否对最终结果影响较小的 ...
- ubuntu18.04安装nodejs最新版、指定版 12.x 14.x
今天准备在 ubuntu 服务器里面安装 nodejs 版本,ubuntu 18.04 仓库 nodejs 默认是 8.x 版本. 1. 通过 apt 安装 nodejs 在 Ubuntu 18.04 ...
- xxl-job搭建、部署、SpringBoot集成xxl-job
一.搭建xxl-job 1.下载xxl-job代码 码云地址:https://gitee.com/xuxueli0323/xxl-job gitHub地址:https://github.com/xux ...
- DOM-BOM-EVENT(3)
3.Node常用属性 childNodes 获取所有子节点 <div id="wrap"> <div>1111</div> <div> ...
- Spring 获取单例流程(三)
读完这篇文章你将会收获到 Spring 何时将 bean 加入到第三级缓存和第一级缓存中 Spring 何时回调各种 Aware 接口.BeanPostProcessor .InitializingB ...