Предложена опережающая (Ahead of time) компиляция для JVM
Надо признать довольно интересное предложение в контексте возможности ускорения старта приложения в облачной инфраструктуре.
https://www.infoworld.com/article/3704490/ahead-of-time-compilation-proposed-for-the-jvm.html#tk.rss_java
Надо признать довольно интересное предложение в контексте возможности ускорения старта приложения в облачной инфраструктуре.
https://www.infoworld.com/article/3704490/ahead-of-time-compilation-proposed-for-the-jvm.html#tk.rss_java
InfoWorld
Ahead of time compilation proposed for the JVM
An OpenJDK plan would improve Java Virtual Machine startup times with the ability to load Java applications and libraries already compiled to native code.
👍2
Объектно-ориентированный подход к созданию REST-клиентов, или возможна ли жизнь без Open API
Довольно радикальный взгляд на возможность отказа от Open API в REST сервисах. Open API стал негласным стандартом при разработке REST сервисов. Возможно в локальных проектах где есть гарантия того , что будет использоваться исключительно экосистема JVM языков это решение окажется лучше. Сама идея мне лично понравилась.
https://habr.com/ru/companies/magnit/articles/763952/
Довольно радикальный взгляд на возможность отказа от Open API в REST сервисах. Open API стал негласным стандартом при разработке REST сервисов. Возможно в локальных проектах где есть гарантия того , что будет использоваться исключительно экосистема JVM языков это решение окажется лучше. Сама идея мне лично понравилась.
https://habr.com/ru/companies/magnit/articles/763952/
Хабр
Объектно-ориентированный подход к созданию REST-клиентов, или возможна ли жизнь без Open API
Как-то в общении с моим другом-разработчиком из одной крупной софтверной компании у нас зашёл разговор о взаимодействии распределённых команд. В его компании было множество достаточно изолированных...
🔥2❤1
Синхронизация в Java, часть 1: состояния гонки, блокировки и условия
Это первая статья цикла о синхронизации потоков из трех частей на основе книги "Java. Библиотека профессионала. Том 1. Основы", 12-е издание, Кей С. Хорстманн
https://blogs.oracle.com/javamagazine/post/java-thread-synchronization-raceconditions-locks-conditions
Это первая статья цикла о синхронизации потоков из трех частей на основе книги "Java. Библиотека профессионала. Том 1. Основы", 12-е издание, Кей С. Хорстманн
https://blogs.oracle.com/javamagazine/post/java-thread-synchronization-raceconditions-locks-conditions
O’Reilly Online Learning
Core Java, Volume I: Fundamentals, 12th Edition
The #1 Java Guide for Serious Programmers: Fully Updated through Java 17 Core Java, Volume I: Fundamentals, Twelfth Edition, is the definitive guide to writing robust, maintainable... - Selection from Core Java, Volume I: Fundamentals, 12th Edition [Book]
Как скомпилировать Spring Boot приложение в native image с помощью GraalVm и развернуть его с помощью Docker
GraalVm довольно интересная штука, но лично меня она сильно не впечатлила. Старт приложения происходит действительно быстрее. В статье приводится пример сборки довольно простого приложения.
https://habr.com/ru/articles/755550/
GraalVm довольно интересная штука, но лично меня она сильно не впечатлила. Старт приложения происходит действительно быстрее. В статье приводится пример сборки довольно простого приложения.
https://habr.com/ru/articles/755550/
Хабр
Как скомпилировать Spring Boot приложение в native image с помощью GraalVm и развернуть его с помощью Docker
Предыстория До недавнего времени мой опыт работы с бекенд-приложениями ограничивался созданием приложения на базе Spring Boot различных версий с использованием реляционных баз данных, ликвибейза,...
👍1
Apache Flink ML – прогнозирование в реальном времени
Возможно ли заниматься машинным обучением на Java? Конечно ДА ))
Сегодня рассмотрим замечательный продукт Apache Flink ML.
https://habr.com/ru/companies/neoflex/articles/755804/
Возможно ли заниматься машинным обучением на Java? Конечно ДА ))
Сегодня рассмотрим замечательный продукт Apache Flink ML.
https://habr.com/ru/companies/neoflex/articles/755804/
Хабр
Apache Flink ML – прогнозирование в реальном времени
Всем привет! В этой статье рассмотрим применение библиотеки Apache Flink ML для построения конвейеров машинного обучения. Затем реализуем простой проект по прогнозированию поведения системы, а также...
👍1
«Фундаментальное»руководство по пакетам в Java
Джунам прочитать будет полезно. Пакеты в Java появились с самого начала, во времена, когда язык еще назывался Oak. Java-пакеты реализуют так называемое пространство имен (namespace), позволяющее использовать в проекте файлы с одинаковыми именами. Такой подход существует с давних времен во многих языках.
https://habr.com/ru/articles/755654/
Джунам прочитать будет полезно. Пакеты в Java появились с самого начала, во времена, когда язык еще назывался Oak. Java-пакеты реализуют так называемое пространство имен (namespace), позволяющее использовать в проекте файлы с одинаковыми именами. Такой подход существует с давних времен во многих языках.
https://habr.com/ru/articles/755654/
Хабр
Фундаментальное руководство по пакетам в Java
Что такое пакет Примеры пакетов Назначение пакетов Правила создания пакетов Импорт классов Компиляция и запуск Возможные ошибки и их решение Введение Пакеты в Java появились с самого начала, во...
IBM Watsonx использует генеративный ИИ для перевода кода COBOL на язык Java
https://www.infoworld.com/article/3705251/ibm-watsonx-to-use-generative-ai-to-translate-cobol-code-into-java.html#tk.rss_java
https://www.infoworld.com/article/3705251/ibm-watsonx-to-use-generative-ai-to-translate-cobol-code-into-java.html#tk.rss_java
InfoWorld
IBM Watsonx to use generative AI to translate COBOL code into Java
The product is targeted at modernizing mainframe applications that run on IBM Z systems, as the number of COBOL developers starts to dwindle.
👍1
Все что вам нужно знать о таймаутах
В статье хорошо раскрыта тема таймаутов и даны ссылки на доп материал. В статье дается пример с использованием
https://engineering.zalando.com/posts/2023/07/all-you-need-to-know-about-timeouts.html
В статье хорошо раскрыта тема таймаутов и даны ссылки на доп материал. В статье дается пример с использованием
CompletableFuture, но лучше конечно полагаться на готовые решения типа
Resilience4j.https://engineering.zalando.com/posts/2023/07/all-you-need-to-know-about-timeouts.html
Zalando Engineering Blog
Zalando Engineering Blog - All you need to know about timeouts
How to set a reasonable timeout for your microservices to achieve maximum performance and resilience.
Аудит пользователей Spring Data JPA
В статье приводится одно из возможных решений по аудиту изменений в базе. Хочу также отметить, что с soft delete-ами нужно быть аккуратными. Обратите также внимание на комментарии к статье.
https://habr.com/ru/companies/nlmk/articles/757866/
В статье приводится одно из возможных решений по аудиту изменений в базе. Хочу также отметить, что с soft delete-ами нужно быть аккуратными. Обратите также внимание на комментарии к статье.
https://habr.com/ru/companies/nlmk/articles/757866/
Хабр
Аудит пользователей Spring Data JPA
Задача: в БД необходимо фиксировать кто создал сущность, кто её обновил, и кто её удалил. Все знают, как взять пользователя из контекста и сунуть его в сущность. Допустим,...
👍1🔥1
Высокие технологии или дешевые фокусы с двойным дном
Мне никогда не приходила идея мокать null. В этом случаи наблюдается достаточно интересный эффект, который на первый взгляд похож на «магию».
https://habr.com/ru/articles/759344/
Мне никогда не приходила идея мокать null. В этом случаи наблюдается достаточно интересный эффект, который на первый взгляд похож на «магию».
https://habr.com/ru/articles/759344/
Хабр
Высокие технологии или дешевые фокусы с двойным дном
Отлаживал я как-то тесты и параллельно размышлял о null-safety. Звезды сошлись и родилась довольно странная идея - замокать null . Искушения программиста смотрящего на Mockito.when().thenReturn() Ниже...
👍4👏1
Прикольная игрушка про историю развития Spring
Браузерная игрушка в стиле «Марио», созданная к 20-летию Spring. Управляя листочком, мы узнаем о самых важных вехах развития фреймворка с 2003 года.
https://springone.io/history-of-spring
Браузерная игрушка в стиле «Марио», созданная к 20-летию Spring. Управляя листочком, мы узнаем о самых важных вехах развития фреймворка с 2003 года.
https://springone.io/history-of-spring
Vmware
SpringOne | Las Vegas | VMware Explore
Discover the future of Spring at SpringOne—featuring live and in-person sessions around Spring Boot, Spring AI & more.
👍2🔥1
JDBC Profiling with VisualVM
Думаю многие из вас пользовались старым добрым VisualVM. В нем есть прекрасная возможность попрофилировать взаимодействие с базой. В частности можно поисследовать медленные запросы к базе, а также проблему N+1
https://vladmihalcea.com/jdbc-profiling-visualvm/
Думаю многие из вас пользовались старым добрым VisualVM. В нем есть прекрасная возможность попрофилировать взаимодействие с базой. В частности можно поисследовать медленные запросы к базе, а также проблему N+1
https://vladmihalcea.com/jdbc-profiling-visualvm/
Vlad Mihalcea
JDBC Profiling with VisualVM - Vlad Mihalcea
Learn how to do JDBC profiling using the VisualVM tool and find slow-running SQL queries or N+1 query issues.
FizzBuzz и искусство фильтрации
Проблема FizzBuzz - это классическая задача, которая часто встречается на собеседованиях для программистов. В статье дается решение с использованием Stream API.
https://habr.com/ru/articles/760192/
Проблема FizzBuzz - это классическая задача, которая часто встречается на собеседованиях для программистов. В статье дается решение с использованием Stream API.
https://habr.com/ru/articles/760192/
Хабр
FizzBuzz и искусство фильтрации
Проблема FizzBuzz - это классическая задача, которая часто встречается на собеседованиях для программистов. Обычно она формулируется так: Создайте программу, которая выводит числа от 1 до n. - Если...
Искусство ETL. Пишем собственный движок SQL на Spark [часть 1 из 5]
В данной серии статей подробно рассказано о том, как написать на Java собственный интерпретатор объектно-ориентированного диалекта SQL с использованием Spark RDD API, заточенный на задачи подготовки и трансформации наборов данных.
https://habr.com/ru/articles/760504/
В данной серии статей подробно рассказано о том, как написать на Java собственный интерпретатор объектно-ориентированного диалекта SQL с использованием Spark RDD API, заточенный на задачи подготовки и трансформации наборов данных.
https://habr.com/ru/articles/760504/
Хабр
Искусство ETL. Пишем собственный движок SQL на Spark [часть 1 из 5]
В данной серии статей я подробно расскажу о том, как написать на Java собственный интерпретатор объектно-ориентированного диалекта SQL с использованием Spark RDD API, заточенный на задачи подготовки и...
OOM: direct memory при работе с сетью TCP/IP через NIO в Java
Эта статья основана на реальной практике борьбы с "OutOfMemory: direct memory" в шине данных гибридной интеграционной платформы.
https://habr.com/ru/companies/bercut/articles/762254/
Эта статья основана на реальной практике борьбы с "OutOfMemory: direct memory" в шине данных гибридной интеграционной платформы.
https://habr.com/ru/companies/bercut/articles/762254/
Хабр
OOM: direct memory при работе с сетью TCP/IP через NIO в Java
Вступление Привет, меня зовут Денис Агапитов, я руководитель группы Platform Core компании Bercut. Работаю в компании без малого 20 лет, из них 18 пишу на Java. Сегодня я расскажу об опыте...
Кэширование контекста Spring между запусками тестов: как ускорить процесс локального тестирования
Тестирование является важным элементом процесса разработки программного обеспечения. При этом работа с тестами может занимать достаточно большое количество времени в сравнении с самой разработкой, в связи с этим возникает необходимость оптимизировать этот процесс. В этой статье рассказывается про плагин Sprinter для IntelliJ IDEA, который может помочь значительно сократить время на локальный запуск тестов.
https://habr.com/ru/companies/jugru/articles/762632/
Тестирование является важным элементом процесса разработки программного обеспечения. При этом работа с тестами может занимать достаточно большое количество времени в сравнении с самой разработкой, в связи с этим возникает необходимость оптимизировать этот процесс. В этой статье рассказывается про плагин Sprinter для IntelliJ IDEA, который может помочь значительно сократить время на локальный запуск тестов.
https://habr.com/ru/companies/jugru/articles/762632/
Хабр
Кэширование контекста Spring между запусками тестов: как ускорить процесс локального тестирования
Тестирование является важным элементом процесса разработки программного обеспечения. При этом работа с тестами может занимать достаточно большое количество времени в сравнении с самой разработкой, в...
👍3
Microsoft начала выпускать сборки JDK 21,
которые скоро станут доступны на Azure PaaS.
Кроме того, Microsoft анонсировала новый выпуск семантического ядра для Java версии 0.2.9, который, по ее словам, находится в альфа-состоянии. Семантическое ядро - это облегченный SDK для интеграции больших языковых моделей для генеративного искусственного интеллекта с обычными языками программирования. Новая библиотека поможет разработчикам усовершенствовать Java-приложения с помощью расширенного интеллекта за счет идиоматической интеграции больших языковых моделей.
https://www.infoworld.com/article/3707711/microsoft-ships-java-21-builds.html
InfoWorld
Microsoft ships Java 21 builds
Microsoft made Microsoft Build for OpenJDK 21 binaries available for free download and announced that JDK 21 will soon be available in Azure PaaS services.
Микросервисы победили. Или не совсем
В статье представлена довольно оригинальная точка зрения. Обязательно стоит почитать. Меня особенно порадовал коммент где описывается попытка спроектировать калькулятор используя микросервисы ))
https://habr.com/ru/companies/haulmont/articles/766188/
В статье представлена довольно оригинальная точка зрения. Обязательно стоит почитать. Меня особенно порадовал коммент где описывается попытка спроектировать калькулятор используя микросервисы ))
https://habr.com/ru/companies/haulmont/articles/766188/
Хабр
Микросервисы победили. Или не совсем
«Мы хотим сделать систему по учету персонала. Только у наших архитекторов есть требование, что все у нас должно быть на микросервисах». Это, пожалуй, самый бесячий заход, который нам приходится...
👍3🔥2
Создание и тестирование gRPC сервиса (Spring Boot приложение)
Эта статья будет полезна для тех, кто только начинает знакомиться с gRPC и ищет руководство по написанию и тестированию сервисов.
https://habr.com/ru/articles/767130/
Эта статья будет полезна для тех, кто только начинает знакомиться с gRPC и ищет руководство по написанию и тестированию сервисов.
https://habr.com/ru/articles/767130/
Хабр
Создание и тестирование gRPC сервиса (Spring Boot приложение)
Привет, Хабр! Сегодня я поделюсь опытом работы с gRPC и расскажу как создать и протестировать gRPC -сервис в приложении на Spring Boot . Основная проблема — это отсутствие структурированной информации...
👍1
Oracle представила расширение для разработки на Java для Visual Studio Code
Расширение охватывает цикл разработки от редактирования до компиляции, отладки и тестирования, при этом поддерживается рефакторинг на уровне классов и переменных. Первоначальный выпуск предлагает такие функции, как просмотр проекта, автозавершение, выделение ошибок и возможности перехода к определению, а также поддержку модульного тестирования для Junit.
https://www.infoworld.com/article/3709228/oracle-unveils-java-development-extension-for-visual-studio-code.html#tk.rss_java
Расширение охватывает цикл разработки от редактирования до компиляции, отладки и тестирования, при этом поддерживается рефакторинг на уровне классов и переменных. Первоначальный выпуск предлагает такие функции, как просмотр проекта, автозавершение, выделение ошибок и возможности перехода к определению, а также поддержку модульного тестирования для Junit.
https://www.infoworld.com/article/3709228/oracle-unveils-java-development-extension-for-visual-studio-code.html#tk.rss_java
InfoWorld
Oracle unveils Java development extension for Visual Studio Code
Oracle said that its Oracle Java Platform extension would support current JDK releases and the next upcoming JDK version.