Статья написана для тех, кто умеет писать простейшие программы на java, но не умеет их собирать. Этим людям уже известно, что такое классы, что такое пакеты и зачем нужен public static main(String[] argv), но код без среды разработки они не запускали, да и не понимают кому и зачем это вообще может понадобиться.


Сразу скажу, что Java программиста, который не может собрать свою программу из консольки, на работу не возьмут, и это в общем более чем достаточная причина, чтобы научиться искусству обращения с системами сборки. Остальное детали, которым и посвящена статья.


Я принципиально не буду обсуждать в статье ничего, кроме сборки минимального HelloWorld. Также я постараюсь опустить все технические детали, которые можно опустить и подробно раскрыть всё, без понимания чего обойтись нельзя.


Для того, чтобы воспользоваться информацией из статьи нужно знать, что такое xml, переменные окружения, зачем нужна переменная окружения PATH и как пользоваться консолью.


Зачем собирать код без IDE


Первый вопрос, который возникает у начинающего разработчика — как в реальной жизни может пригодиться умение собирать код без среды разработки. Она ведь установлена и настроена у всех — это первое, что делает программист, когда приходит на проект.


Ответ простой — для того, чтобы нормально организовать рабочий процесс — код нужно регулярно собирать, проверять что он вообще компилируется, а потом, для того чтобы убедиться в работоспособности кода, прогонять тесты.


Можно, конечно, выделить специального человека, который будет раз в 15 минут запускать IDE и проводить описанные выше процедуры, но это безумие, такие вещи следует делать автоматически.


Уметь собирать код без среды разработки — суровая необходимость. Настолько суровая, что для решения этой задачи существует особый класс программного обеспечения, называемого системами сборки.


Что такое система сборки?


Система сборки это программа, которая собирает другие программы. На вход система сборки получает исходный код, а на выход выдаёт программу, которую уже можно запустить.


Чем она отличается от компилятора? Если коротко, то система сборки вызывает компилятор при своей работе, а компилятор о существовании системы сборки даже не подозревает.


Если более длинно, то сборка, помимо компиляции, включает в себя ещё целый спектр задач, для решения которых компилятор не пригоден от слова совсем.


Например, если программе для работы нужны какие-нибудь картинки, то положить их в директорию с программой — задача системы сборки. Если программе нужны сторонние библиотеки, то положить их в директорию с программой — задача системы сборки. Ну и так далее.


И да, если автоматическая сборка проекта настроена и работает, то нет нужды вручную конфигурировать IDE — современная среда разработки сгенерирует проект самостоятельно, достаточно показать ей где находится конфигурация для системы сборки.


Систем сборки для java по большому счёту 3 — ant, maven и gradle. ant отживает свой век, нынче его используют либо ретрограды, либо реально крутые чуваки, типа Антона Кекса, gradle пока удел хипстеров, а вот maven — стандарт индустрии. Уметь им пользоваться просто необходимо.


Как установить maven


Maven устанавливается просто копированием в нужную директорию — никакого инсталлера нет. Как и в случае с большинством консольных утилит для использования достаточно добавить директорию maven/bin в переменную окружения PATH.


То есть, если maven находится в d:/soft/maven, то в PATH надо добавить d:/soft/maven/bin


Ещё для работы maven потребует переменную JAVA_HOME, которая указывает на JDK. Если JDK находится в C:/Program Files/Java/jdk1.8.0_05, то именно такое значение нужно поместить в JAVA_HOME.


После этого можно попробовать написать в консоли


mvn --version

Если получится, значит maven установлен.


Как структурировать проект для maven


В терминологии maven совокупность файлов с исходным кодом программы, файлов настроек и всего такого называется проектом. Директория, в которой располагаются эти файлы, называется корневой директорией проекта. В дальшейшем я буду обозначать эту директорию как <project>


Как известно, язык программирования java навязывает программисту структуру директорий, которая диктует расположение файлов с классами. Напимер класс с полным именем com.app.HelloWorld должен находиться в файле com/app/HelloWorld.java и никак иначе.


Maven добавляет к этому ограничению ещё одно — исходный код должен находиться в директории <project>/src/main/java. То есть класс com.app.HelloWorld maven будет искать в <project>/src/main/java/com/app/HelloWorld.java


Вот как будет выглядеть этот самый HelloWorld


package com.app;

public class HelloWorld {
    public static void main(String[] argv) {
        System.out.println("Hello world");
    }
}

Как сделать описание проекта


Но просто положить файлы в ожидаемую maven структуру директорий недостаточно. Для сборки проекта необходимо его описание в виде xml документа. Maven будет искать описание в корневой директории проекта в файле pom.xml .


Содержимое минимального файла pom.xml будет примерно следующим.


<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</groupId>
    <artifactId>hello-world</artifactId>
    <version>1.0-SNAPSHOT</version>
</project>

Что тут было существенно важного и что надо запомнить? Запомнить надо вот эти три строки.


<groupId>com</groupId>
<artifactId>hello-world</artifactId>
<version>1.0-SNAPSHOT</version>

Эти три строки являются идентификатором программы для внешнего мира. Программа, она же результат работы по сборке проекта, в терминологии maven называется артефактом.


Непонятное слово артефакт используется здесь вместо понятного слова программа потому, что результатом работы системы сборки может быть не только собственно программа, но и библиотека или ещё что-нибудь эдакое. Комбинация параметров groupId, artifactId и version уникальна для каждого артефакта. Об уникальности этой комбинации должен позаботиться программист.


Технически, значения этих параметров могут быть любыми, но при их выборе строго рекомендуется соблюдать правила хорошего тона.


groupId


В groupId обычно находится название какого-нибудь пакета. Напомню, что название пакета согласно тем же правилам хорошего тона, должно быть именем веб-домена, владельцем которого является автор пакета, что позволяет худо-бедно обеспечить уникальность названия.


artifactId


В artifactId — строка с именем артефакта, которое придумывает его создатель. Как правило это какое-нибудь слово, иногда с разделителями в виде тире. Например hibernate-annotation-wat. artifactId должны быть уникальны в рамках groupId.


version


Ну и наконец version это версия артефакта, которую надо увеличивать при каждом более-менее значительном изменении. Версия обычно включает цифрры и буквы. Типа 1.0-SNAPSHOT


Как собрать проект


Теперь, когда структура файлов проекта соответствует ожидаемой, а его описание присутствует в файле pom.xml, для того, чтобы собрать проект, осталось только открыть консоль, сменить текущую директорию на директорию проекта и написать в консоли:


mvn compile

После того, как maven закончит свою работу, в директории проекта появится директория target, в которой будет находиться скомпилированный код.


Скомпилированный java код выглядит так же, как исходный, только вместо файлов с расширением java в директориях, соответствующих названиями пакетов, находятся файлы с расширением class, в которых будет уже не исходный код, а код, предназначенный для интерпретации джава-машиной.


То есть теперь этот код можно запустить.


Как запустить проект


Чтобы запустить скомпилированный код, нужно в консоли из этой же директории набрать


mvn exec:java -Dexec.mainClass="com.app.HelloWorld"

После того, как maven перестанет качать всякую дрянь из интернета, где-то перед здоровой табличкой с надписью BUILD SUCCESS, появится строчка Hello World.


Код отработал, всё прошло удачно.


Вот так собирают java программы с помощью системы сборки maven.


Итого


  1. maven ищет код для сборки в директории <project>src/main/java.


  2. Инструкции по сборке maven будет искать в <project>/pom.xml


  3. Результат работы системы сборки называется артефактом.


  4. От программиста требуется задать groupId, artifactId и version


  5. Сборка осуществляется командой mvn compile


  6. Скомпилированный java код выглядит так же, как исходный код, но вместо файлов с расширением java, там будут файлы с расширением class.


  7. Запустить скомпилированную программу можно командой
    mvn exec:java -Dexec.mainClass="com.app.HelloWorld"
Поделиться с друзьями
-->

Комментарии (62)


  1. shizo
    05.09.2016 14:28
    +6

    После того, как maven перестанет качать всякую дрянь из интернета

    Ад, конечно.


    1. poxu
      05.09.2016 14:31

      Не могли бы вы раскрыть свою мысль? :)


      1. izzholtik
        05.09.2016 15:21

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


        1. grossws
          05.09.2016 15:37
          +2

          Это куда более характерно для ant'а, в котором это очень сильно зависит от того как именно написали build.xml. mvn -o и использование внутреннего nexus'а — наше усё.


          1. lpre
            05.09.2016 21:00

            Вообще-то Ant по умолчанию вообще ничего на тащит из интернета и не требует его. Если Ant-скрипт что-то и тянет оттуда, то это программист своими очумелыми ручками сделал такой custom-таск (ну, или вставил сторонний таск «для улучшения»).

            Тянуть что-либо со стороны — это как раз maven (ну и gradle).

            Автору: статья расчитана на новичков, не умеющих делать сборку. Почему вы не началим с простейшего срособа собрать «hello world» без сторонних систем сборок? Или это уже не требуется от желающих найти работу?


            1. grossws
              06.09.2016 13:57

              Вообще-то Ant по умолчанию вообще ничего на тащит из интернета и не требует его. Если Ant-скрипт что-то и тянет оттуда, то это программист своими очумелыми ручками сделал такой custom-таск (ну, или вставил сторонний таск «для улучшения»).

              Я в курсе. Обычно народ пишет таск для выкачивания зависимостей для сборки и далеко не всегда использует нормальные средства (типа ivy, который, собственно, используется gradle и sbt), которые нормально работают с кэшами и имеют offline режим.


        1. poxu
          05.09.2016 15:44

          Ну да, тут совершенно согласен. Я вообще сначала думал запустить программу через простой вызов бинарника java. Но потом решил, что раз уж в статье акцент на maven, то надо делать им.


  1. smple
    05.09.2016 15:37

    собрать проект mvn build а не compile


    1. poxu
      05.09.2016 15:41
      +1

      Я не помню такого этапа жизненного цикла у maven. Может быть вы имели в виду package?


      1. smple
        05.09.2016 15:54

        да package, прошу прощение мое общение с maven окончилось 3 года назад но точно помню что compile на выходу jar и war не давал
        а чтобы отработал mvn package необходимо указать entity point
        а еще лучше mvn deploy


        1. poxu
          05.09.2016 16:21
          -2

          Для того, чтобы объяснить что такое mvn package, нужно объяснить что такое jar и war и, возможно, рассказать про этапы жизненного цикла. По моему, для первого знакомства это слишком много.
          Я считаю, что про jar нужно рассказывать в статье про то, как подключить библиотеки, а про стадии жизненного цикла в статье про то, как запустить юнит-тесты.


          1. smple
            05.09.2016 16:31

            возможно

            но тогда зачем рассказывать человеку о maven если можно использовать javac?
            и почему именно maven когда я несколько лет сталкивался с java везде повально перезжали на gradle и maven был только там где это исторически сложилось.

            Статья ваша вам, видней, по поводу mvn build да был не прав не так написал, имел ввиду именно package.


            1. poxu
              05.09.2016 17:40

              Видимо надо было подробнее остановиться на вопросе о том, зачем нужен maven, когда есть javac.


              maven, помимо того, что о чём написано в статье может делать ещё очень многое. Он может скачать используемые в проекте библиотеки, может разложить куда надо ресурсы может запустить юнит тесты. Кроме того, как верно заметил grossws, он позволяет описать проект и этим описанием может воспользоваться любая современная IDE.


              Gradle хорош, но он не стандарт индустрии. Без знания maven пока что обойтись не получится.


              1. smple
                05.09.2016 17:48

                да именно об этом я и хотел сказать что maven здесь не до конца раскрыт, для чего может применяться и как его применять и в чем он именно может помочь, просто мне не удалось это понятно изложить.

                про gradle возможно(сколько людей столько и мнений)
                и знаю что maven central repository стандарт де факто, который кстате в gradle используется.


              1. grossws
                05.09.2016 18:28

                Gradle хорош, но он не стандарт индустрии. Без знания maven пока что обойтись не получится.

                Не соглашусь с первой частью, но соглашусь со второй.


                Насколько я видел по android-проектам, gradle там является стандартом de facto для сборки.


                В мире же java se, когда используют gradle, sbt, lein или ant для библиотек — всё равно генерируют pom (хотя при использовании ant'а это бывает несколько реже), описывающий проект, но не сборку: всякие вещи типа project/distributionManagement, project/scm, project/mailingLists и т. п. Например, см. фрагмент из sbt'шных скриптов akka.


                1. poxu
                  05.09.2016 18:40
                  +1

                  Вы не смотрели эпик баттл между gradle, maven и svt? Там Барух Садогурский (один из адептов gradle и groovy) говорит, что gradle хорошо, но для кровавого энтерпрайза не готов потому, что слишком гибок.


                  Хотя про андроид я конечно немного забыл :)


                  1. grossws
                    05.09.2016 18:45
                    +2

                    И, в качестве project model для IDE, gradle, боюсь, никогда не потянет в силу той же гибкости и динамичности.


                    Той же idea приходится исполнять build.gradle на каждый чих при его изменениях, и с десятком зависимостей и без модулей/плагинов это уже становится не менее дорогой операцией, чем изменение зависимостей в maven-проекте с парой-тройкой сотен транзитивных зависимостей и десятком профилей сборки.


                    1. guai
                      05.09.2016 20:02

                      это скорее недоработки со стороны идеи. Если юзаете plugin: 'idea', а не полагаетесь на стандартный эскпорт, можно сократить время перегенерации проекта так:
                      task ideaOnly {
                      finalizedBy allprojects*.tasks*.idea
                      doFirst {
                      allprojects*.tasks.sum().findAll { !it.name.startsWith('idea') }*.enabled = false
                      }
                      }
                      часто его перегенерить не нужно, только при изменении зависимостей и добавлении модулей


                      1. grossws
                        05.09.2016 20:39

                        Для maven'а существовали (и местами существуют) плагины для генерации проекта под конкретную ide (типа m2e), но использование их, а равно описываемого вами генератора для проекта, имеет один фатальный недостаток: это дополнительное ручное действие, которое надо не забыть сделать после модификации pom.xml/build.gradle.


                        Рано или поздно оно забывается, а дальше — happy-debug. Ловля проблем с неконсистентными версиями зависимостей — очень неприятное развлечение.


                        1. guai
                          06.09.2016 11:23

                          вы меня натолкнули на мысль повесить это на пулл из системы контроля версий. когда я сам что-то меняю, ну понятно, что надо пересобрать, а когда кто-то, тут не помешает автоматом.


        1. grossws
          05.09.2016 16:22
          +1

          maven package по умолчанию (при packaging=jar) соберёт jar без зависимостей и запускаться он не будет. Чтобы он запускался надо сделать одно из двух:


          • собирать uberjar (с помощью assembly/shade/jarjar/onejar) с указанием Main-Class в манифете (можно сделать, например, через plugin/configuration/archive/addManifestEntries/mainClass в рамках maven-jar-plugin/maven-shade-plugin или в assembly дескрипторе)
          • собирать jar+deps (можно использовать к mainClass добавить addClasspath плюс опционально classpathPrefix и сложить зависимости в classpath prefix с помощью maven-dependency-plugin'а.

          Оно может работать автоматически, если настроено в parent pom'е, но в корневом parent pom'е (который используется по умолчанию) этого нет. Ниже примеры из моего parent'а, которые я использую для сборки uberjar'ов и standalone jar + libs для случаев типа embedded jetty + weld (реализация CDI), которые не работают в режиме uber jar'а либо требуют дополнительной хитрой настройки для работы.


          Любой из вариантов ниже (plugin и ниже по дереву) можно скопировать в project/build/plugins.


          uberjar
              <!-- uberjar -->
              <profile>
                <id>uberjar-assembly</id>
          
                <activation>
                  <file>
                    <exists>.uberjar-assembly</exists>
                  </file>
                </activation>
          
                <build>
                  <plugins>
                    <plugin>
                      <groupId>org.apache.maven.plugins</groupId>
                      <artifactId>maven-shade-plugin</artifactId>
          
                      <configuration>
                        <finalName>${project.build.finalName}-uber</finalName>
          
                        <transformers>
                          <transformer implementation="org.apache.maven.plugins.shade.resource.ManifestResourceTransformer">
                            <mainClass>${mainClass}</mainClass>
                          </transformer>
                          <transformer implementation="org.apache.maven.plugins.shade.resource.ServicesResourceTransformer" />
                          <transformer implementation="org.apache.maven.plugins.shade.resource.AppendingTransformer">
                            <resource>reference.conf</resource>
                          </transformer>
                          <transformer implementation="org.apache.maven.plugins.shade.resource.AppendingTransformer">
                            <resource>META-INF/spring.handlers</resource>
                          </transformer>
                          <transformer implementation="org.apache.maven.plugins.shade.resource.AppendingTransformer">
                            <resource>META-INF/spring.schemas</resource>
                          </transformer>
                          <transformer implementation="org.apache.maven.plugins.shade.resource.ApacheLicenseResourceTransformer" />
                          <transformer implementation="org.apache.maven.plugins.shade.resource.ApacheNoticeResourceTransformer">
                            <addHeader>false</addHeader>
                          </transformer>
                        </transformers>
                      </configuration>
          
                      <executions>
                        <execution>
                          <phase>package</phase>
                          <goals>
                            <goal>shade</goal>
                          </goals>
                        </execution>
                      </executions>
                    </plugin>
                  </plugins>
                </build>
              </profile>

          Наличие в проекте файла .uberjar-assembly подключит этот профиль и он будет генерировать jar с classifier'ом uber, сконфигурированный для запуска через java -jar. Требует наличие в проекте property mainClass.


  1. fishca
    05.09.2016 15:37

    Вот тут вроде описано как собрать. Этого не достаточно?


    1. poxu
      05.09.2016 15:40

      По ссылке статья о том, как собрать код на java, не используя системы сборки. Я делал акцент на maven. Конечно таких руководств тоже много. Возможно пользоваться моим кому-нибудь будет проще, чем каким-то другим.


  1. manefesto
    05.09.2016 15:47

    Maven позволяет разруливать нависимости
    Цена на самом деле не велика, правильно настроенный pom.xml


    1. poxu
      05.09.2016 15:48

      Про это я хочу написать отдельную статью. Благо тема, если её раскрывать полностью, заслуживает чуть ли не книги.


      1. manefesto
        05.09.2016 15:53

        А стоит ли? Мне кажется что maven своего рода инструмент как git, выполняет свою задачу на отлично.
        Но на самом деле если сделать как https://git-scm.com/book/ru/v1/, то это будет весьма похвально


        1. poxu
          05.09.2016 16:05

          Я думаю, стоит. Существующие руководства нередко делают акцент на том, как что-то сделать без объяснения что собственно происходит. Например, мне кажется, что в случае с библиотеками нужно сначала объяснить что такое библиотека, а потом уже коротко написать, как её подключить. И этим ограничиться, чтобы информации было не слишком много за один раз.


      1. grossws
        05.09.2016 15:55
        +2

        Особенно весело, что хорошая книга уже есть. Это даже без учёта maven by example.


        В общем, я бы посоветовал новичкам изучать maven по этим двум книжкам, то статьи по мавену на хабре, к сожалению, в большинстве своём поверхностны и разные авторы по глубине охвата останавливались не сильно дальше данной статьи.


        1. poxu
          05.09.2016 16:16

          Я специально остановился на абсолютном минимуме. Тем, кто хочет научиться пользоваться maven этой статьи конечно недостаточно. Она предназначена для тех, кто хочет понять зачем нужен мавен и провести с ним первое знакомство.


          1. grossws
            05.09.2016 16:25
            +2

            Ну я в фазе новичка бы из этой статьи не понял зачем нужен maven. Т. к. главное — что maven — это проектная модель — здесь не описано. Ну и что она включает минимально, в общем, тоже.


            1. poxu
              05.09.2016 16:33

              Про то, что в maven есть такая сущность как проект — есть. Про структуру проекта в maven тоже есть. Минимальный помник есть. Что означают обязательные строки в этом помнике — есть. Есть даже про то, что IDE может создать проект в собственном формате на основме pom.xml, но наверное на этом надо было сделать больший акцент.


              Что ещё, по вашему мнению, нужно было добавить к минимуму?


              1. MacIn
                05.09.2016 18:22
                +1

                Зачем нужен maven, проектная модель и т.д.
                Вы показали, как при помощи этого микроскопа забить гвоздь, который можно забить javac ом, но не показали, зачем он, maven, нужен вообще. Мне, как новичку, непонятно, а зачем надо делать вот так, именно так. Зачем структурировать проект именно таким образом и т.д.


                1. poxu
                  05.09.2016 18:35
                  -1

                  Есть объяснение, зачем нужны систем сборки вообще. Оно очень короткое. Я опасаюсь, что если сделать его длиннее, то потеряется фокус статьи.


                  1. MacIn
                    05.09.2016 21:17

                    Без претензий, я просто задумался, как, например, я бы объяснил, зачем нужен make и makefile'ы, если мы можем собрать проект из Visual Studio. Я бы взял простой случай из DDK или что-то аналогичное, где используется, скажем, некоторое количество модулей на ассемблере, несколько модулей на языке С, объяснил бы, как это будет строиться, как почистится мусор, как определится, что нужно откомпилировать, и как все соберется. А потом показал бы дооолгий и нудный путь того же самого, но руками.


  1. mihmig
    05.09.2016 16:37

    Пользуясь случаем хочу спросить:
    Как можно избежать передеплоя всего war-файла, если измеился только один class-файл?
    Эклипс как-то ругнулся на Ctrl+S что, мол "… не поддерживаю hot redeploy..." но я не понял что ему нужно…


    1. grossws
      05.09.2016 17:25
      +2

      Если для разработки, то можно использовать dcevm. Если для production'а, то есть штуки типа rebel'а, но не стоит ожидать, что это будет стоить сколь-либо гуманно.


  1. PolyAkaMorph
    05.09.2016 17:31
    +2

    А зачем запускать с помощью мавена? И можно ли как-то сделать из class exe-файл, что бы без консоли и батников запускать?


    1. poxu
      05.09.2016 17:35

      Запускать с помощью мавена не обязательно, но в статье акцент на использование мавена и поэтому я решил привести пример запуска с его помощью.


      exe файл сделать вроде бы можно, но я не знаю как. Эта тема далеко за гранью рамок статьи. Можно сделать jar файл, который будет работать как exe, но это тоже в рамки статьи не входит. Коротко, как это сделать, описано grossws вот в этом комментарии.


    1. igor_suhorukov
      05.09.2016 17:53
      +2

      Можно сделать exe c помощью Excelsior JET. AOT компиляция в gnu gcj была, но проект давно мертв… На днях опубликую статью про запуск java проекта сервисом, ссылку выложу тут.


      1. cypok
        06.09.2016 07:45
        +2

        Прямо в тему статьи: у нас (Excelsior JET) недавно еще и maven-plugin появился. ;)


    1. igor_suhorukov
      05.09.2016 17:54

      Поищите на хабре статьи про Avian


    1. igor_suhorukov
      06.09.2016 10:05

      Еще вариант сделать exe и упаковать проект и jvm с помощью packr.


    1. j_wayne
      06.09.2016 10:07
      +2

      Есть стоковый Java FX packager (но только в oracle jdk вроде с 7 версии, в 8 точно есть), он умеет создавать нативные сборки.
      https://docs.oracle.com/javase/8/docs/technotes/guides/deploy/self-contained-packaging.html

      Не уверен насчет non-fx аппов — мельком видел, что без UI может глючить. Не знаю так ли это, использовал для Java FX приложения, для сервера особого смысла в принципе и нет.


      1. igor_suhorukov
        06.09.2016 10:15

        Спасибо! Интересный способ, не знал.
        А как с лицензией на распространения oracle jre со своим приложением?


        1. j_wayne
          06.09.2016 10:18
          +1

          Все нормально, это легальный способ, специально открытый разработчикам.
          Подробно не скажу, но есть определенные несложные правила — не менять состав jre, оставить файлы лицензий и т.п.


    1. igor_suhorukov
      07.09.2016 13:12

      Как и обещал статья про запуск java проекта сервисом/демоном: «Превращаем Java/JVM приложение в демона».


      1. fishca
        07.09.2016 13:30

        зловеще звучит :) ;)


        1. igor_suhorukov
          07.09.2016 13:36

          Шутка с бородой «В качестве ОС для компьютера в храме всегда выберут windows. Ведь в windows — иконы и службы, а в linux — демоны и зомби».


          1. fishca
            07.09.2016 13:42

            +1, воистину так :)


  1. webkumo
    05.09.2016 20:40
    +1

    «Дорогая, в интернете кто-то неправ»…
    хотел написать комментарий с кучей замечаний… но решил всё-таки его в личку отправить…
    Впрочем пару моментов здесь опишу:

    > Сразу скажу, что Java программиста, который не может собрать свою программу из консольки, на работу не возьмут

    — вплоть до мидла возьмут. Умение составлять грамотные билд-файл требуется нечасто и 1-2х человек на проект хватает вполне.

    > После того, как maven перестанет качать всякую дрянь из интернета

    вы вроде мануал пишете? Для новичков? Ну и зачем засорять неокрепшие умы такой фигнёй? Неужели тяжело было написать что-то вроде после того, как мавен скачает зависимости и инструменты, определённые в проектном файле (а также maven-exec-plugin, к которому вы и обратились командой exec:java)"

    А ещё можно было рассказать, что можно разом mvn compile exec:java -Dexec.mainClass=«com.app.HelloWorld»


    1. poxu
      06.09.2016 09:05

      Спасибо за рекомендации. Я думаю, что то, что вы написали в личку нужно было писать в коментарии. Это интересно всем, не только мне.


      вы вроде мануал пишете? Для новичков? Ну и зачем засорять неокрепшие умы такой фигнёй?

      Мой подход к тому, что такое "засорять" отличается от вашего. Добавлять в статью термины зависимости, инструменты и плагин — когда они в ней по сути не используются — это на мой взгляд неправильно. Я хотел написать, что мавен будет что-то качать, но это неважно — не обращайте внимание, главное что он запустит код.


  1. Seboreia
    06.09.2016 02:36

    Возможно ламерский вопрос, но что означает слово SNAPSHOT в версиях артифактов?


    1. poxu
      06.09.2016 08:39

      Оно означает, что артифакт нестабилен и может измениться без изменения версии. Мавен понимает, что это может произойти и обновляет артифакт при каждой сборке.


      1. webkumo
        06.09.2016 11:23

        Ещё из особенностей — обычная версия не имеет права изменяться в мавен-репозитории (а вот снепшот — может, потому и идёт проверка при каждой сборке).


      1. lagranzh
        06.09.2016 11:27

        не при каждой. нужно давать опцию '-U'.


        1. poxu
          06.09.2016 12:17

          Действительно не при каждой, это ценное замечание, я сильно упрощаю. SNAPSHOT версии будут обновляться, если с момента предыдущего получения зависимости из удалённого репозитория и до текущего запуска maven прошло больше суток. Интервал можно настраивать через repository->shapshots->updatePolicy.


          Опция -U обновит снепшоты принудительно, независимо от интервалов и всего такого.


          1. grossws
            06.09.2016 14:18

            Плюс можно в repository/snapshots/updatePolicy указать always. При использовании nexus'а на небольшом расстоянии (в смысле rtt) довольно удобно.


  1. saboteur_kiev
    06.09.2016 02:44

    C 2009 год, https://habrahabr.ru/post/77382/


    1. poxu
      06.09.2016 12:20

      Статья хорошая но носит обзорный характер. В ней коротко раскрыто слишком много вопросов. Я хотел написать статью, посвящённую только одному узкому вопросу.


  1. shurkandak
    06.09.2016 09:19

    Был бы очень интересно читать, если бы в статье было написано о работе с несколькими подпроектами в одном проекте. Ведь maven это могет.


    1. poxu
      06.09.2016 12:21

      Это тема для отдельной статьи, я надеюсь её написать. Но вообще следующую я планирую написать про то, как подключать сторонние библиотеки.


  1. punkkk
    06.09.2016 13:37

    Спасибо! Коротко и ясно.