EAR (формат файла) - EAR (file format)

Корпоративный архив
Расширение имени файла
.ухо
РазработанSun Microsystems
Тип форматафайловый архив, Сжатие данных
Расширен сБАНКА

EAR (Eпредприятие Априложение арчеснок) это формат файла использован Java EE для упаковки одного или нескольких модулей в единый архив, чтобы развертывание различных модули на сервер приложений происходит одновременно и последовательно. Он также содержит XML файлы под названием дескрипторы развертывания которые описывают, как развернуть модули.

Муравей, Maven, или же Gradle может использоваться для создания файлов EAR.

Файловая структура

EAR-файл является стандартным JAR файл (и, следовательно, Почтовый индекс файл) с расширением .ear, с одной или несколькими записями, представляющими модули приложения, и каталог метаданных, называемый МЕТА-ИНФ который содержит один или несколько дескрипторов развертывания.

Модуль

Разработчики могут встраивать различные артефакты в файл EAR для развертывания серверами приложений:

Изоляция класса

Большинство серверов приложений загружают классы из развернутого файла EAR как изолированного дерева Java. загрузчики классов, изолируя приложение от других приложений, но разделяя классы между развернутыми модулями. Например, развернутый файл WAR сможет создавать экземпляры классов, определенных в файле JAR, который также был включен в содержащий файл EAR, но не обязательно те, которые находятся в файлах JAR в других файлах EAR. Одна из ключевых причин такого поведения - обеспечить полное разделение между приложениями, которые используют статические синглтоны (например, Log4J), что в противном случае могло бы запутать конфигурацию между отдельными приложениями. Это также позволяет развертывать параллельно разные версии приложений и библиотек.

В JBoss Серверы приложений до Версии 5 были примечательны тем, что не изолируют развернутые компоненты. Веб-приложение, развернутое в одном файле EAR, будет иметь доступ к классам в других файлах EAR и WAR. Это несколько противоречивая политика. В Единый загрузчик классов design уменьшает накладные расходы на обмен данными между запущенными приложениями, поскольку данные классов могут совместно использоваться посредством ссылки или простых копий. Это также позволяет разработчикам избежать понимания проблем, которые может создать дерево загрузчиков классов. Однако это предотвращает развертывание разных версий зависимых библиотек в отдельных приложениях. JBoss 4.0.2 переключился на иерархический загрузчик классов, но в версии 4.0.3 он вернулся к унифицированному загрузчику классов по причинам обратной совместимости. Теперь есть возможность изменить это поведение. JBoss 5.x, 6.x и 7.x больше не используют унифицированную загрузку классов.

Каталог META-INF

В МЕТА-ИНФ каталог содержит как минимум application.xml дескриптор развертывания, известный как Дескриптор развертывания Java EE. Он содержит следующие объекты XML:

  • значок, который указывает расположение изображений, представляющих приложение. Подразделение сделано на маленькая иконка и большой значок.
  • показать имя, который идентифицирует приложение
  • описание
  • А модуль элемент для каждого модуля в архиве
  • Ноль или больше роль безопасности элементы для ролей глобальной безопасности в приложении

Каждый модуль элемент содержит ejb, сеть или Ява элемент, который описывает отдельные модули в приложении. Веб-модули также предоставляют контекст-корень который идентифицирует веб-модуль по его URL.

Рядом с дескриптором развертывания Java EE может быть ноль или более дескрипторы развертывания среды выполнения. Они используются для настройки параметров Java EE, зависящих от реализации.

Смотрите также

внешняя ссылка