21 марта 2024

☕ Плавный переход с Java 11 на Java 21: пошаговое руководство для разработчиков

Программирую на Java начиная с JDK 1.6, почти побил мировой рекорд по переписыванию легаси проектов, написал гигабайты кода на Spring Framework. В свободное время обучаю людей программированию и перевожу IT статьи.
Наше пошаговое руководство поможет вам осуществить плавную миграцию вашего проекта с Java 11 на Java 21, избегая подводных камней и извлекая максимум пользы из новых возможностей.
3
☕ Плавный переход с Java 11 на Java 21: пошаговое руководство для разработчиков
Данная статья является переводом. Ссылка на оригинал.

В этой статье, мы освоим тонкости миграции от надежной и широко используемой Java 11 к современной Java 21. Также мы вникнем в процесс миграции и проясним смысл некоторых аспектов, содержащихся и охватывающих Java 11, так как она даёт много преимуществ для миграции и целенаправленного перехода Java ориентированных проектов.

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

Причины миграции на Java 21

1. Безопасность: защитите ваш проект от CVE уязвимостей

Безопасность приложений является первостепенно важной задачей для динамично развивающейся среды разработки программного обеспечения. Обновившись по Java 21 разработчики гарантируют защищенность их приложений от потенциальных уязвимостей. CVE (Common Vulnerabilities and Exposure) является стандартом для определения уязвимостей в сфере кибербезопасности. Обновление проекта до последней версии Java является решительной мерой для защиты вашего кода от потенциальных угроз, снижая пространство для уязвимостей.

2. Поддержка фреймворков: используйте современный инструментарий

Java долгое время была синхронизирована с мощными фреймворками, которые упрощают процесс разработки. Такие столпы экосистемы Java как Spring Framework, Quarkus и Jakarta EE активно продвигаются в направлении Java 21. Следовательно, продолжение работы с Java 11 может спровоцировать прекращение дальнейшей поддержки этих фреймворков и оставить вас без критически важных обновлений. Эта необходимость для любой развивающейся экосистемы подталкивает вас к миграции на Java 21, которая гарантирует вашему коду совместимость с последними нововведениями этих фреймворков.

3. Нововведения Java 21: улучшение производительности

Java 21 дает разработчикам много инструментария для улучшения производительности и сопровождаемости кода. Примечательным дополнением является паттерн проектирования Record, который упрощает создание неизменяемых классов и коллекций с последовательностями и предоставляющий эффективные и краткие методы для работы с последовательностью элементов.

Рассмотрев все эти причины для миграции с Java 11 по Java 21, становится совершенно очевидно — это не просто обновление, а целые стратегические меры по обеспечению улучшенной безопасности, внедрению инноваций и дальнейшего будущего ваших Java приложений.

В следующей главе мы начнем практический курс — представляющий пошаговое руководство по плавному процессу миграции приложения.

Библиотека джависта
Больше полезных материалов вы найдете на нашем телеграм-канале «Библиотека джависта»
🎓☕ Библиотека Java для собеса
Подтянуть свои знания по Java вы можете на нашем телеграм-канале «Библиотека Java для собеса»
🧩Библиотека задач по Java
Интересные задачи по Java для практики можно найти на нашем телеграм-канале Библиотека задач по Java

Пошаговое руководство для миграции

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

Пошаговое руководство для миграции
Пошаговое руководство для миграции

Шаг 1. Обновите ваши фреймворки и библиотеки

Для начала нужно поплясать над обновлением ваших фреймворков и библиотек к версиям совместимым с Java 11. К примеру, Spring Boot 2.7.x — должен быть обновлен до последней версии, такой как 2.7.18. Не забывайте о Lombok, обновите его до версии 1.18.30. Этот начальный шаг сформирует совместимость окружения и гарантирует вашему коду готовность к последующему представлению.

Шаг 2. Подключите Java 21 к пайплайну

Теперь давайте сконфигурируем ваш CI/CD пайплайн. Добавьте промежуточный шаг, чтобы убедиться в том, что ваш код собирается как на Java 11, так и на Java 21. Тесты здесь играют ключевую всевидящего ока, предотвращая любую незамеченную ошибку.

Шаг 3. Скомпилируйте и запустите проект на Java 21

Теперь в центре внимания только Java 21. Настройте ваш пайплайн на сборку и выполнение проекта с Java 21, но без внесения изменений в его код. Это как репетиция нового распорядка дня — придерживайтесь знакомых шагов, но делайте это в современном стиле. GitOps играет роль вашего пропуска за кулисы, предоставляя полную видимость процесса изменений и возможность отката, если это необходимо.

Шаг 4. Подключите нововведения Java 21

Как изящно вы преодолели предыдущие шаги! Кажется, настало время для использования нововведений Java 21. Отрегулируйте настройки вашего компилятора (-source и -target), в Maven или Gradle.

Шаг 5. Следите за актуальными версиями библиотек

Танец с бубном не заканчивается безупречным исполнением. В действительности, это рутина. Нужно регулярно проверять обновления для библиотек и фреймворков. Использовать такие инструменты для автоматизации как Dependabot, гарантирующий вашему коду синхронизацию с последними и наилучшими версиями библиотек. Эпоха тысячелетнего ожидания канула в Лету — активно и еженедельно используйте подход обновления вашего кода.

В заключении хочется сказать, что миграция с Java 11 по Java 21 представляет из себя именно такой танец с бубном. Следуя спокойному подходу, при поддержке GitOps и надежных тестов, вам гарантирована плавная миграция и использование полного потенциала Java 21 в ваших приложениях.

***

Статья по теме

Комментарии

 
 
06 июня 2024

Статья в духе: "Управлять самолетом очень легко, садишься в него, решаешь куда лететь и летишь."

Для начала нужно поплясать над обновлением ваших фреймворков и библиотек к версиям совместимым с Java 11.

Так, вроде, с неё на 21 уже мигрируем?

К примеру, Spring Boot 2.7.x — должен быть обновлен до последней версии, такой как 2.7.18

Тут не поспоришь. Последняя во всех смыслах. После 24 ноября 2023 года только коммерческая поддержка. При этом на maven отображается 28 CVE, которые нам, вроде, не нравятся https://spring.io/projects/spring-boot#support

Не забывайте о Lombok, обновите его до версии 1.18.30

Ну именно такая версия и прописана в spring-boot-dependencies-2.7.18 И если не хочется икать, когда кто-то потом будет переводить ваш проект на какой-нибудь SB 3.2, то не стоит явно дублировать версию таких зависимостей в самом приложении, без явной необходимости.

Приветствую! В шаг 1 нужно подобрать версии которые будет совместимы для java 11 и для java 21. Задача не простая... Иначе будут регрессионные ошибки и т. д. И в шаге 2 попробовать собрать

По поводу версий либ история та же. Лучше исходить из тех которые совместимы как с java 11, так и с java 21

ВАКАНСИИ

Добавить вакансию
Разработчик C++
Москва, по итогам собеседования

ЛУЧШИЕ СТАТЬИ ПО ТЕМЕ

LIVE >

Подпишись

на push-уведомления