Я использую JBoss EAP 6.2 и Apache 2.2.25-no-ssl для балансировки нагрузки и развертывания кластеров моего приложения.Кластеризация (Apache 2.2.25 mod_jk + JBoss EAP 6.2) с репликацией сеанса OFF и липкость ON не работает
Я хочу Сессия репликации с и Важная сессия на.
Но после выполнения всех конфигураций я заметил, что мой балансировщик нагрузки не вставляет пользовательский запрос на основе идентификатора сеанса на один конкретный узел, вместо этого пересылает запрос другому узлу.
Ниже приведены конфигурации моего кластера.
Нет кластерных узлов = 2
Апач балансировки нагрузки = Apache 2.2.25-нет-SSL
сервер приложений JBoss EAP = 6.2.0
Apache конфигурации балансировки нагрузки
работников.properties
# Define list of workers that will be used
# for mapping requests
worker.list=loadbalancer,status
# Define Node1
# modify the host as your host IP or DNS name.
worker.node1.port=8009
worker.node1.host=172.20.150.33
worker.node1.type=ajp13
worker.node1.ping_mode=A
worker.node1.lbfactor=1
# Define Node2
# modify the host as your host IP or DNS name.
worker.node2.port=8209
worker.node2.host=172.20.150.33
worker.node2.type=ajp13
worker.node2.ping_mode=A
worker.node2.lbfactor=1
# Load-balancing behavior
worker.loadbalancer.type=lb
worker.loadbalancer.balance_workers=node1,node2
worker.loadbalancer.sticky_session=1
# Status worker for managing load balancer
worker.status.type=status
uriworkermap.properties
# Simple worker configuration file
# Mount the Servlet context to the ajp13 worker
/*=loadbalancer
мод-jk.conf
# Load mod_jk module
# Specify the filename of the mod_jk lib
LoadModule jk_module modules/mod_jk.so
# Where to find workers.properties
JkWorkersFile conf/workers.properties
# Where to put jk logs
JkLogFile logs/mod_jk.log
# Set the jk log level [debug/error/info]
JkLogLevel debug
# Select the log format
JkLogStampFormat "[%a %b %d %H:%M:%S %Y]"
# JkOptions indicates to send SSK KEY SIZE
JkOptions +ForwardKeySize +ForwardURICompat -ForwardDirectories
# JkRequestLogFormat
JkRequestLogFormat "%w %V %T"
# Mount your applications
# The default setting only sends Java application data to mod_jk.
# Use the commented-out line to send all URLs through mod_jk.
# JkMount /* loadbalancer
JkMount /* loadbalancer
# Add shared memory.
# This directive is present with 1.2.10 and
# later versions of mod_jk, and is needed for
# for load balancing to work properly
JkShmFile logs/jk.shm
# You can use external file for mount points.
# It will be checked for updates each 60 seconds.
# The format of the file is: /url=worker
# /examples/*=loadbalancer
JkMountFile conf/uriworkermap.properties
# Add jkstatus for managing runtime data
<Location /jkstatus/>
JkMount status
Order deny,allow
Deny from all
Allow from 127.0.0.1
</Location>
мод-jk.conf загружены в файл httpd.conf и Apache работает на порту 80.
В JBoss EAP создайте две реплики с именем node1 и node2 из автономного папки на одном компьютере, как показано ниже
Команда для запуска сервера:
node1
standalone.bat -c standalone-ha.xml -b 172.20.150.33 -u 230.0.10.0 -Djboss.server.base.dir=../node1 -Djboss.node.name=node1 -Dlogging.configuration=file:/${JBOSS_HOME}/node1/configuration/logging.properties
node2
standalone.bat -c standalone-ha.xml -b 172.20.150.33 -u 230.0.10.0 -Djboss.server.base.dir=../node2 -Djboss.node.name=node2 -Dlogging.configuration=file:/${JBOSS_HOME}/node2/configuration/logging.properties -Djboss.socket.binding.port-offset=200
Я пробовал с репликации сеанса вкл. (Добавив в web.xml), но все же такая же проблема существует.
Ниже приведены мои наблюдения JSESSIONID.
по первому требованию
JSESSIONID = SY1d0wVTmX2b-czp50whdmCW.61423f3f-b623-3da4-bd2f-69ba448af636 where 61423f3f-b623-3da4-bd2f-69ba448af636 is JVM-ROUTE for node2.
на второй запрос
JSESSIONID = QMTCTAzt2u-ANTidqZdBIzxO.f742b8d4-46f7-3914-86bb-1044d0a1bfce where f742b8d4-46f7-3914-86bb-1044d0a1bfce is a JVM-ROUTE for node1.
Кажется, даже если JVM-маршрут добавляется к основному идентификатору сессии, по-прежнему загрузить балансир (апач мод-JK) отправка запросить другой узел вместо того, чтобы придерживаться того, на котором установлен сеанс.
Пожалуйста, помогите.