nginx+tomcat反向代理 负载均衡器 实现web缓存

本文详细介绍了如何使用nginx作为反向代理和负载均衡器,结合tomcat实现web服务的高可用性。讲解了nginx的安装、配置虚拟主机、反向代理以及负载均衡设置,同时探讨了nginx的负载均衡高可用方案——keepalived+nginx主备模式。

1      课程目bi

 掌握nginx+tomcat反向代理的使用方法。
掌握nginx作为负载均衡器的使用方法。
掌握nginx实现web缓存方法。

掌握nginx+tomcat反向代理的使用方法。

掌握nginx作为负载均衡器的使用方法。

掌握nginx实现web缓存方法。

2      nginx介绍

2.1    什么是nginx

         Nginx是一款高性能的http 服务器/反向代理服务器及电子邮件(IMAP/POP3)代理服务器。官方测试nginx能够支支撑5万并发链接,并且cpu、内存等资源消耗却非常低,运行非常稳定。

        

3      nginx安装

3.1    下载

 

进入http://nginx.org/en/download.html 下载nginx1.8.0版本(当前最新稳定版本)。

 

1.1    安装

1.1.1 nginx安装环境

         nginx是C语言开发,建议在linux上运行,本教程使用Centos6.5作为安装环境。

n  gcc

         安装nginx需要先将官网下载的源码进行编译,编译依赖gcc环境,如果没有gcc环境,需要安装gcc:yum install gcc-c++

n  PCRE

         PCRE(PerlCompatible Regular Expressions)是一个Perl库,包括 perl 兼容的正则表达式库。nginx的http模块使用pcre来解析正则表达式,所以需要在linux上安装pcre库。

yuminstall -y pcre pcre-devel

注:pcre-devel是使用pcre开发的一个二次开发库。nginx也需要此库。

n  zlib

         zlib库提供了很多种压缩和解压缩的方式,nginx使用zlib对http包的内容进行gzip,所以需要在linux上安装zlib库。

yuminstall -y zlib zlib-devel

 

n  openssl

         OpenSSL是一个强大的安全套接字层密码库,囊括主要的密码算法、常用的密钥和证书封装管理功能及SSL协议,并提供丰富的应用程序供测试或其它目的使用。

         nginx不仅支持http协议,还支持https(即在ssl协议上传输http),所以需要在linux安装openssl库。

yuminstall -y openssl openssl-devel

 

1.1.2 编译安装

将nginx-1.8.0.tar.gz拷贝至linux服务器。

 

解压:

tar -zxvf nginx-1.8.0.tar.gz

cd nginx-1.8.0

 

1、  configure

./configure --help查询详细参数(参考本教程附录部分:nginx编译参数)

 

参数设置如下:

./configure \

--prefix=/usr/local/nginx \

--pid-path=/var/run/nginx/nginx.pid \

--lock-path=/var/lock/nginx.lock \

--error-log-path=/var/log/nginx/error.log \

--http-log-path=/var/log/nginx/access.log \

--with-http_gzip_static_module \

--http-client-body-temp-path=/var/temp/nginx/client\

--http-proxy-temp-path=/var/temp/nginx/proxy\

--http-fastcgi-temp-path=/var/temp/nginx/fastcgi\

--http-uwsgi-temp-path=/var/temp/nginx/uwsgi\

--http-scgi-temp-path=/var/temp/nginx/scgi

 

注意:上边将临时文件目录指定为/var/temp/nginx,需要在/var下创建tempnginx目录

mkdir -p /var/temp/nginx

 

2、  编译安装

make

make  install

 

安装成功查看安装目录:

 

 

1.2    启动nginx

cd /usr/local/nginx/sbin/

./nginx

 

查询nginx进程:

 

15098是nginx主进程的进程id,15099是nginx工作进程的进程id

 

注意:执行./nginx启动nginx,这里可以-c指定加载的nginx配置文件,如下:

./nginx-c /usr/local/nginx/conf/nginx.conf

如果不指定-c,nginx在启动时默认加载conf/nginx.conf文件,此文件的地址也可以在编译安装nginx时指定./configure的参数(--conf-path= 指向配置文件(nginx.conf))

 

1.3    停止nginx

方式1,快速停止:

cd /usr/local/nginx/sbin

./nginx -s stop

此方式相当于先查出nginx进程id再使用kill命令强制杀掉进程。

 

方式2,完整停止(建议使用):

cd /usr/local/nginx/sbin

./nginx -s quit

此方式停止步骤是待nginx进程处理任务完毕进行停止。

 

 

1.4    重启nginx

方式1,先停止再启动(建议使用):

对nginx进行重启相当于先停止nginx再启动nginx,即先执行停止命令再执行启动命令。

如下:

./nginx -s quit

./nginx

 

方式2,重新加载配置文件:

当nginx的配置文件nginx.conf修改后,要想让配置生效需要重启nginx,使用-s reload不用先停止nginx再启动nginx即可将配置信息在nginx中生效,如下:

./nginx -s reload

 

3.6    安装测试

nginx安装成功,启动nginx,即可访问虚拟机上的nginx:


到这说明nginx基本上安装成功。

1      Nginx的rpm软件包安装

1.1    安装包在位置

D:\讲课内容--\新巴巴运动网\nginx高并发解决\nginx安装包

D:\讲课内容--\新巴巴运动网\nginx高并发解决\nginx安装包

1.1    此种安装方式不用安装gcc等编译工具

1.2    安装命令如下

rpm –ivh nginx

2      配置虚拟主机

2.1    什么是虚拟主机

         虚拟主机是一种特殊的软硬件技术,它可以将网络上的每一台计算机分成多个虚拟主机,每个虚拟主机可以独立对外提供www服务,这样就可以实现一台主机对外提供多个web服务,每个虚拟主机之间是独立的,互不影响的。

 

如下图:


通过nginx可以实现虚拟主机的配置,nginx支持三种类型的虚拟主机配置,1、基于ip的虚拟主机, 2、基于域名的虚拟主机 3、基于端口的虚拟主机

1.1    基于域名的虚拟主机配置

1.1.1 需求

两个域名指向同一台服务器,用户访问不同的域名显示不同的网页内容。

两个域名是aaa.test.com和bbb.test.com

一台服务器还使用虚拟机192.168.101.3代替

1.1.2 创建工程目录

创建/usr/local/aaa_html,此目录为aaa.test.com域名访问的目录

创建/usr/local/bbb_html,此目录为bbb.test.com域名访问的目录

 

目录中的内容使用nginx自带的html文件,将/usr/local/nginx/html中的内容拷贝分别拷贝到上边两个目录中,并且将aaa_html目录中的index.html内容改为:“Welcome to aaa nginx!”

将bbb_html目录中的index.html内容改为“Welcome to bbb nginx!”

 

1.1.3 虚拟主机配置

修改/usr/local/nginx/conf/nginx.conf文件,添加两个虚拟主机,如下:

#配置虚拟主机aaa.test.com

server {

                   #监听的ip和端口,配置本机ip和端口

       listen 192.168.101.3:80;         

                   #虚拟主机名称是aaa.test.com,请求域名aaa.test.com的url将由此server配置解析

       server_name aaa.test.com;  

                   #所有的请求都以/开始,所有的请求都可以匹配此location

       location / {

                   #使用root指令指定虚拟主机目录即网页存放目录

                   #比如访问http://ip/test.html将找到/usr/local/aaa_html/test.html

                   #比如访问http://ip/item/test.html将找到/usr/local/aaa_html/item/test.html

                root /usr/local/aaa_html;       

                                #指定欢迎页面,按从左到右顺序查找

                index index.html index.htm;   

       }

    }

 

#配置虚拟主机bbb.test.com

   server {

       listen 192.168.101.3:80;

       server_name bbb.test.com;

       location / {

                root /usr/local/bbb_html;

                index index.html index.htm;

       }

    }

 

 

2      nginx反向代理

2.1    什么是反向代理

         通常的代理服务器,只用于代理内部网络对Internet的连接请求,客户机必须指定代理服务器,并将本来要直接发送到Web服务器上的http请求发送到代理服务器中由代理服务器向Internet上的web服务器发起请求,最终达到客户机上网的目的。

         而反向代理(ReverseProxy)方式是指以代理服务器来接受internet上的连接请求,然后将请求转发给内部网络上的服务器,并将从服务器上得到的结果返回给internet上请求连接的客户端,此时代理服务器对外就表现为一个反向代理服务器。

 

如下图:

1.1    nginx+tomcat反向代理

1.1.1 需求

         两个tomcat服务通过nginx反向代理,本例子使用三台虚拟机进行测试,

         nginx服务器:192.168.101.3

         tomcat1服务器:192.168.101.5

         tomcat2服务器:192.168.101.6

如下图:

1.1.1 启动tomcat

         tomcat使用apache-tomcat-7.0.57版本,在192.168.101.5和192.168.101.6虚拟机上启动tomcat。

 

1.1.2 nginx反向代理配置

根据上边的需求在nginx.conf文件中配置反向代理,如下:

 

#配置一个代理即tomcat1服务器

upstream tomcat_server1 {

           server 192.168.101.5:8080;

       }

#配置一个代理即tomcat2服务器

   upstream tomcat_server2 {

           server 192.168.101.6:8080;

       }

 

#配置一个虚拟主机

    server{

       listen 80;

       server_name aaa.test.com;

       location / {

                                     #域名aaa.test.com的请求全部转发到tomcat_server1即tomcat1服务上

                proxy_passhttp://tomcat_server1;

                                     #欢迎页面,按照从左到右的顺序查找页面

                index index.jsp index.htmlindex.htm;

       }

 

    }

 

   server {

       listen 80;

       server_name bbb.test.com;

 

       location / {

                                      #域名bbb.test.com的请求全部转发到tomcat_server2即tomcat2服务上

                  proxy_passhttp://tomcat_server2;

                  index index.jsp index.htmlindex.htm;

       }

    }

 

1.1.3 测试

分别修改两个tomcat下的webapps/ROOT/index.jsp的内容,使用tomcat1和tomcat2两个服务首页显示不同的内容,如下:

tomcat1下的index.jsp修改后:

tomcat2下的index.jsp修改后:

分别访问aaa.test.com、bbb.test.com测试反向代理。

 

请求访问aaa.test.com通过nginx代理访问tomcat1,请求访问bbb.test.com通过nginx代理访问tomcat2。

 

 

1      负载均衡

1.1    什么是负载均衡

         负载均衡 建立在现有网络结构之上,它提供了一种廉价有效透明的方法扩展网络设备和服务器的带宽、增加吞吐量、加强网络数据处理能力、提高网络的灵活性和可用性。

         负载均衡,英文名称为LoadBalance,其意思就是分摊到多个操作单元上进行执行,例如Web服务器、FTP服务器、企业关键应用服务器和其它关键任务服务器等,从而共同完成工作任务。

1.2    nginx实现负载均衡

1.2.1 需求

         nginx作为负载均衡服务器,用户请求先到达nginx,再由nginx根据负载配置将请求转发至 tomcat服务器。

         nginx负载均衡服务器:192.168.101.3

         tomcat1服务器:192.168.101.5

         tomcat2服务器:192.168.101.6

1.1.1 配置

根据上边的需求在nginx.conf文件中配置负载均衡,如下:

 

upstream tomcat_server_pool{

       server 192.168.101.5:8080 weight=10;

       server 192.168.101.6:8080 weight=10;

       }

 

   server {

       listen 80;

       server_name aaa.test.com;

       location / {

                 proxy_passhttp://tomcat_server_pool;

                 index index.jsp index.htmlindex.htm;

       }

    }

 

1.1.2 测试

请求aaa.test.com,通过nginx负载均衡,将请求转发到tomcat服务器。

通过观察tomcat的访问日志或tomcat访问页面即可知道当前请求由哪个tomcat服务器受理。

 

 

2      nginx负载均衡高可用

2.1    什么是负载均衡高可用

         nginx作为负载均衡器,所有请求都到了nginx,可见nginx处于非常重点的位置,如果nginx服务器宕机后端web服务将无法提供服务,影响严重。

         为了屏蔽负载均衡服务器的宕机,需要建立一个备份机。主服务器和备份机上都运行高可用(High Availability)监控程序,通过传送诸如“I am alive”这样的信息来监控对方的运行状况。当备份机不能在一定的时间内收到这样的信息时,它就接管主服务器的服务IP并继续提供负载均衡服务;当备份管理器又从主管理器收到“I am alive”这样的信息时,它就释放服务IP地址,这样的主服务器就开始再次提供负载均衡服务。

 

 

 

2.2    keepalived+nginx实现主备

2.2.1 什么是keepalived

         keepalived是集群管理中保证集群高可用的一个服务软件,用来防止单点故障。

        Keepalived的作用是检测web服务器的状态,如果有一台web服务器死机,或工作出现故障,Keepalived将检测到,并将有故障的web服务器从系统中剔除,当web服务器工作正常后Keepalived自动将web服务器加入到服务器群中,这些工作全部自动完成,不需要人工干涉,需要人工做的只是修复故障的web服务器。

 

2.2.2 keepalived工作原理

         keepalived是以VRRP协议为实现基础的,VRRP全称VirtualRouter Redundancy Protocol,即虚拟路由冗余协议。

         虚拟路由冗余协议,可以认为是实现路由器高可用的协议,即将N台提供相同功能的路由器组成一个路由器组,这个组里面有一个master和多个backup,master上面有一个对外提供服务的vip(该路由器所在局域网内其他机器的默认路由为该vip),master会发组播,当backup收不到VRRP包时就认为master宕掉了,这时就需要根据VRRP的优先级来选举一个backup当master。这样的话就可以保证路由器的高可用了。

         keepalived主要有三个模块,分别是core、check和VRRP。core模块为keepalived的核心,负责主进程的启动、维护以及全局配置文件的加载和解析。check负责健康检查,包括常见的各种检查方式。VRRP模块是来实现VRRP协议的。

 

详细参考:Keepalived权威指南中文.pdf

 

2.2.3 keepalived+nginx实现主备过程

 

2.2.3.1初始状态


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

yue31313

感谢打赏,继续分享,给您帮忙。

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值