Apache & Tomcat Балансировка нагрузки через проблему Mod_jk
Я надеюсь, что это находит вас всех в лучшем здоровье и настроении. У меня проблема с новой настройкой, где у меня в настоящее время есть 1 APACHE 2.2.15 и Tomcat 6.0.14 на RHEL. Mod_JK версия 1.2.30. Я добавлю второй Tomcat, когда это начнет работать.
Поэтому, когда я пытаюсь указать свой браузер на apache-host: port, я получаю ЭТО РАБОТАЕТ, но если указать браузеру на host: port //examples/jsp/, я получаю 404....apache isnt не перенаправляет запросы в Tomcat Tomcat работает нормально Я могу перейти на страницу примеров JSP и запустить вещи. Я просто не могу сделать это через апач. Любая помощь очень ценится... пожалуйста, помогите!!!!!
Вот мои конфиги.... никаких виртуальных хостов не настроено...
HTTPD.CONF
Include conf/jk/mod_jk.conf
LoadModule jk_module modules/mod_jk.so
MOD_JK.CONF
JkWorkersFile conf/jk/workers.properties
JkShmFile logs/mod_jk.shm
JkLogFile logs/mod_jk.log
JkLogLevel info
JkLogStampFormat "[%a %b %d %H:%M:%S %Y] "
WORKERS.PROPERTIES
worker.list=loadbalancer,status
# Node #1 properties
worker.worker1.type=ajp13
worker.worker1.host=localhost
worker.worker1.port=8009
worker.worker1.lbfactor=1
# Node #2 properties(will be configured later when apache and node 1 start working)
worker.worker2.type=ajp13
worker.worker2.host=localhost
worker.worker2.port=001
worker.worker2.lbfactor=1
# Load-balancing behaviour
worker.loadbalancer.type=lb
worker.loadbalancer.balance_workers=worker1,worker2
# Status worker for managing load balancer
worker.status.type=status
#JkMount /* loadbalancer
JkMount /examples/jsp lb
JkMount /examples/jsp/* lb
tomcat server.xml has this
<Service name="Catalina">
...
<!-- Define an AJP 1.3 Connector on port 8009 -->
<Connector port="8009" protocol="AJP/1.3" redirectPort="8443" />
...
</Service>
2 ответа
WORKERS.PROPERTIES
# Load-balancing behaviour worker.loadbalancer.type=lb worker.loadbalancer.balance_workers=worker1,worker2 #JkMount /* loadbalancer JkMount /examples/jsp lb JkMount /examples/jsp/* lb
Это не верно. Переместить JkMount
директива к mod_jk.conf
, что-то вроде этого:
JkWorkersFile conf/jk/workers.properties
JkShmFile logs/mod_jk.shm
JkLogFile logs/mod_jk.log
JkLogLevel info
JkLogStampFormat "[%a %b %d %H:%M:%S %Y] "
JkMount /examples/jsp loadbalancer
JkMount /examples/jsp/* loadbalancer
Обратите внимание, что рабочий Tomcat должен быть loadbalancer
как вы определили в workers.properties
, вместо lb
,
Исправлено оба... теперь я просто получаю пустую страницу.... он жалуется на второго работника в журналах mod_jk о хосте не работает, но я думаю, это нормально, так как у меня не настроен работник 2. Это должно направить запросы к работнику 1 правильно?
я получаю это в журналах доступа, когда я пытаюсь хост: порт /examples/jsp
172.31.118.231 - - [22/Feb/2013:09:27:09 -0600] "GET /examples/jsp HTTP/1.1" 200 -
172.31.118.231 - - [22/Feb/2013:09:27:21 -0600] "GET /examples/jsp HTTP/1.1" 200 -
172.31.118.231 - - [22/Feb/2013:09:27:21 -0600] "GET /favicon.ico HTTP/1.1" 404 209
172.31.118.231 - - [22/Feb/2013:09:28:06 -0600] "GET /examples/jsp HTTP/1.1" 200 -
172.31.118.231 - - [22/Feb/2013:09:28:07 -0600] "GET /favicon.ico HTTP/1.1" 404 209
в журналах ошибок
[Fri Feb 22 09:26:00 2013] [error] [client 172.31.118.231] File does not exist: /opt/fas/loader/tomproj/apache2.2.15/htdocs/examples
в mod_jk logs
[Fri Feb 22 09:25:27 2013] [5773:47624974852416] [info] init_jk::mod_jk.c (3189): mod_jk/1.2.30 initialized
[Fri Feb 22 09:26:45 2013] [5777:1119607104] [info] jk_open_socket::jk_connect.c (622): connect to 127.0.0.1:1 failed (errno=111)
[Fri Feb 22 09:26:45 2013] [5777:1119607104] [info] ajp_connect_to_endpoint::jk_ajp_common.c (959): Failed opening socket to (127.0.0.1:1) (errno=111)
[Fri Feb 22 09:26:45 2013] [5777:1119607104] [error] ajp_send_request::jk_ajp_common.c (1585): (worker2) connecting to backend failed. Tomcat is probably not started or is listening on the wrong port (errno=111)
[Fri Feb 22 09:26:45 2013] [5777:1119607104] [info] ajp_service::jk_ajp_common.c (2540): (worker2) sending request to tomcat failed (recoverable), because of error during request sending (attempt=1)
[Fri Feb 22 09:26:45 2013] [5777:1119607104] [info] jk_open_socket::jk_connect.c (622): connect to 127.0.0.1:1 failed (errno=111)
[Fri Feb 22 09:26:45 2013] [5777:1119607104] [info] ajp_connect_to_endpoint::jk_ajp_common.c (959): Failed opening socket to (127.0.0.1:1) (errno=111)
[Fri Feb 22 09:26:45 2013] [5777:1119607104] [error] ajp_send_request::jk_ajp_common.c (1585): (worker2) connecting to backend failed. Tomcat is probably not started or is listening on the wrong port (errno=111)
[Fri Feb 22 09:26:45 2013] [5777:1119607104] [info] ajp_service::jk_ajp_common.c (2540): (worker2) sending request to tomcat failed (recoverable), because of error during request sending (attempt=2)
[Fri Feb 22 09:26:45 2013] [5777:1119607104] [error] ajp_service::jk_ajp_common.c (2559): (worker2) connecting to tomcat failed.
[Fri Feb 22 09:26:45 2013] [5777:1119607104] [info] service::jk_lb_worker.c (1388): service failed, worker worker2 is in error state
это