Nginx负载均衡

基于Nginx的负载均衡以及高可用简单应用

一、负载均衡配置

1、Nginx负载均衡配置

前面配置好的Nginx,可以访问之后,克隆4台,统一配置为512M,因为我的电脑内存是4G的。一台用来访问,一台用来做调度器(Director),两台web服务器(real server),Nginx前面已经介绍过了,故在此简单介绍一下那台Director的配置。

Nginx负载均衡

2、测试

1、定义好hosts文件,访问www.daili.com(负载均衡器的地址)

Nginx负载均衡

3、现在把web2服务器的nginx关掉测试

Nginx负载均衡

看,我的web服务器坏一个也可以正常访问,就是在配置的时候可以用一个共享文件库,使得web集群的资源都一样,用户访问页面获取的信息都一样。

我再启用web2,又可以看到web2了。

二、Nginx负载均衡核心组件介绍:upstrem模块

1、upstream模块

ngx_http_upstream_module模块允许Nginx定义一组或者多组节点服务器组,可以通过proxypass代理方式把网站请求发送到实现定义好的upstream组的名字上。具体写法:http://www_server_pools

2、权重,我们把web2的权重改成2试试

Nginx负载均衡

访问出现出现web1和web2的比率是1:2

3、比较完整的upstream配置案例

upstream blog_server_pool {
    server 10.0.10.6:80 weight=1 max_fails=1 fail_timeout=10s
        }
含义:

server 10.0.10.6:80  RS配置:可以是ip或域名,如果端口不写,默认是80,如果是域名,要通过dns做负载均衡。

weight=1  权重

max_fails Nginx尝试连接后端主机失败的次数,这个数值是配合proxy_next_upstream、fastcgi_next_upstream和memcached_next_upstream这三个参数来使用的,当Nginx接受后端服务器返回这三个参数定义的状态码时,会将这个请求转发给正常工作的后端服务器,例如404、502、503.Max_fails的默认值是1:企业场景下建议是2~3。京东是1次,蓝汛10次,根据业务需求去配置。

backup 热备配置(RS节点的高可用),当前面激活的RS都失败后会自动启用热备RS。这标志着这个服务器作为备份服务器,如果主服务器全部坏了,就会向它转发请求,注意,当负载调度算法为ip_hash时,后端服务器在负载均衡调度中的状态就不能是weight和backup了。

fail_timeout=10s 在max_fails定义失败次数后,距离下次检查的间隔时间、默认是10s;如果max_fails是5,就检查5次,如果5ci都是502,那么它就会根据fail_timeout的值,等待10s再去检查一次。

down 标志着服务器永远不可用,配合ip_hash使用。

4、Nginx代理Cache服务,可能要使用hash算法,此时如果主服务器坏了,就要通过设置down参数确保客户端用户按照当前的hash算法访问。

upstream backend {
    ip_hash;
    server 192.168.1.123;
    server 192.168.1.124 down;
    }

5、Haproxy负载均衡器server的配置示例

server php_server_1 10.12.25.68:80 cookie 1 check inter 2000 rize 3 fall weight 2

server php_server_bak 10.12.25.79:80 cookie 3 check inter 1500 rise 3 fall 3 backup

weight 权重
check 开启对服务器的健康检查
inter 设置连续两次的健康检查间隔时间,单位是毫秒,默认是2000
rise 指定多少次连续成功的健康检查后,即可认定该服务器处于可用状态
fall 指定多少次检查不健康后,则认为服务器处于坏的 默认是3
maxconn 指定可被发送到该服务器的最大并发连接数

更加具体的可以参考官方文档

6、upstream模块调度算法

(1)rr:轮巡,默认调度算法,静态

(2)wrr:权重轮巡,静态

(3)ip_hash 静态:每个请求按客户端IP的hash结果分配,当新的请求到达时,先会将其客户端IP通过哈希算法哈希出一个值,在随后的客户请求中,客户IP的哈希值只要相同,就会分配到同一台服务器,该调度算法可以解决动态网页的session共享问题,但有时会导致分配不均。

(4)fair:动态调度算法 此算法根据后端服务器的响应时间来分配请求,响应时间短的优先分配,智能,要使用这种调度算法必须先下载upstream_fair。

upstream cwj_db {
    server 192.168.1.123;   
    server 192.168.1.124;
    fair;
    }

(5)least_conn 动态 根据后端节点的连接数来决定分配情况,哪个机器少就分发给谁

(6)url_hash算法 与ip_hash类似,根据访问URL的hash结果来分配请求,让每个URL定向到同一个后端服务器,后端服务器为缓存服务器时效果显著,如果需要使用这种调度算法,必须要安装Nginx的hash模块软件包

三、Nginx负载均衡核心组件介绍:proxy_pass模块

1、简单实用案例

1)、将匹配URI为name的请求抛给http://172.0.0.1/remote/

location /name/ {
proxy_pass http://127.0.0.1/remote/;
            }

2)、将匹配URI为some/path的请求抛给http://127.0.0.1

location /some/path {
proxy_pass http://127.0.0.1;
            }

3)、将匹配URI为name的请求用指定的rewrite规则,然后抛给http://127.0.0.1

loaction /name/ {
    rewrite /name/ ([^/]+)  /usersname=$1 break;
    proxy_pass http://127.0.0.1;
}

2、模块参数

通常配置完后,再最后加上proxysetheader Host $host;若后端有多个虚拟主机,它就可以识别代理的是哪个虚拟主机了,很关键。

13.jpg

原创文章,作者:N24_yezi,如若转载,请注明出处:http://www.178linux.com/65267

(1)
N24_yeziN24_yezi
上一篇 2016-12-29 18:09
下一篇 2016-12-29 23:21

相关推荐

  • N25-第十二周博客作业

    1、请描述一次完整的http请求处理过程; (1) 建立或处理连接:接收请求或拒绝请求;(2) 接收请求:接收来自于网络上的主机请求报文中对某特定资源的一次请求的过程;(3) 处理请求:对请求报文进行解析,获取客户端请求的资源及请求方法等相关信息;(4) 访问资源:获取请求报文中请求的资源;从磁盘中获取(5) 构建响应报文:(6) 发送响应报文:(7) 记录…

    Linux干货 2017-04-09
  • M20-1 8月3号 ACL访问控制列表

    一、acl简介:   access control list,用于实现灵活的权限管理,除了文件的所有者,所属组和其他人,可以对更多的用户设置权限,而acl生效的顺序是所有者,自定义用户组,自定义组,其他人。 二、ACL的设置技巧:   getfacl:取得某个文件/目录的ACL设置项目   setfacl:设置某个目录/文件的A…

    Linux干货 2016-08-08
  • LVM——如何让你的磁盘空间可大可小

    逻辑卷管理器(LVM) 允许对卷进行方便操作的抽象层,包括重新设定文件系统的大小 允许在多个物理设备间重新组织文件系统          将设备指定为物理卷          用一个或者多个物理卷来创…

    Linux干货 2016-08-29
  • 用户,组和权限管理 基础命令整理

    安全3A任何一个安全策略都应该有Authentication(认证)、Authentication(授权)、Accouting|Audition(审计)这三个措施。 用户(User)Linux用户是安全3A中的Authentication(认证)措施。用户在登录时,系统会检查用户输入的用户名和密码。如果用户输入的用户名和密码匹配,会根据用户信息给用户分配一个…

    Linux干货 2017-03-16
  • FHS-文件系统层级结构标准

    文件系统层级结构标准(FHS:Filesystem Hierarchy Standard) 文件系统层次结构标准(英语:Filesystem Hierarchy Standard,FHS)定义了Linux操作系统中的主要目录及目录内容。当前的版本是2.3,在2004年1月29日公布。多数Linux发行版遵从FHS标准并且声明其自身政策以维护FHS的要求。然而…

    Linux干货 2016-10-16
  • Redis的编译安装

    介绍     redis是一个key-value存储系统。和Memcached类似,它支持存储的value类型相对更多,包括string(字符串)、list(链表)、set(集合)、zset(sorted set –有序集合)和hash(哈希类型)。这些数据类型都支持push/pop、add/remove及取交集并集和差集及更…

    Linux干货 2015-02-28