Рекомендуемое решение для разделения проектов Maven? - PullRequest
14 голосов
/ 11 сентября 2009

Как лучше всего разделить крупный корпоративный проект в Maven?

Достаточно легко понять, как разделить вещи по вертикали, как это ...

  1. У вас есть проект DAO
  2. Проект DAO является зависимостью Сервисный проект
  3. Сервисный проект является зависимостью веб-проекта.

Есть ли у кого-нибудь отзывы о лучших практиках разбиения / разделения действительно больших проектов в Maven.m

Ответы [ 4 ]

18 голосов
/ 11 сентября 2009

Некоторые вещи, которые помогли мне

  • Используйте многомодульные проекты для связанных проектов и только связанных проектов. EJB, который существует только в одном EAR, является кандидатом на это. Бо-слой, используемый EJB и клиентским приложением, не является.
  • Один артефакт на человека, один развертываемый на многомодульный проект Не тратьте время на попытки обойти это.
  • Создание poms зависимостей , которые включают общие наборы зависимостей. Таким образом, вы можете включить DAO, драйвер jdbc и инструменты ORM в одну зависимость. Это также значительно упрощает обновление десятков проектов до новейшей версии ORM или DAO.
  • Создание проектов компоновщика , которые существуют только для запуска сборки и создания наборов развертывания. Это позволит синхронизировать несколько частей вашего проекта. Сборка больших сложных корпоративных приложений часто бывает достаточно сложной, и вам нужно сочетание сценариев maven, shell и / или ant: run плюс десятки профилей. Размещение беспорядка в проекте далеко от вашего кода будет содержать беспорядок до его распространения.
  • Создание тестовых проектов для непрерывной интеграции. Определите ваши веб-серверы и серверы приложений в этих poms, а также информацию о тестовом развертывании. Использование родительских проектов и файлов общих свойств облегчит тестирование изменений развертывания.
  • Определяет managementManagement только в родительском pom , если возможно сделать все подпроекты дочерними (или внучатыми) его.
  • Старайтесь не зависеть от больших файлов (EAR, WAR), вставляемых в ваш репозиторий при каждой сборке. Устранение необходимости отправки 175 Мбайт WAR на нексус для каждого снимка позволило сократить время сборки.
  • Попробуйте определить вещи как можно меньше раз . Сухая сборка - это счастливая сборка. Наличие 30 poms с исходной версией 1.5 или 30 poms с использованием junit 3.8.2 значительно усложнит обновление до java 6 или junit 4.4.

Надеюсь, это поможет.

8 голосов
/ 11 сентября 2009

Я с удовольствием использую Мультимодульный корпоративный проект макет из Maven по примеру . Прочитайте это для вдохновения и работайте над тем, что работает для вас .. alt text

7 голосов
/ 11 сентября 2009

Вот несколько указателей:

  • Объявите версии зависимостей в общем родительском объекте или используйте объявите версии в зависимом проекте конкретного проекта и свяжите его с областью импорта .
  • Избегайте неверсированных плагинов . Объявите версии плагинов в разделе управления плагинами.
  • Объявление общих конфигураций плагинов в родительском pom, в частности, отчеты о конфигурациях.
  • Не объявляйте репозитории в ваших POM .
  • Используйте менеджер репозитория, такой как Nexus
  • Используйте свойства, чтобы позволить дочерним проектам наследовать конфигурацию, но переопределить значения ключа (например, в URL для distributionManagement)
  • Настройка сервера непрерывной интеграции . Разрабатываемые проекты должны иметь версии SNAPSHOT и регулярно развертываться в хранилище.
0 голосов
/ 11 сентября 2009

Это все регулировка. У мейвена нет ни всех, ни последних. мой здесь спас меня, вы можете посмотреть и просто почувствовать, что подходит вам.

<?xml version="1.0" encoding="UTF-8"?>
<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/maven-v4_0_0.xsd">
  <modelVersion>4.0.0</modelVersion>
  <groupId>com.appspot.classifiedsmarket</groupId>
  <artifactId>classifiedsmarket</artifactId>
  <packaging>war</packaging>
  <version>1.0-SNAPSHOT</version>
  <name>classifiedsmarket Maven Webapp</name>
  <url>http://maven.apache.org</url>
  <dependencies>
    <dependency>
      <groupId>junit</groupId>
      <artifactId>junit</artifactId>
      <version>3.8.1</version>
      <scope>test</scope>
    </dependency>
    <dependency>
            <groupId>log4j</groupId>
            <artifactId>log4j</artifactId>
            <version>1.2.12</version>
            <scope>compile</scope>
        </dependency>
    <dependency>
            <groupId>httpunit</groupId>
            <artifactId>httpunit</artifactId>
            <version>1.6.1</version>
            <scope>compile</scope>
        </dependency>
    <dependency>
            <groupId>struts</groupId>
            <artifactId>struts</artifactId>
            <version>1.2.9</version>
            <scope>compile</scope>
        </dependency>
    <dependency>
            <groupId>mysql</groupId>
            <artifactId>mysql-connector-java</artifactId>
            <version>5.1.6</version>
            <scope>compile</scope>
        </dependency>
    <dependency>
            <groupId>informa</groupId>
            <artifactId>informa</artifactId>
            <version>0.6.0</version>
            <scope>compile</scope>
        </dependency>
    <dependency>
            <groupId>org.jasypt</groupId>
            <artifactId>jasypt</artifactId>
            <version>1.3</version>
            <scope>compile</scope>
        </dependency>
    <dependency>
            <groupId>htmlunit</groupId>
            <artifactId>htmlunit</artifactId>
            <version>1.9</version>
            <scope>compile</scope>
        </dependency>

    <dependency>
 <groupId>javax.activation</groupId>
 <artifactId>activation</artifactId>
 <version>1.1</version>
</dependency>
<dependency>
 <groupId>javax.mail</groupId>
 <artifactId>mail</artifactId>
 <version>1.4</version>
</dependency>
<dependency>
            <groupId>dwr</groupId>
            <artifactId>dwr</artifactId>
            <version>1.1.3</version>
            <scope>compile</scope>
        </dependency>
<dependency>
            <groupId>commons-dbcp</groupId>
            <artifactId>commons-dbcp</artifactId>
            <version>1.2.2</version>
            <scope>compile</scope>
        </dependency>
<dependency>
            <groupId>commons-pool</groupId>
            <artifactId>commons-pool</artifactId>
            <version>1.4</version>
            <scope>compile</scope>
        </dependency>
<dependency>
            <groupId>jstl</groupId>
            <artifactId>jstl</artifactId>
            <version>1.1.2</version>
            <scope>compile</scope>
        </dependency>
<dependency>
            <groupId>taglibs</groupId>
            <artifactId>standard</artifactId>
            <version>1.1.2</version>
            <scope>compile</scope>
        </dependency>









  </dependencies>
  <build>
    <finalName>classifiedsmarket</finalName>
    <plugins>
            <plugin>
                <artifactId>maven-compiler-plugin</artifactId>
                <version>RELEASE</version>
                <configuration>
                    <source>1.6</source>
                    <target>1.6</target>
                </configuration>
            </plugin>
            <plugin>
                <artifactId>maven-compiler-plugin</artifactId>
                <version>RELEASE</version>
                <configuration>
                    <encoding>UTF-8</encoding>
                    <source>1.5</source>
                    <target>1.5</target>
                </configuration>
            </plugin>
            <plugin>
                <artifactId>maven-resources-plugin</artifactId>
                <version>RELEASE</version>
                <configuration>
                    <encoding>UTF-8</encoding>
                </configuration>
            </plugin>
        </plugins>
  </build>
  <properties>
        <netbeans.hint.deploy.server>Tomcat55</netbeans.hint.deploy.server>
    </properties>
</project>
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...