推荐-Nginx专题: upstream模块和缓存的简单使用

Nginx专题: upstream模块和缓存的简单使用

nginx 负载均衡

前言:

本文接着上篇Nginx专题: 从编译安装到URL重写来介绍Nginx的负载均衡模块使用方法, 本文的实验没有考虑大多数情况, 例如两个web服务器之间的数据同步等, 主要写Nginx如何作为负载均衡器使用并且缓存

实验拓扑

blob.png

实验环境

主机 IP地址 功用
lb.anyisalin.com 172.16.1.2 负载均衡并缓存静态资源
web1.anyisalin.com 172.16.1.3 提供web服务
web2.anyisalin.com 172.16.1.4 提供web服务

注意: 本文所有操作都在SELinux和iptables关闭的情况下进行

Nginx_Upstream模块介绍

The ngx_http_upstream_module module is used to define groups of servers that can be referenced by the proxy_pass, fastcgi_pass, uwsgi_pass, scgi_pass, and memcached_pass directives. 摘自官方文档

简单来说就是通过upstream模块定义一个服务器组, 可以结合其他代理模块从而提供负载均衡的效果

upstream使用方法

我们这里提供一个最简单的upstream定义方法: 
以下两段简单的配置就能实现最简单的负载均衡效果

upstream servers {
   server 172.16.1.2;
   server 172.16.1.3;
   }

location / {
   proxy_pass http://servers;
   }

upstream的常用参数介绍

upstream name {
   [ip_hash]
   server address [weight=number] [max_fails=number] [fail_timeout=number] [down|up|backup];
   ...
}

#ip_hash: 类似于lvssh算法,将同一IP的请求定向至同一主机
#weight: 权重设置
#max_failsupstream能够自动对各群组中的服务器进行健康状态检查, 这里代表健康状态检查时最多几次连接失败就删除
#fail_timeout:多久超时算失败
#down:将某个主机下线
#backup:将某个主机设置为备份模式, 只要不是所有主机都宕机, 它就不会上线

upstream使用示例

安装nginx的过程这里就不演示了, 有兴趣的可以看我上篇博客

在nginx主配置文件中添加以下几列

http段添加
   upstream servers {
       server 172.16.1.3;
       server 172.16.1.4;
       }

server段添加

   location / {
       proxy_pass http://servers;
   }

重载nginx

看图!我们实现了简单的负载均衡效果,为了演示出效果,所以使用了不同的页面

若水GIF截图_2016年4月7日19点35分7秒.gif

Nginx_Cache介绍

大家都知道在现今的网络世界中, Cache is King,缓存能够为我们减轻服务器的负担和加快响应速度, Nginx_proxy模块能够支持缓存功能, 我们这里使用我们这里缓存静态资源

缓存静态资源

我们在web1 server上有一组静态网页通过负载均衡调度器进行反向代理, 我们在没有设置缓存之前先使用ab进行压力测试

blob.png

proxy_cache_path /cache levels=1:1 keys_zone=mycache:64m;   #http段添加

location /index.html {  #Location段配置
   proxy_pass http://172.16.1.3;
   proxy_cache mycache;    #使用mycache进行缓存
   proxy_cache_valid 200 1d;   #响应码为200的缓存1
   proxy_cache_valid 500 501 502 503 1m;   #响应码为500...的缓存1分钟
   proxy_cache_use_stale error ;   #如果请求源主机的时候出问题, 仍然使用缓存
 }

保存重载

mkdir /cache #创建缓存存放文件夹
chown nginx:nginx /cache  #修改属主和属组为nginx

再次对其进行测试

blob.png

从上面测试可以看出缓存对于静态资源响应的提升是非常明显的

总结

因为时间比较紧,所有本文简单的介绍了Nginx_upstream模块和缓存的使用方法,很多配置参数都没有明确的说明,以后应该还有机会和大家详细说明, Nginx专题还没有结束,敬请期待 
作者: AnyISalIn QQ: 1449472454 
感谢: MageEdu

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

(0)
Net18-AnyISalInNet18-AnyISalIn
上一篇 2016-04-07
下一篇 2016-04-09

相关推荐

  • Linux系统启动基本流程

    Linux开机流程 如下图 00×01、BISO自检     硬件检查,检查硬件完整性,之后从开机BIOS开机硬件列表选择BOOT设备     2. 00×02、MBR引导     从bootloader446…

    2017-07-09
  • Linux进程管理之“四大名捕”

    一、四大名捕 四大名捕,最初出现于温瑞安创作的武侠小说,是朝廷中正义力量诸葛小花的四大徒弟,四人各怀绝技,分别是轻功暗器高手“无情”、内功卓越的高手“铁手”、腿功惊人的“追命”和剑法一流的“冷血”本文四大名捕由linux命令所出演      无情:ps     出演      铁…

    Linux干货 2016-04-25
  • 网络接口Bonding以及网络组

    网络接口Bonding就是将多块网卡绑定同一IP地址对外提供服务,可以实现高可用或者负载均衡。当然,直接给两块网卡设置同一IP地址是不可能的。通过bonding,虚拟一块网卡对外提供连接,物理网卡的被修改为相同的MAC地址。 网络组 :网络组:是将多个网卡聚合在一起方法,从而实现冗错和提高吞吐量。网络组不同于旧版中bonding技术,提供更好的性能…

    Linux干货 2016-11-23
  • 文件系统自动挂载

    什么是文件系统自动挂载?          利用mount在shell终端进行挂载的时,开机自动启动文件文件系统不会自动挂载,我们需要开机的时候自动挂载文件系统,称为文件系统自动挂载 实现Linux自动挂载文件:/etc/fstab Linux中挂载注意事项:  &nb…

    Linux干货 2016-08-29
  • Linux基础知识(五)

    本文主要讲述使用grep做模式匹配,具体示例包括: 1、显示/boot/grub/grub.conf中以至少一个空白字符开头的行; 2、显示/etc/rc.d/rc.sysinit文件中以#开头,后面跟至少一个空白字符,而后又有至少一个非空白字符的行; 3、打出netstat -tan命令执行结果中以‘LISTEN’,后或跟空白字符结尾的行; 4、添加用户b…

    Linux干货 2016-10-23
  • man和history及bashi的快捷键

    man:帮助命令     命令格式:man# cmd;使用时可以先使用whatis 查询所对应的man的章节,然后用对应的man章节来查询帮助;     info:本地帮助文档     官方文档,在线查询等等,如果是付费版系统的话可以使用S…

    Linux干货 2016-07-29