nginx负载均衡实验

实验一、

实验环境:

    1、一台director主机。并部署nginx服务。

       内网iP192.168.1.1  外网iP10.1.64.1

    2、一台后端服务器。并部署httpd服务。并创建两个测试页。

       Vim  /var/www/html/index.html

       Vim  /var/www/html/admin/index.html

实验步骤:

    1、配置director主机,vim  /var/nginx/conf.d/default.conf

        location  /  {

           root  /usr/share/nginx/html;

           proxy_pass  http://192.168.1.2;

           index  index.html  index.htm;

                    }

        

        location  /admin/  {

            proxy_pass  http://192.168.1.2;

                    }

        注意:当proxy_pass http://192.168.1.2;时,用浏览器访问10.1.64.1/admin/时,

          出现的页面是定义在/var/www/html/admin/index.html中的页面。

              proxy_pass http://192.168.1.2/;时,用浏览器访问10.1.64.1/admin/时,

          将被代理服务器代理到后端,显示/var/www/html/index.html中的页面。

    2、将符合条件的URL代理至后端服务器。例如将图片代理至后端。

          location  ~* \.(jpg|peg|gif|png)$  {

            proxy_pass  http://192.168.1.2;

                     }

        /var/www/html/放置一张图片。

   blob.png

实验二、

     proxy_set_header field value;

设定发往后端主机的请求报文的请求首部的值;Context: http, server, location

 通过实验一的实验结果查看后端服务器的httpdaccess.log日志,会发现请求结果全是

 director192.168.1.1请求的。

     blob.png

 

proxy_set_header模块添加上后,可以在后端服务器的日志中记录实际的报文发起者,

而不再记录directorip

配置nginx服务。

    将该模块加入到server

    proxy_set_header X-Real-IP $remote_addr;

          X-Real-IP $remote_addr:面向客户端一侧时,真正发出请求的客户端的ip地址。于

                            将请求直接向后端代理。

配置httpdhttpd.conf配置文件

blob.png 

重启服务,在浏览器中登录网页。查看后端服务器的access.log文件。

blob.png 

 

 

实验三、定义proxy的缓存功能。

1、定义可用于proxy功能的缓存。只可定义于http

   vim  /etc/nginx/nginx.conf

       proxy_cache_path /var/cache/nginx/proxy_cache levels=1:1:1 keys_zone=pxycache:20m max_size=1g;

       定义缓存路径:/var/cache/nginx/proxy_cache

       定义缓存级别:level=1:1:1

       Max_size:目录一共用多大的空间来缓存缓存项

       Keys_zone:

2定义在需要调用缓存功能的配置段例如对图片定义缓存功能。

   Vim default.conf

   location ~* \.(jpg|jpeg|gif|png)$ {

        proxy_pass http://192.168.1.2;

        proxy_cache pxycache;  表示调用此缓存功能。

        proxy_cache_key $request_uri;

        proxy_cache_valid 200 302 301 1h;  对不同的响应码作缓存时长。

        proxy_cache_valid any 1m;  对其他响应码作缓存时长,为1min

    }

4、重启服务。在浏览器中输入10.2.64.1/logo.png第一次响应会有点慢,但是当第一次请

       求成功后,当第二次请求时就会很快了,因为在/var/cache/nginx/porxy_cache目录中已

       经生成了缓存项,可以进入该目录进行验证。

实验四、

定义服务器组

实验环境:

    1、一台director,并配置nginx服务。

      内网ip192.168.1.1  外网ip10.1.64.1

    2、两台后端服务器,分别部署httpd服务,并创建相应的测试页。

       Server1:192.168.1.2    server2:192.168.1.3

实验步骤:

    1、在nginxhttp中定义后端服务器组。

          upstream  webser  {

             Server 192.168.1.2;

             Server 192.168.1.3;

                   }

    2、在default.conf中定义后端引用;

          location  /  {

              proxy_pass  http://webser;

                      }

    3、当在浏览器中测试10.1.64.1时,后端服务器组会以轮询的方式显示页面,实现了

       后端服务器的负载均衡,在生产环境中,服务器组中的页面内容应该是一样的。

blob.png 

    4、测试weight=number   

   upstream  webser  {

             Server 192.168.1.2  weight=2;

             Server 192.168.1.3;

                     }

   当在server 192.168.1.2上加上权重后,server1在被响应时,会根据权重的值来轮询。

blob.png 

5backup

将服务器标记为“备用”,即所有服务器均不可用时此服务器才启用;

        server2主机上部署nginx服务,提供测试页,并将端口修改为8080,因为80端口

已经被httpd服务占用。

    upstream  webser  {

             Server 192.168.1.2  weight=2;

             Server 192.168.1.3;

             Server 192.168.1.38080  buckup;

                      }

    server1server2的主机正常工作时,server3是不会被启用的。只有当server1

Server2都不可用时server3才会被启用。

6、测试hash key

       在之前的两台后端主机上分别创建10个名称相同内容不同的网页,以判断是来自主机

1还是主机2

    upstream  webser  {

                 Server 192.168.1.2  weight=2;

                 Server 192.168.1.3;

                 Server 192.168.1.38080  buckup;

                 hash  $request_uri;

                      }

 

     http://10.1.64.1/test{1..9}.html进行测试

    实现的效果就是:

        把对同一个url的请求,不管是来自哪台主机,都将发往upstream server

 

 

 

 

 

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

(0)
zzdzzd
上一篇 2016-10-30 20:46
下一篇 2016-10-30 21:02

相关推荐

  • N_28 正则表达式的一些基本用法

    1、复制/etc/skel目录为/home/tuser1,要求/home/tuser1及其内部文件的属组和其它用户均没有任何访问权限。 ~]# cp -r /etc/skel /home/tuser1 ~]# chmod -R -g— -o— /home/tuser1 2、编辑/etc/group文件,添加组hadoop。 ~]#vi…

    Linux干货 2017-12-23
  • linux发行版的基础目录名称命名法则及功用规定。

    Linux文件系统:         Linux:glibc标准C库                  &nb…

    Linux干货 2016-10-30
  • Linux磁盘与文件系统管理

    对于一块磁盘,如果我们想要使用的话,需要对磁盘进行分区并建立文件系统。下面,我们就了解一下Linux中的磁盘与文件系统管理 一、MBR 硬盘的0扇区为MBR扇区,其由以下几部分组成: l  主引导程序(偏移地址0000H–0088H),它负责从活动分区中装载,并运行系统引导程序。 l  出错信息数据区,偏移地址0089H&#8…

    Linux干货 2016-08-28
  • 马哥教育网络班20期+第3周课程练习

    1、列出当前系统上所有已经登录的用户的用户名。 注意同一个用户登陆多次,只显示一次即可。    w | cut -d ' ' -f 1 | uniq -c       2、取出最后登陆到当前系统的用户的相关信息    last | head -n 1  &nbsp…

    Linux干货 2016-06-26
  • 关于大型网站技术演进的思考(十四)–网站静态化处理—前后端分离—上(6)

    原文出处: 夏天的森林  前文讲到了CSI技术,这就说明网站静态化技术的讲述已经推进到了浏览器端了即真正到了web前端的范畴了,而时下web前端技术的前沿之一就是前后端 分离技术了,那么在这里网站静态化技术和前后端分离技术产生了交集,所以今天我将讨论下前后端分离技术,前后端分离技术讨论完后,下一篇文章我将会以网站 静态化技术的角度回过头来…

    Linux干货 2015-02-26
  • 软件管理

    ldd   /path/to/binary_file       查看二进制所依赖的库文件 ldconfig  -p  查看已缓存的库文件名和文件路径 配置文件 :/etc/ld.so.conf,   /etc/ld.so.conf.d/*.conf 缓存文件:/etc/ld.so.cac…

    Linux干货 2017-06-11