Как заставить работать Tomcat AJP-разъемы?

9

Я хочу получить доступ к Tomcat через веб-сервер Apache, используя коннекторы. Я придерживался документации: http://tomcat.apache.org/connectors-doc/generic_howto/quick.html Я лишь немного изменил ее, чтобы она соответствовала структуре каталогов, используемой в моей системе Debian (Squeeze).

Поэтому я добавил следующее в /etc/apache2/httpd.conf:

# Load mod_jk module
# Update this path to match your modules location
#LoadModule    jk_module  libexec/mod_jk.so
# Declare the module for <IfModule directive> (remove this line on Apache 2.x)
#AddModule     mod_jk.c
# Where to find workers.properties
# Update this path to match your conf directory location (put workers.properties next to httpd.conf)
JkWorkersFile /etc/apache2/workers.properties
# Where to put jk shared memory
# Update this path to match your local state directory or logs directory
JkShmFile     /var/log/apache2/mod_jk.shm
# Where to put jk logs
# Update this path to match your logs directory location (put mod_jk.log next to access_log)
JkLogFile     /var/log/apache2/mod_jk.log
# Set the jk log level [debug/error/info]
JkLogLevel    info
# Select the timestamp log format
JkLogStampFormat "[%a %b %d %H:%M:%S %Y] "
# Send everything for context /examples to worker named worker1 (ajp13)
JkMount  /tomcat7/* worker1

Я прокомментировал загрузку модуля, потому что это уже происходит после того, как я установил mod_jk через систему пакетов (libapache2-mod-jk).

Мои работники.свойства выглядят так:

# Define 1 real worker using ajp13
worker.list=worker1
# Set properties for worker1 (ajp13)
worker.worker1.type=ajp13
worker.worker1.host=localhost
worker.worker1.port=8009

Tomcat 7 устанавливается непосредственно из архива от Apache, потому что это не пакет в Squeeze. Tomcat 7 работает и доступен через собственный порт (8180, чтобы не столкнуться с tomcat6 из системы пакетов). Насколько я понимаю, теперь я должен увидеть tomcat-site с http: // host / tomcat7 / . Но вместо этого я получаю 404. Что не так?


После того, как кванты намекнули установить уровень журнала для отладки (спасибо), я сделал это и обнаружил следующее сообщение об ошибке в mod_jk.log: 'jk_map_to_storage :: mod_jk.c (3585): отсутствует карта uri для 176.9.9.55:/tomcat7 /». Я гуглил и нашел http://old.nabble.com/mod_jk%2C-missing-uri-map-td23984359.html

Поэтому параметры, установленные в httpd.conf, не использовались в VirtualHosts. Я добавил 'JkMountCopy On' в мой VirtualHost - и получил сначала Tomcat 404 (вместо httpd 404). Проблема здесь в том, что он пытается получить доступ к тому же монтированному URI, поэтому в моем случае / tomcat7. Вместо имени я использовал название веб-приложения, и все в порядке.

Mnementh
источник

Ответы:

4

Убедись в том, что:

  1. Вы вводите косую черту http: // host / tomcat7 / , а не http: // host / tomcat7 .
  2. у вас есть разъем AJP 1.3, прослушивающий порт 8009 в server.xml:

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

Если это все еще не работает, я предлагаю вам включить отладку и посмотреть mod_jk.log.


РЕДАКТИРОВАТЬ:

Если вы используете:

JkMount  /tomcat7/* worker1

и доступ через http: // host / tomcat7 , я уверен, что вы получите ошибку Apache 404.

В JkMountразделе «Виртуальный хост» вы можете указать :

<VirtualHost *:80>
    ServerName  xx
    ServerAdmin xx

    JkMount /tomcat7 worker1
    JkMount /tomcat7/* worker1
</VirtualHost>
кванты
источник
Я пробовал с косой чертой и без нее, а server.xml содержит упомянутую строку. В mod_jk.log нет ничего интересного, только сообщение о том, что mod_jk был инициализирован.
Мнемент
1
Установили ли вы JkLogLevelк debugи перезагружать / перезапустить Apache? Попробуйте это: http://host/tomcat7/xx. Опубликовать весь контент server.xml.
кванты
Ах, спасибо за подсказку с уровнем журнала.
Мнемент
Пожалуйста, ознакомьтесь с моим выше отредактированным ответом.
кванты
1

У меня такая же проблема. Решение состоит в том, чтобы изменить JkMount /tomcat7* worker1на JkMount /your-servlet-app* worker1. Вы можете иметь столько, JkMountсколько хотите.

Например, после добавления JkMount /manager* worker1вы сможете получить доступhttp://host/manager/html

Я понял эту проблему после того, как попробовал AJP и http. У меня был следующий журнал доступа в моем/var/log/tomcat7/localhost_access_log.txt

10.215.22.132 - - [04/Mar/2016:13:14:39 +0800] "GET /tomcat-demo/manager/ HTTP/1.1" 404 1009
10.215.22.132 - - [04/Mar/2016:13:26:05 +0800] "GET /tomcat-demo/manager/http/ HTTP/1.1" 404 1019
10.215.22.132 - - [04/Mar/2016:13:40:33 +0800] "GET /manager/ HTTP/1.1" 302 -
10.215.22.132 - - [04/Mar/2016:13:40:33 +0800] "GET /manager/html?org.apache.catalina.filters.CSRF_NONCE=E68B5F7E6E96D09C75A8D6854ECE9092 HTTP/1.1" 401 2474
10.215.22.132 - yz [04/Mar/2016:13:40:35 +0800] "GET /manager/html?org.apache.catalina.filters.CSRF_NONCE=E68B5F7E6E96D09C75A8D6854ECE9092 HTTP/1.1" 200 12405

Первые две строки журнала были сгенерированы, пока я использую AJP. Последние три были сгенерированы, пока я использую http для прямого доступа к tomcat. Таким образом, apache передает весь URL-адрес tomcat вместо удаления префикса jkmount.

У Юнчжэн
источник