Использование локальной или удаленной отладки может очень помочь и сэкономить время.
По умолчанию удаленная отладка в JBoss отключена, для ее активации нужно внести изменения в конфигурационный файл
%EAP_HOME%/bin/standalone.conf.
- Найдите и раскомментируйте следующую строку:
JAVA_OPTS="$JAVA_OPTS -agentlib:jdwp=transport=dt_socket,address=8787,server=y,suspend=n"
Видно, что мы задействовали порт 8787.
- Перегрузите JBoss
- Осталось настроить IDEA
Зайдите в меню Run и выберите пункт Edit configurations...:
В открывшемся окне Run/Debug configurations выберите пункт Remote:
Придумайте название для данной конфигурации (поле Name), пропишите адрес(Host) и порт(Port) JBoss'а, на котором включена удаленная отладка. Нажмите OK:
В качестве адреса можно указать localhost.
- Теперь попробуем подключаться к работающему JBoss'у, для этого выберите в списке созданную конфигурацию и нажмите "зеленого жучка", как на картинке:
При успешном подключении в консоли IDEA вы увидите следующее сообщение:
Connected to the target VM, address: '10.1.0.50:8787', transport: 'socket'
- Далее мы можем расставить необходимые breakpoint'ы, где необходимо приостановить код и просмотреть содержимое переменных:
Вот так в IntelliJ IDEA выглядит отображение содержимого переменных - это очень удобно:
- Для навигации по исполняемому коду вам помогут следующие кнопки:
Одна из самых полезных - Step Over(перешагнуть), вызывается нажатием функциональной клавиши F8.
- Также IntelliJ IDEA предоставляет некоторые возможности по горячей замене классов (Hot Swap). Например, вы можете что-то изменить внутри метода, нажать на кнопку Make Project, и все изменные классы будут перегружены:
Если изменения несовместимы с горячей заменой, то вам будет сообщено о невозможности замены классов.
- И последнее - для выхода из режима отладки нажмите кнопку Stop:
В консоли появиться сообщение об отсоединении от сервера:
Disconnected from the target VM, address: '10.1.0.50:8787', transport: 'socket
Опишу сначала ситуацию: Два приложения на Seam Framework (два war-ника) нужно было запустить на одном сервере, но т.к. в приложениях многие seam-компоненты, которые были созданы, имели одинаковые имена, был конфликт.
Можно, конечно, добиться уникальности названий компонентов, но это нужно переписать кучу кода и в дальнейшем следить за уникальностью названий в обоих приложениях. Я пошел по этому пути, и приложения запускались и работал без ошибок, но при работе с сервисами возникли проблемы, т.к. jboss путался в компонентах.
Тогда пришло решение запустить приложения на разных jboss'ах.
Запустить два jboss'а на одном сервере относительно просто: нужно добиться того, чтобы jboss'ы не использовали одинаковые порты, а этих портов не мало. И чтобы не путаться в портах, к портам одного их jboss'ов можно добавлять единичку. Это выглядит так: 8009 -> 18009, 1099 -> 11099, 1098 -> 11098 и т.д.
Я делал следующим образом: запускал один jboss, после его полной загрузки запускал второй и смотрел какие порты конфликтуют, заменял эти порты, потом еще раз перезапускал второй jboss до тех пор, пока второй jboss стартовал без конфликтов портов.
Ниже приведу список файлом и замен портов (конфигурация default):
bin\run.bat
8787 -> 18787
server\default\conf\jboss-service.xml
8083 -> 18083
1099 -> 11099
1098 -> 11098
4444 -> 14444
4445 -> 14445
4446 -> 14446
server\default\deploy\ejb3.deployer\META-INF\jboss-service.xml
3873 -> 13873 (этот порт встречается дважды в файле)
server\default\deploy\jboss-web.deployer\server.xml
8080 -> 8085 (порты через, которые будет работать web)
443 -> 1443
5443 -> 15443
8009 -> 18009
server\default\deploy\jms\uil2-service.xml
8093 -> 18093
Также нужно учесть, что теперь debug первого приложения будет по порту 8787, а второго по порту 18787.