Форум программистов, компьютерный форум, киберфорум
Java: Spring, Spring Boot
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.91/11: Рейтинг темы: голосов - 11, средняя оценка - 4.91
Эксперт функциональных языков программированияЭксперт Java
 Аватар для korvin_
4575 / 2774 / 491
Регистрация: 28.04.2012
Сообщений: 8,779

Spring (Boot) & Gradle build dependency management

28.12.2017, 22:29. Показов 2470. Ответов 8
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Столкнулся недавно со следующей ситуацией:

Примерная структура проеткта:

Code
1
2
3
root-project
+- some-data-repo-subproject : dependsOn cassandra-driver v3.x.x
+- spring-boot-subproject : dependsOn some-data-repo-subproject, spring-boot-1.3.x
как только я добавил some-data-repo-subproject в зависимости для spring-boot-subproject, внезапно поломались все тесты. По стектрейсу удалось нагуглить, что проблема в том, что spring-boot-стэк (той версии, что у нас в проекте), в частности spring-data, использует драйвер для Кассандры версии 2.x, который не умеет работать с Кассандрой 3.x из-за некоторых изменений. Суть в том, что с одной стороны, при разрешении зависимостей проект spring-boot-subproject, зависящий от some-data-repo-subproject, подхватывает все зависимости some-data-repo-subproject и может их использовать, но также он имеет свои собственные зависимости и в частности его 2.x драйвер «перекрывает» собой драйвер 3.x.

По мне так это крайне мудацкое поведение. Gradle позволяет исключить из зависимости её под-зависимости, я пробовал исключить спринговый драйвер Кассандры нагуглёнными примерами, но не помогло. Да и гуглить сложно: большинство результатов про то как _подключить_, а нее наоборот.

Решил проблему в итоге тем, что добавил в зависимости spring-boot-subproject ту же версию драйвера, что и в some-data-repo-subproject. Но это какое-то костыльное решение.

Вопроса 2:

1) Можно ли настроить Gradle (в идеале, в одном месте — в root-project) так, чтобы он не пробрасывал под-зависимости под-проектов, а собирал их как-то более независимо и модульно, чтобы таких неявных перекрытий не происходило? (Возможно тут дело не в Gradle, а в самой Java, просветите)

2) Как правильно исключить спринговый драйвер Кассандры из spring-boot-стэка, чтобы он его не подтягивал?

P.S. Прошу не советовать обновить spring-boot до актуальной версии, т.к. во-первых, это не решение, во-вторых там есть некоторые изменений в API, в частности в аннотациях, с которыми я уже день провозился в отдельной Git-ветке, но пока что не до того, чтобы мерджить её в основные ветки.
0
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
28.12.2017, 22:29
Ответы с готовыми решениями:

[Spring Boot & Thymeleaf] Сервер не может найти статические ресурсы
Здесь написано Spring Boot will automatically add static web resources located within any of the following directories: ...

Gradle build failed
В чём заключается ошибка? И как её исправить? В интернете не смог понять, что да как ...

Не коплилируется build.gradle
Привет. Очень нужна помощь. У меня простой проект которий просто подключається к firebase. Но при компиляции видает оштбку. Много где...

8
Эксперт Java
378 / 370 / 114
Регистрация: 30.06.2010
Сообщений: 1,445
29.12.2017, 11:24
korvin_, подключи spring-boot bom ко всем подпроектам, например через subprojects в руте, тогда везде будут одни и те же версии. на самом деле он у тебя наверно подрублен неявно в boot подпроекте, если там применен spring boot плагин

вариант б - можно заэксклудить в бутовом проекте зависимость, в гугле куча инфы по запросу gradle exclude transitive dependency
dependencies {
compile('com.example.m:m:1.0') {
exclude group: 'org.unwanted', module: 'x'
}
compile 'com.example.l:1.0'
}
Добавлено через 2 минуты
на самом деле лучше всего первый вариант. потом в корневом проекте и бутовом подпроекте апаешь версию бута и мигрируешь немного код

Цитата Сообщение от korvin_ Посмотреть сообщение
во-первых, это не решение
на самом деле решение, ибо сколько не пользовался и сколько не мигрировал особо проблем не было с
Цитата Сообщение от korvin_ Посмотреть сообщение
там есть некоторые изменений в API, в частности в аннотациях
Добавлено через 52 секунды
тут на самом деле лучше по чаще апать версию что бы перепрыгиваний больших не было. а то скоро вон уже второй бут выйдет
1
Эксперт функциональных языков программированияЭксперт Java
 Аватар для korvin_
4575 / 2774 / 491
Регистрация: 28.04.2012
Сообщений: 8,779
29.12.2017, 18:09  [ТС]
Цитата Сообщение от LeX Посмотреть сообщение
подключи spring-boot bom ко всем подпроектам
Что это и зачем мне это во всех подпроектах?

Цитата Сообщение от LeX Посмотреть сообщение
применен spring boot плагин
Применён.

Цитата Сообщение от LeX Посмотреть сообщение
вариант б - можно заэксклудить в бутовом проекте зависимость, в гугле куча инфы по запросу gradle exclude transitive dependency
Я пробовал, возможно как-то не так заэксклюдил или недозаэксклюдил что-то. Вот кусок build.gradle:

Code
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
configurations {
    compile.exclude module: 'spring-boot-starter-data-cassandra'
    compile.exclude module: 'spring-data-cassandra'
    ...
}
 
dependencies {
    ...
    compile ("org.springframework.boot:spring-boot-starter-data-cassandra:${versionSpringBootStarter}") {
        exclude group: 'com.datastax.cassandra', module: 'cassandra-driver-core'
    }
    ...
    testCompile ("org.springframework.boot:spring-boot-starter-data-cassandra:${versionSpringBootStarter}") {
        exclude group: 'com.datastax.cassandra', module: 'cassandra-driver-core'
    }
    ...
}
оно не сработало.

Цитата Сообщение от LeX Посмотреть сообщение
ибо сколько не пользовался и сколько не мигрировал особо проблем не было с
Хз, может, у нас спрингбутовый проект неправильно реализован, не я его разрабатывал, но когда попробовал апнуть версию, пришлось долго разбираться с изменениями в этой аннотационной магии.

Не по теме:

Из-за чего терпеть её не могу. Особенно то, что многие ошибки возникают в рантайме, хотя иначе могли быть легко отловлены при компиляции.

0
Эксперт Java
 Аватар для KEKCoGEN
2399 / 2224 / 565
Регистрация: 28.12.2010
Сообщений: 8,672
29.12.2017, 19:03
Цитата Сообщение от korvin_ Посмотреть сообщение
Вот кусок build.gradle:
у maven есть комманда mvn dependency:tree, которая показывает откуда пришла каждая зависимосить. Обычно проблемы с перекрытием версий отлавливаются такой коммандой. Думаю в градле есть нечто подобное.
1
Эксперт функциональных языков программированияЭксперт Java
 Аватар для korvin_
4575 / 2774 / 491
Регистрация: 28.04.2012
Сообщений: 8,779
29.12.2017, 19:32  [ТС]
Цитата Сообщение от KEKCoGEN Посмотреть сообщение
у maven есть комманда mvn dependency:tree, которая показывает откуда пришла каждая зависимосить. Обычно проблемы с перекрытием версий отлавливаются такой коммандой. Думаю в градле есть нечто подобное.
Точно, не подумал об этом. Главное теперь — после новогодних праздников вспомнить.
0
Эксперт Java
378 / 370 / 114
Регистрация: 30.06.2010
Сообщений: 1,445
29.12.2017, 21:57
В гредле есть project report плагин, там можно посмотреть откуда еще тянется зависимость.

Что это и зачем мне это во всех подпроектах
Bom предоставляет набор версий либ, которые протестированы для взаимодействия друг с другом, и.е. разрабы бута говорят что с этими версиями все будет работать. В самом проекте эффект следующий, при объявлении зависимостей версия не пишется, она подтянется сама
0
Эксперт функциональных языков программированияЭксперт Java
 Аватар для korvin_
4575 / 2774 / 491
Регистрация: 28.04.2012
Сообщений: 8,779
30.12.2017, 00:13  [ТС]
Цитата Сообщение от LeX Посмотреть сообщение
В самом проекте эффект следующий, при объявлении зависимостей версия не пишется, она подтянется сама
1) Чем это отличается от того, что я не буду указывать конкретную версию спринг-бута?
2) Мне не нужен спринг-бут и всё, что с ним связано, во всех подпроектах.
0
Эксперт Java
378 / 370 / 114
Регистрация: 30.06.2010
Сообщений: 1,445
30.12.2017, 07:24
1. Ты будешь использовать версии зависимостей с ним совместимые
2. Ты не подключаешь бут ко всем проектам, ты подключаешь только бом с совместимым версиями, сами зависимости будет подключены только те, которые пропишешь

Что тут собственно объяснять, ты вроде взрослый мальчик опытный разработчик, гуглить наверно умеешь
0
Эксперт Java
 Аватар для KEKCoGEN
2399 / 2224 / 565
Регистрация: 28.12.2010
Сообщений: 8,672
30.12.2017, 13:47
Цитата Сообщение от LeX Посмотреть сообщение
Bom предоставляет набор версий либ, которые протестированы для взаимодействия друг с другом
это хорошо работает до того момента пока тебе не нужна новая версия либы из BOM, или либа, которая там не указанна. Обычно проблемы с версиями начинаются именно с таких кейсов.

Добавлено через 4 минуты
Кстати не все проблемы с перекрытиями версий возможно решить исключением проблемной зависимости. У меня был случай что некая либа работала со старой версией httpclient (вроде бы) и когда я подключил очередную зависимость, более новая версия httpclient перекрыла старую и старая либа перестала работать. Когда я исключил новый httpclient, перестала работать новая либа. Выяснилось что некоторая часть httpclient не имеет обратной совместимости. Пришлось тащить сорсы httpclient, править проблемный метод и заворачивать его в свой кастомный httpclient....dependency hell во всей красе
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
30.12.2017, 13:47
Помогаю со студенческими работами здесь

MinifyEnabled в build.gradle
Можете объяснить за что отвечает параметр minifyEnabled в build.gradle файле? Он делает абфускацию кода или что то другое? Добавлено...

TargetSdkVersion в build.gradle
compileSdkVersion - это версия при помощи которой я компилирую свое приложение, а targetSdkVersion - это версия, максимальная версия,...

Build.gradle - параметры SdkVersion
Приветствую, В build.gradle есть три параметра: minSdkVersion targetSdkVersion compileSdkVersion Если с первым все понятно, то с...

Нет второго build.gradle в проекте
Привет! Перешел с eclipse на android studio. Экспортировал проект все нормально собирается, но нет второго файла build.gradle в котором...

Чертова ошибка Gradle build failed
Весь "гугл перегуглил". ссылка на Stack Overflow...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
9
Ответ Создать тему
Новые блоги и статьи
Оттенки серого
Argus19 18.03.2026
Оттенки серого Нашёл в интернете 3 прекрасных модуля: Модуль класса открытия диалога открытия/ сохранения файла на Win32 API; Модуль класса быстрого перекодирования цветного изображения в оттенки. . .
SDL3 для Desktop (MinGW): Рисуем цветные прямоугольники с помощью рисовальщика SDL3 на Си и C++
8Observer8 17.03.2026
Содержание блога Финальные проекты на Си и на C++: finish-rectangles-sdl3-c. zip finish-rectangles-sdl3-cpp. zip
Символические и жёсткие ссылки в Linux.
algri14 15.03.2026
Существует два типа ссылок — символические и жёсткие. Ссылка в Linux — это запись в каталоге, которая может указывать либо на inode «файла-ИСТОЧНИКА», тогда это будет «жёсткая ссылка» (hard link),. . .
[Owen Logic] Поддержание уровня воды в резервуаре количеством включённых насосов: моделирование и выбор регулятора
ФедосеевПавел 14.03.2026
Поддержание уровня воды в резервуаре количеством включённых насосов: моделирование и выбор регулятора ВВЕДЕНИЕ Выполняя задание на управление насосной группой заполнения резервуара,. . .
делаю науч статью по влиянию грибов на сукцессию
anaschu 13.03.2026
прикрепляю статью
SDL3 для Desktop (MinGW): Создаём пустое окно с нуля для 2D-графики на SDL3, Си и C++
8Observer8 10.03.2026
Содержание блога Финальные проекты на Си и на C++: hello-sdl3-c. zip hello-sdl3-cpp. zip Результат:
Установка CMake и MinGW 13.1 для сборки С и C++ приложений из консоли и из Qt Creator в EXE
8Observer8 10.03.2026
Содержание блога MinGW - это коллекция инструментов для сборки приложений в EXE. CMake - это система сборки приложений. Здесь описаны базовые шаги для старта программирования с помощью CMake и. . .
Как дизайн сайта влияет на конверсию: 7 решений, которые реально повышают заявки
Neotwalker 08.03.2026
Многие до сих пор воспринимают дизайн сайта как “красивую оболочку”. На практике всё иначе: дизайн напрямую влияет на то, оставит человек заявку или уйдёт через несколько секунд. Даже если у вас. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru