JK整合Apache HTTP Server 与 Tomcat

一、为何要将Apache HTTP Server 与 Tomcat 结合

 

      首先我们先介绍一下为什么要让 Apache 与 Tomcat 之间进行连接。事实上 Tomcat 本身已经提供了 HTTP 服务,该服务默认的端口是 8080,装好 tomcat 后通过 8080 端口可以直接使用 Tomcat 所运行的应用程序,你也可以将该端口改为 80。

 

      既然 Tomcat 本身已经可以提供这样的服务,我们为什么还要引入 Apache 或者其他的一些专门的 HTTP 服务器呢?原因有下面几个:

 

      1). 提升对静态文件的处理性能

      2). 利用 Web 服务器来做负载均衡以及容错

      3). 无缝的升级应用程序

 

      这三点对一个 web 网站来说是非常之重要的,我们希望我们的网站不仅是速度快,而且要稳定,不能因为某个 Tomcat 宕机或者是升级程序导致用户访问不了,而能完成这几个功能的、最好的 HTTP 服务器也就只有 apache 的 http server 了,它跟 tomcat 的结合是最紧密和可靠的。

 

 

二、JK简介


      JK 本身有两个版本分别是 1 和 2,目前 1 最新的版本是 1.2.19,而版本 2 早已经废弃了,以后不再有新版本的推出了,所以建议你采用版本 1。


      注意JK的每个版本都对应一个apache版本。Jk下载可以直接到apache.org官网下载,有多种版本,适用于各种操作系统,地址如下:http://www.apache.org/dist/tomcat/tomcat-connectors/jk/binaries/
      本文以 win32/jk-1.2.28/mod_jk-1.2.28-httpd-2.2.3.so 为例


      下载完JK的so模块后,放在${APACHE_HOME} \modules\mod_jk.so

 

       jk与apahce的版本要匹配,否则apache启动会失败:

  • mod_jk-1.2.31-httpd-2.2.3.so  is for Apache 2.2.x. It has been build against version 2.2.3, but should work with Apache 2.2.0 and later. Rename tomod_jk.so  before putting it in your Apache2.2/modules directory or adjust your LoadModule  statement.
  • mod_jk-1.2.31-httpd-2.0.52.so  is for Apache 2.0.x. It has been build against version 2.0.52, and should work with Apache 2.0.52 and later. Rename to mod_jk.so  before putting it in your Apache2.0/modules directory or adjust your LoadModule  statement.

 

三、整合配置

 

    3.1. JK 的配置最关键的有三个文件,分别是

         httpd.conf 
        Apache 服务器的配置文件,用来加载 JK 模块以及指定 JK 配置文件信息

     下边在(apache安装目录\conf\)下增加tomcat目录,在tomcat目录下新建workers.properties、
         uriworkermap.properties


        这里说明一下,workers.properties这个文件是配置jk模块与tomcat通信地址,以及一些约定
uriworkermap.properties 是配置哪些文件由apache http server 处理,哪些由tomcat处理,你也可以在httpd.conf配置下边的内容,但是由于这些属性是jk模块所独有的,为了让我们更改配置后不重新启动apache http server,这里分开配置。

 

         workers.properties

              到 Tomcat 服务器的连接定义文件

         uriworkermap.properties
             URI 映射文件,用来指定哪些 URL 由 Tomcat 处理,你也可以直接在 httpd.conf 中配置这些 URI,

         但是独立这些配置的好处是 JK 模块会定期更新该文件的内容,使得我们修改配置的时候无需重新启动

         Apache 服务器。

 

       3.1.1 http.conf的典型配置

 

# (httpd.conf)


# 加载 mod_jk 模块
LoadModule jk_module modules/mod_jk.so

# Configure mod_jk

JkWorkersFile conf/workers.properties
JkMountFile conf/uriworkermap.properties
JkLogFile logs/mod_jk.log
JkLogLevel warn

 

       3.1.2 works.properties配置

 

       如果不需要做负载均衡使用以下配置

 

# workers.properties

# list the workers by name

worker.list=s1, status

# localhost server 1
# ------------------------
worker.s1.port=8009
worker.s1.host=localhost
worker.s1.type=ajp13
worker.status.type=status

    无负载均衡的jkstatus的管理页面信息,图片里的worker叫tomcat,说明一下,我只是把work.properties配置文件的s1改成了tomcat而已

访问http://url/jkstatus

       如果需要做负载均衡需要以下配置

 

# workers.properties

# list the workers by name

worker.list=DLOG4J, status

# localhost server 1
# ------------------------
worker.s1.port=8109
worker.s1.host=localhost
worker.s1.type=ajp13

# localhost server 2
# ------------------------
worker.s2.port=8209
worker.s2.host=localhost
worker.s2.type=ajp13
#可以制定该worker为停止状态
#worker.s2.stopped=1

worker.DLOG4J.type=lb
worker.retries=3
worker.DLOG4J.balanced_workers=s1, s2
worker.DLOG4J.sticky_session=1
worker.status.type=status


    使用了负载均衡的jkstatus管理页面信息

    以上的 workers.properties 。首先我们配置了两个类型为 ajp13 的 worker 分别是 s1 和 s2,它们指向同一台服务器上运行在两个不同端口 8109 和 8209 的 Tomcat 上。接下来我们配置了一个类型为 lb(也就是负载均衡的意思)的 worker,它的名字是 DLOG4J,这是一个逻辑的 worker,它用来管理前面配置的两个物理连接 s1 和 s2。最后还配置了一个类型为 status 的 worker,这是用来监控 JK 本身的模块。有了这三个 worker 还不够,我们还需要告诉 JK,哪些 worker 是可用的,所以就有 worker.list = DLOG4J, status 这行配置。    

 

   3.1.3 uriworkermap.properties配置

 

     如果不需要负载均衡,以下配置就可以了

 

/*=s1
/jkstatus=status
#the following types's request will be given to apache http server,so the prefix is '!'
!/*.gif=s1
!/*.jpg=s1
!/*.png=s1
!/*.css=s1
!/*.js=s1
!/*.htm=s1
!/*.html=s1


    解释以下以上配置:

    /*=s1表示对于所有类型的请求都由s1这个worker处理,除了几个例外(gif,jpg,png,css,js,htm,html)这些静态的资源由Apache Http Server处理

 

    如果使用负载均衡,需要以下配置

 

 

/*=DLOG4J

/jkstatus=status
!/*.gif=DLOG4J
!/*.jpg=DLOG4J
!/*.png=DLOG4J
!/*.css=DLOG4J
!/*.js=DLOG4J
!/*.htm=DLOG4J
!/*.html=DLOG4J


    解释一下以上的配置:

    /*表示所有的请求都由 DLOG4J 这个 worker(使用了负载均衡的,DLOG4J是逻辑的worker,实际就是s1,s2) 进行处理,但是要除去几个例外,/jkstatus 请求由 status 这个worker 处理。另外这个配置中每一行数据前面的感叹号是什么意思呢?感叹号表示接下来的 URI 不要由 JK 进行处理,也就是 Apache 直接处理所有的图片、css 文件、js 文件以及静态 html 文本文件,Apache Http Server处理静态资源内容很拿手。

 

    如果使用了负载均衡,那么要注意还需要修改%CATALINA_HOME%/conf/server.xml。

    将原先的不使用负载均衡的配置

 

    <Connector
        port="8109"
        redirectPort="8443"
        protocol="AJP/1.3">
    </Connector>
 

 

    改成使用使用负载均衡的,对应workers.properties使用负载均衡配置的两个worker所指向的8109,8209

 

    <Connector
        port="8109"
        redirectPort="8443"
        protocol="AJP/1.3">
    </Connector>


    <Connector
        port="8209"
        redirectPort="8443"
        protocol="AJP/1.3">
    </Connector>

  在cmd命令行下输入 netstat -ano 可以看到进程号为4520的进程在监听8080,8109,8209端口,如果不使用负载均衡那么,这里只会出现8080,跟8009,当然这个进程是javaw.exe是java虚拟机

  至此结束了所有的事情了。

 

 注:服务器段向客户端写入的Cookie内容中含有换行符号会丢失Cookie,将换行符号替换成其他字符以后,Cookie工作正常。

 

 !!!补充:

修改apache的httpd.conf配置文件,如不做修改那么你可以从apache安装目录的logs/error.log

发现

 

[Wed Jun 01 21:27:16 2011] [error] [client 122.232.110.19] File does not exist: C:/Program Files/Apache Group/Apache2/htdocs/asf-logo-wide.gif, referer: http://jaychang1987.gicp.net/
 

 

JK会去C:/Program Files/Apache Group/Apache2/htdocs/找图片,JS,CSS,html等文件,故你的JSP页面就会没有图片,样式了。

所以要修改apache的httpd.conf配置文件,如下,就是将TOMCAT的webapps目录设为DodumentRoot

 

#
# DocumentRoot: The directory out of which you will serve your
# documents. By default, all requests are taken from this directory, but
# symbolic links and aliases may be used to point to other locations.
#
DocumentRoot "D:/Tomcat-5.5.27/webapps"

#
# This should be changed to whatever you set DocumentRoot to.
#
<Directory "D:/Tomcat-5.5.27/webapps">   
 

 

参考资料:http://www.ibm.com/developerworks/cn/opensource/os-lo-apache-tomcat/index.html

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值