Комментарии 14
Есть же tcpdump
+8
Сама разработка ведется не из под linux, к сожалению (я уже начинаю всерьез об этом задумываться). На винде я так понимаю это тот еще квест.
0
Есть же дебаггер.
Есть же логирование нужных классов с уровнем TRACE.
Есть же логирование нужных классов с уровнем TRACE.
+6
Честно говоря не так часто приходится пользоваться дебаггером и поэтому не очень люблю это дело. Особенно когда начинаешь "плясать" по кругу (если дебажить по "шагам"). Но в описанной ситуации собирался уже воспользоваться дебаггером, если бы ничто другое не помогло. А вот про логирование нужных классов с уровнем TRACE не понял, проясните, пожалуйста, о чем речь.
+2
Я имел ввиду, что большинство библиотек в экосистеме Java используют логирование с помощью какого-нибудь логирующего фреймворка типа log4j. Если задать уровень логирование в максимально подробный, то в логах можно увидеть причину того или иного поведения программы.
Правда, в Вашем случае, похоже, этот прием не помог бы.
Правда, в Вашем случае, похоже, этот прием не помог бы.
0
Загрузку внешних схем из XML можно отключить. Тут есть варианты: https://www.owasp.org/index.php/XML_External_Entity_(XXE)_Processing (см параграф с Java).
А диагностировать неудачный коннект можно было ещё попробовать с помощью dtrace.
А диагностировать неудачный коннект можно было ещё попробовать с помощью dtrace.
+3
Как-то это вообще неправильно, что критичные для старта компоненты подгружаются из интернета.
В том же спринге, например, xml-конфиг ссылается на какие-то внешние ресурсы, но эти xml так же есть внутри jar, и он их берет из jar, а не подтягивает из интернета. Как это сделано, я не разбирался.
В том же спринге, например, xml-конфиг ссылается на какие-то внешние ресурсы, но эти xml так же есть внутри jar, и он их берет из jar, а не подтягивает из интернета. Как это сделано, я не разбирался.
0
В специальных properties файлах прописан маппинг url -> путь в classpath, вот и всё. Примерно так же, как описано в http://docs.spring.io/spring/docs/current/spring-framework-reference/htmlsingle/#extensible-xml-registration
0
Полностью с вами согласен, именно тот факт, что так быть не должно и сподвиг меня перебороть лень и изложить по свежей памяти ход расследования. Т.е. пришел я к этому не совсем оптимальным способом, но сама ситуация удручает.
+1
Обычно сервера держат необходимые схемы в локальных ресурсах, и подгружаться ничего не должно. Просто Вы зачем-то взяли уж очень экзотическую и старую схему для web.xml. Обычно используют что-то вроде этого:
<web-app version=«2.4» xmlns=«http://java.sun.com/xml/ns/j2ee» xmlns:xsi=«http://www.w3.org/2001/XMLSchema-instance» xsi:schemaLocation=«http://java.sun.com/xml/ns/j2ee http://java.sun.com/xml/ns/j2ee/web-app_2_4.xsd»>
А с недавнего времени (servlet 3.0, лет 5 как уже) используют это:
<web-app xmlns=«http://java.sun.com/xml/ns/javaee»
xmlns:xsi=«http://www.w3.org/2001/XMLSchema-instance»
xsi:schemaLocation=«http://java.sun.com/xml/ns/javaee http://java.sun.com/xml/ns/javaee/web-app_3_0.xsd»
version=«3.0»
metadata-complete=«false»>
В этих случаях ничего нигде ниоткуда не подгружается, сервер знает все схемы.
<web-app version=«2.4» xmlns=«http://java.sun.com/xml/ns/j2ee» xmlns:xsi=«http://www.w3.org/2001/XMLSchema-instance» xsi:schemaLocation=«http://java.sun.com/xml/ns/j2ee http://java.sun.com/xml/ns/j2ee/web-app_2_4.xsd»>
А с недавнего времени (servlet 3.0, лет 5 как уже) используют это:
<web-app xmlns=«http://java.sun.com/xml/ns/javaee»
xmlns:xsi=«http://www.w3.org/2001/XMLSchema-instance»
xsi:schemaLocation=«http://java.sun.com/xml/ns/javaee http://java.sun.com/xml/ns/javaee/web-app_3_0.xsd»
version=«3.0»
metadata-complete=«false»>
В этих случаях ничего нигде ниоткуда не подгружается, сервер знает все схемы.
0
Теоретически ничем. Схема — это фишка исключительно парсера, который в случае ее указания, пытается сначала проверить XML на соответствие оной. Если схема не указана, XML парсится без нее как есть. А затем уже сервер готовит контекст, зная заранее структуру.
0
Зарегистрируйтесь на Хабре, чтобы оставить комментарий
Затмение на острове Java или внимательней читайте стэктрейсы