注意:nginx自带的http服务后端检测有缺陷,无法根据状态码来检测,建议使用tengine的nginx_upstream_check_module来实现后端服务的http健康状态检测

(1)负载均衡简介

作用:提升吞吐率,提升请求性能,提高容灾
负载均衡按层级划分
四层负载均衡:ip+tcp端口,
七层负载均衡:处理http层,例如根据主机地址调度
nginx实现负载均衡用到了proxy_pass代理模块核心配置,将客户端请求代理转发至一组upstream虚拟服务池
ngx_http_proxy_module //proxy代理模块
ngx_http_upstream_module //负载均衡模块,可以实现网站的负载均衡功能及节点的健康检查。nginx自带的健康状态不好用

(2)负载均衡基本实现

0.语法和例子

upstrem name { .... }
必须要配置http标签之内和server标签之外



1.web服务器配置

#vim /usr/local/nginx/conf/nginx.conf
server {
listen 8001;
root /webroot/node1;
index index.html;
}
server {
listen 8002;
root /webroot/node2;
index index.html;
}
server {
listen 8003;
root /webroot/node3;
index index.html;
}
#nginx -t
#mkdir -pv /webroot/{node1,node2,node3}
#echo "node1" >>/webroot/node1/index.html
#echo "node2" >>/webroot/node2/index.html
#echo "node3" >>/webroot/node3/index.html
#nginx -s reload

2.代理服务器配置

#vim /usr/local/nginx/conf
http {
include /usr/local/nginx/conf.d
}
#vim /usr/local/nginx/conf.d/www.test.com.conf
upstream node {
server 192.9.191.31:8001;
server 192.9.191.31:8002;
server 192.9.191.31:8003;
}
server {
listen 80;
server_name www.test.com;
location / {
proxy_pass http://node;
}
}
#nginx -t
#nginx -s reload

3.修改hosts文件以及测试

#vim /etc/hosts
192.9.191.30 www.test.com
# curl http://192.9.191.30
node2
# curl http://192.9.191.30
node3
# curl http://192.9.191.30
node1

(3)upstream参数

1.参数详解

server 1.1.1.1:80	\\负载均衡后面的RS配置,可以是IP或域名,端口不写,默认是80端口,高并发场景ip要换成域名,通过dns做负载均衡
weight \\权重,默认为1,权重大接受的请求越多
max_fails=2 \\最大尝试次数监测后端服务是否正常,默认根据端口检查,默认为1,0表示禁止失败尝试,
backup \\预留的备份服务器,当前面激活的real server都失败后会自动启用该服务器
fail_timeout=20s \\失败超时时间,默认是10s。根据业务需求去配置,常规业务2-3秒合理,失败之后,20秒之后在检测服务是否正常
down \\这标志着服务器永远不可用
max_conns=10 \\最大并发连接数,超过10个连接无法访问;保护节点
slow_start=10s \\后端服务器由down转为up,加入到集群的时间
server x.x.x.x:80 max_fails=2 fail_timeout=20s; \\ 每隔20秒钟检测后端服务是否正常2次,如果后端服务down机,自动切换到其它正常机器,如果后端机器由down改成up状态,又自动加入到web集群中

2.配置案例

#vim /usr/local/nginx/conf.d/www.test.com.conf
upstream node {
server 192.9.191.31:8001 down;
server 192.9.191.31:8002 backup;
server 192.9.191.31:8003 max_fail=1 fail_timeout=10s;
}
server {
listen 80;
server_name www.test.com;
location / {
proxy_pass http://node;
}
}

(4)upstream调度算法

1.调度算法详解

rr轮询      \\按时间顺序逐一分配到不同的后端服务器,默认调度算法
weight \\加权轮询,weight值越大,分配到访问几率越大
ip_hash \\同一个ip请求web服务器,第一次扔给一台服务器,下次同一个ip都会扔给同一台服务器,可以解决动态网页session共享问题,但是会破坏负载均衡,请求分配不均,最大的问题是NAT;建议不要使用ip_hash方式,使用redis方式进行会话共享;
fair \\第三方动态算法,按照后端服务器RS的响应时间来分配请求,响应时间短的优先分配
url_hash \\按访问url的hash结果来分配请求,让每个url定向到同一个后端服务器,url_hash和ip_hash类似,url_hash用于web缓存,ip_hash用于会话保持,例如www.baidu.com/1.html和www.baidu.com/index.html这两个url会分配不同的后端服务器,一定要记录url包含请求的资源例如index.html等
一直性hash \\淘宝tengine,
least_conn \\最少连接数

2.weight加权配置案例

upstream  node {
server 192.9.191.31:8001;
server 192.9.191.31:8002 weight=5;
}

3.ip_hash配置案例

upstream  node {
ip_hash;
server 192.9.191.31:8001;
server 192.9.191.31:8002;
}

4.url_hash配置案例,注意低版本的nginx不支持

upstream  node {
hash $request_uri;
server 192.9.191.31:8001;
server 192.9.191.31:8002;
}

nginx的http负载均衡的更多相关文章

  1. nginx安装及负载均衡配置

    Nginx (“engine x”) 是一个高性能的 HTTP 和 反向代理 服务器,也是一个 IMAP/POP3/SMTP 代理服务器. Nginx 是由 Igor Sysoev 为俄罗斯访问量第二 ...

  2. Nginx 简单的负载均衡配置示例(转载)

    原文地址:Nginx 简单的负载均衡配置示例(转载) 作者:水中游于 www.s135.com 和 blog.s135.com 域名均指向 Nginx 所在的服务器IP. 用户访问http://www ...

  3. 观nginx与lvs负载均衡的较量

    在技术工作者中,常用到的就是lvs负载均衡和Nginx负载均衡了.这两者也是比较普及的.那么,根据不同的需求,两者存在着不同的优势.具体选择哪一个,还要看您的要求了.那么我们在此为大家分享一篇文章,对 ...

  4. 如何使用Weave以及Docker搭建Nginx反向代理/负载均衡服务器

    Hi, 今天我们将会学习如何使用 Weave 和 Docker 搭建 Nginx 的反向代理/负载均衡服务器.Weave 可以创建一个虚拟网络将 Docker 容器彼此连接在一起,支持跨主机部署及自动 ...

  5. Nginx+Tomcat+Memcached负载均衡集群服务搭建

    操作系统:CentOS6.5  本文档主要讲解,如何在CentOS6.5下搭建Nginx+Tomcat+Memcached负载均衡集群服务器,Nginx负责负载均衡,Tomcat负责实际服务,Memc ...

  6. 基于nginx的tomcat负载均衡和集群

    要集群tomcat主要是解决SESSION共享的问题,因此我利用memcached来保存session,多台TOMCAT服务器即可共享SESSION了. 你可以自己写tomcat的扩展来保存SESSI ...

  7. nginx+tomcat+redis负载均衡及session共享

    概述 本文档是用来详细描述 nginx+tomcat+redis负载均衡实现session共享 所需软件及下载地址 软件名称 下载地址 功能说明 Nginx-v1.6.0 http://nginx.o ...

  8. Nginx 简单的负载均衡配置示例

    http://www.cnblogs.com/xiaogangqq123/archive/2011/03/02/1969006.html 在此记录下Nginx服务器nginx.conf的配置文件说明, ...

  9. Nginx+Tomcat7+Mencached负载均衡集群部署笔记

    Nginx+Tomcat+Memcached负载均衡集群服务搭建 操作系统:CentOS6.5 本文档主要解说,怎样在CentOS6.5下搭建Nginx+Tomcat+Memcached负载均衡集群s ...

  10. windows使用nginx+memcached实现负载均衡和session或者缓存共享

    windows使用nginx+memcached实现负载均衡和session或者缓存共享 两台server server1:115.29.186.215 windows2008 64位操作系统 ser ...

随机推荐

  1. JS this的指向

    总结:this指向调用函数的那个对象. 在不同的应用场景this的指向有所不同,但细细思考都符合总结的意思. 场景一:一般的函数调用 这种常见的函数调用方式this指向的是window,因为相当于是w ...

  2. web开发环境和要求配置

    对于eclipse,有很多版本,但要开发WEB程序,需要用到j2ee版本,如果是winform或android 用不带ee的版本就行,两者的明显区别是在看帮助->关于->Eclipse J ...

  3. SqlDataAdapter 用法详解

    SqlCommand是sql命令,执行后通过sqlDataAdapter返回填入DataSet SqlDataAdapter   有不同的构造函数, SqlDataAdapter(SqlCommand ...

  4. Fragment+ViewPager实现仿微信点击和滑动切换界面

    这是在我写的新闻App中实现的界面切换 贴出切换界面的主要代码: xml代码: <span style="font-size:14px;"> <android.s ...

  5. iOS tag的使用

    一.添加标记 (标记不能为0) UIButton *backBtn = [[UIButton alloc] initWithFrame:CGRectMake(,,,)]; backBtn.backgr ...

  6. 多线程复习 Rlock ,Condition,Semaphore

    #对于io操作来说,多线程和多进程性能差别不大 #1.通过Thread类实例化 import time import threading def get_detail_html(url): print ...

  7. 【转载】Lua脚本语法说明(修订)

    原文:http://www.cnblogs.com/ly4cn/archive/2006/08/04/467550.html 挑出来几个 .逻辑运算 and, or, not 其中,and 和 or ...

  8. 【洛谷 P1707】 刷题比赛 (矩阵加速)

    题目连接 很久没写矩阵加速了,复习一下,没想到是一道小毒瘤题. 状态矩阵\(a[k],b[k],c[k],a[k+1],b[k+1],c[k+1],k,k^2,w^k,z^k,1\) 转移矩阵 0, ...

  9. Remmarguts' Date(POJ2449+最短路+A*算法)

    题目链接:http://poj.org/problem?id=2449 题目: 题意:求有向图两点间的k短路. 思路:最短路+A*算法 代码实现如下: #include <set> #in ...

  10. bzoj 2434 fail tree+dfs序

    首先比较明显的是我们可以将字符串组建立ac自动机,那么对于询问s1字符串在s2字符串中出现的次数,就是在以s1结尾为根的fail tree中,子树有多少个节点是s2的节点,这样我们处理fail tre ...