metaclass: (дзедline)
[personal profile] metaclass
Разбираюсь потиху с Intellij IDEA и скалой. И, как обычно, утыкаюсь в "расхождения по земельному вопросу" с жабными инструментами. Сколько раз это все дело открывал - столько утыкался.

Вот у нас есть на данный момент что: jdk (много разных), мавен(две версии), sbt(аналог мавена для скалы), IDEA и тыщи плагинов под мавен, sbt и идею.
Я прочел документацию по мавену и sbt, но от входа все равно не понимаю, как принято создавать проекты с нуля и как принято их деплоить. Открываешь какой-нибудь пример, а там все заканчивается строкой вида sbt container:start, которая работает исключительно внутри запущенного sbt и с помощью плагина типа "com.github.siasia" %% "xsbt-web-plugin. Или мавен с jetty-плагином.

Предположительно, можно поставить jetty сервисом и деплоить туда приложение в виде war. Но сборка этого war и особенно копирование зависимостей для него для меня темный лес.
Я обычно начинаю с того, что запускаю jetty внутри своего приложения, передавая ему хендлер явно, т.к. таким образом для меня проще понять, что в каком порядке работает и откуда берется конфигурация. Но даже в этом случае количество вариаций на тему "запустить жабу с указанием classpath и main class" просто поражает.
Т.е. запуск из мавена, запуск из sbt, запуск из idea, деплоймент в контейнер и запуск из консоли руками и запуск в виде jar - это все совершенно между собой различающиеся варианты, с разными classpath, разными репозиториями и прочим таким.

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

Date: 2013-03-06 01:51 pm (UTC)
From: [identity profile] evil-invader.livejournal.com
Просто томкат для экслипса и идеи легко настраивается. В эклипсе немного попахивает шаманизмом, но вот идея слёту конфигурится.
Для работы и тестирования веб-приложения (не важно скала или джава) проще использовать томкат. Jetty это уже, если нужно запускать прилагу, как стенделон, но со своим веб-сервером.
Для простых случаев в jdk вообще есть свой миниатюрный веб-сервер, который подымается в две строчки.

Date: 2013-03-06 01:59 pm (UTC)
From: [identity profile] metaclass.livejournal.com
Вот я в основном и запускаю приложение сам, с встроенным веб-сервером.

Date: 2013-03-06 02:15 pm (UTC)
From: [identity profile] evil-invader.livejournal.com
А веб-сервер для чего? Чтобы организовать общение rest/soap?

Date: 2013-03-06 04:41 pm (UTC)
From: [identity profile] jdevelop.livejournal.com
ребе, если вы уже взяли spray - зачем вам jetty? возьмите spray-can, оно из коробки работает и все на NIO

Date: 2013-03-06 02:04 pm (UTC)
From: [identity profile] nealar.livejournal.com
Вот мне щаз ВНЕЗАПНО потребовалось научиться собирать под томкэт. В идеале, раввинским способом, одной строчкой на шелле. Но идеей или эклипсой тоже покатило бы. Даже не скажу, что для меня будет лучше: знакомые спецы по жабе любят идею, а спецы по ынтырпрайзу - эклипсу. Сам вообще не шарю.

Date: 2013-03-06 02:14 pm (UTC)
From: [identity profile] evil-invader.livejournal.com
Если только собирать, то достаточно, чтобы проект был ant или мавен. Билдишь, а дальше подкладываешь томкату и запускаешь. По идее можно научить ант или мавен сразу подкладывать куда надо. Чисто раввинатский способ - никакой IDE. Только консоль - только хардкор.

Date: 2013-03-06 04:11 pm (UTC)
From: [identity profile] nealar.livejournal.com
Да, собрать WAR, и впарить его котяре. Поскольку билд-сервер и продакшен сервер не обязательно живут вместе (в моих фантазиях вообще первое - линупс, второе - венда), то ант или мавен учить подкладывать файлы необязательно.
Гуглить maven manual или что попроще?

Date: 2013-03-06 04:41 pm (UTC)
From: [identity profile] jdevelop.livejournal.com
непонятно зачем нужен maven для деплоя в томкат

Date: 2013-03-06 05:40 pm (UTC)
From: [identity profile] evil-invader.livejournal.com
для того, чтобы собрать проект

Date: 2013-03-06 05:59 pm (UTC)
From: [identity profile] jdevelop.livejournal.com
так чтобы собрать проект - его надо допиливать под сборку с maven, это ж не просто кнопка "сделать мне заебись билд"

или я не понял вопроса-проблемы?

Date: 2013-03-06 06:06 pm (UTC)
From: [identity profile] evil-invader.livejournal.com
Ну собсно я про это и написал. Просто неизвестно что там за проект. Если изначально сделан как мавен проект - то тогда "сделать мне билд".
Если груда какого-то кода, то проще антом расписать сборку.

Date: 2013-03-06 06:10 pm (UTC)
From: [identity profile] jdevelop.livejournal.com
вот да, непонятно, need moar gold!

Date: 2013-03-06 07:17 pm (UTC)
From: [identity profile] nealar.livejournal.com
Сам ещё не видел, шо там внутре. Пока что, тыкался только как end-user, слово WAR, например, узнал вчера.

Date: 2013-03-07 01:06 am (UTC)
From: [identity profile] jdevelop.livejournal.com
что если попросить помощи у товарищей "в теме"?

(no subject)

From: [identity profile] jdevelop.livejournal.com - Date: 2013-03-07 06:33 am (UTC) - Expand

Date: 2013-03-07 04:19 am (UTC)
From: [identity profile] norguhtar.livejournal.com
maven имеет смысл использовать если у проекта есть зависимости от сторонних библиотек. Тогда нет головной боли с их вытягиванием и подкладыванием. Оно само это делает.

Date: 2013-03-07 06:16 am (UTC)
From: [identity profile] evil-invader.livejournal.com
Слабо себе представляю проект без зависимости от сторонних библиотек. Даже если все библиотеки не сторонние, а свои, то имеет смысл разворачивать локальный репозиторий.

Date: 2013-03-06 09:48 pm (UTC)
From: [identity profile] jdevelop.livejournal.com
а это тут причем?

Date: 2013-03-07 01:02 am (UTC)
From: [identity profile] juan-gandhi.livejournal.com
при мавне и томкате, сэр

Date: 2013-03-07 01:04 am (UTC)
From: [identity profile] jdevelop.livejournal.com
mvn tomcat:run запустит приложение в томкате, но никак не задеплоит его в него

Date: 2013-03-06 04:46 pm (UTC)
From: [identity profile] evil-invader.livejournal.com
Если проект изначально написан с использованием мавена, то тут особо гуглить ничего не надо. Достаточно установить maven и в консоле сделать проекту mvn install (из папки, где лежит pom.xml файл проекта).
Если же в проекте ант, то будет файл build.xml и внутри должен быть target для создания варки. Если нету, то придётся описывать самому (это не сложно) и запускать из консоли что-то вроде ant war (в зависимости от названия таргета).
Если же в проекте ничего такого не используется, то это очень старнно =). Наверное тогда придётся самому build.xml описывать, настраивать. Мавеном тут не поможешь, так как для мавенанужная определённая структура проекта, а ант более универсальный.

Date: 2013-03-06 07:14 pm (UTC)
From: [identity profile] nealar.livejournal.com
запускать из консоли что-то вроде ant war
Да я только за одно это словосочетание этот способ асилю!

Date: 2013-03-07 04:18 am (UTC)
From: [identity profile] norguhtar.livejournal.com
Штатный же функционал maven. Там все довольно очевидно.

Profile

metaclass: (Default)
metaclass

April 2017

S M T W T F S
      1
2345678
9101112 131415
16171819202122
23242526272829
30      

Most Popular Tags

Style Credit

Expand Cut Tags

No cut tags
Page generated Sep. 21st, 2025 01:18 pm
Powered by Dreamwidth Studios