Дерево страниц
Skip to end of metadata
Go to start of metadata

Вы просматриваете старую версию данной страницы. Смотрите текущую версию.

Сравнить с текущим просмотр истории страницы

« Предыдущий Версия 7 Следующий »

Может возникнуть необходимость для заказчиков в отдельных агентах, модулях и т.п., которые не хочется добавлять в типовую версию. Для этого создается отдельный war, который содержит типовой сервер + библиотеки, созданные специально под нужды заказчика. Проект ведется в отдельном репозитории со своими сборками. В первую очередь необходимо создать каркас проекта.

  1. Клонируется на локал репозиторий заказчика
  2. В созданной папке создается новый корневой проект maven
  3. Версия удаляется, добавляется родительский проект - cmj нужной версии
  4.     <parent>
            <groupId>ru.intertrust.cm-sochi</groupId>
            <artifactId>ssrv-parent</artifactId>
            <version>6.2.1.3.106</version>
        </parent>
       <properties>
            <cmj.version>${project.parent.version}</cmj.version>
        </properties>

  5. В modules будут указываться кастомные модули и модули, в которые собирается приложение, например:
  6.    <modules>
            <module>srv-pvo-agents</module>
            <module>ssrv-pvo-war</module>
            <module>ssrv-pvo-ear</module>
        </modules>
  7. Добавляется кастомный модуль, в котором будет нужный заказчику функционал. Таких модулей может быть сколько угодно, но их всех нужно указать в верхнем проекте в modules и в зависимостях в модуле с ssrv-war (описан ниже). В IntelliJ Idea это в File → New → Module
  8. pom уже нормальный, можно добавлять туда зависимости, в том числе от cmj-библиотек
  9. Аналогичным образом добавляется модуль с ssrv-war, например, в формате ssrv-orgname-war. В нем указывается 

    <packaging>war</packaging>
    В зависимостях

    <dependency>
    <groupId>ru.intertrust.cm-sochi</groupId>
    <artifactId>ssrv-war</artifactId>
    <type>war</type>
    <version>${cmj.version}</version>
    </dependency>
    , а также зависимость от всех кастомных модулей

    Нужно правильно настроить контекст, чтобы бины в кастомных модулях были доступны. Будут нужны, например, для Менеджера Агентов.

    В 7.0 достаточно в папке \src\main\resources\spring\cmj-extentions\ создать файл applicationContext-cmj-***.xml, в котором указываются пакеты с бинами, подключаемые спринговым приложением (context:component-scan)

    В 6.2 пришлось в war/pom указать вместо ssrv-war все зависимости, скопипащенные из ssrv-war типовой версии, скопипастить классы AFSessionFilter, CmjWebApplicationInitializer, и добавить конфигурацию приложения resources/META-INF/spring/applicationContext-info.xml с указанными там подключаемыми пакетами component-scan

  10. Добавляется модуль ear. У него в pom указывается имя приложения <applicationName>. Используется как минимум Менеджером Агентов.
  11. Выполняется сборка самого верхнего проекта.
  12. ear, который нужно деплоить на сервер, лежит в репозитории в папке с именем модуля ssrv-ear (ssrv-orgname-ear - для папки из примера выше)
  13. Точка входа - ssrv-orgname-war (ssrv-pvo-war для примера выше).

Проект в результате будет иметь структуру вида

parent-pom.xmlcustom-pom.xmlwar-pom.xmlear-pom.xml

  • Нет меток