让mod_jk运行

时间:2013-05-05 01:49:41

标签: java tomcat mod-jk ajp apache2.2

我正在尝试让Apache将请求转发给Tomcat附带的示例。几个月前我在另一台机器上做过一次,但在这台新服务器上我是残桩。

Tomcat运行正常,localhost:8080加载默认主页,localhost:8080 / examples /显示示例页面。但是当我放弃8080并在apache服务器上使用端口80时,它只是给了我一个404。

真正困扰我的是缺少任何有关原因的日志信息。我正在使用股票httpd-jk.conf添加:

JkMount     /examples/*             worker1

然后这是我的workers.properties:

worker.list=jk-status
worker.jk-status.type=status
worker.jk-status.read_only=true

worker.list=jk-manager
worker.jk-manager.type=status

worker.list=worker1
worker.worker1.reference=worker.template
worker.worker1.host=localhost
worker.worker1.port=8009
worker.worker1.activation=A

worker.template.type=ajp13

worker.template.socket_connect_timeout=5000

worker.template.socket_keepalive=true
worker.template.ping_mode=A
worker.template.ping_timeout=10000
worker.template.connection_pool_minsize=0
worker.template.connection_pool_timeout=600
worker.template.reply_timeout=300000
worker.template.recovery_options=3

Tomcat server.xml:

<?xml version='1.0' encoding='utf-8'?>
<Server port="8005" shutdown="SHUTDOWN">
  <Listener className="org.apache.catalina.core.AprLifecycleListener" SSLEngine="on" />
  <Listener className="org.apache.catalina.core.JasperListener" />
  <Listener className="org.apache.catalina.core.JreMemoryLeakPreventionListener" />
  <Listener className="org.apache.catalina.mbeans.GlobalResourcesLifecycleListener" />
  <Listener className="org.apache.catalina.core.ThreadLocalLeakPreventionListener" />

  <GlobalNamingResources>
    <Resource name="UserDatabase" auth="Container"
              type="org.apache.catalina.UserDatabase"
              description="User database that can be updated and saved"
              factory="org.apache.catalina.users.MemoryUserDatabaseFactory"
              pathname="conf/tomcat-users.xml" />
  </GlobalNamingResources>

  <Service name="Catalina">

    <Connector port="8080" protocol="HTTP/1.1"
               connectionTimeout="20000"
               redirectPort="8443" />

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

    <Engine name="Catalina" defaultHost="localhost">

      <Realm className="org.apache.catalina.realm.LockOutRealm">

        <Realm className="org.apache.catalina.realm.UserDatabaseRealm"
               resourceName="UserDatabase"/>
      </Realm>

      <Host name="localhost"  appBase="webapps"
            unpackWARs="true" autoDeploy="true">

        <Valve className="org.apache.catalina.valves.AccessLogValve" directory="logs"
               prefix="localhost_access_log." suffix=".txt"
               pattern="%h %l %u %t &quot;%r&quot; %s %b" />

      </Host>
    </Engine>
  </Service>
</Server>

1 个答案:

答案 0 :(得分:2)

回答清单;

  • 您确定端口80是由您期望的Apache提供的 - 您的“404”响应是否显示在该Apache实例的访问日志中
  • 您确定正在加载mod_jk模块(请参阅Apache日志,或使用其中一个Apache状态页面视图进行验证);如果未加载模块,则会默默忽略JK配置部分
  • 您确定找到了您的workers.properties(仍然可以看到Apache日志;您可能还希望在httpd.conf中提升JkLogLevel以暂时跟踪;另外,请确保您知道JkLogFile的位置)

然后关于SSL问题; mod_jk和mod_proxy_ajp都应该有效。如果您只想要基本的“服务器端SSL”,并且不使用客户端证书,则所有内容都将由您的Apache httpd处理。另一方面,如果您将使用SSL客户端证书进行客户端身份验证,那么我认为还有另一个SO posting与该用例相关。