Чашечка Java
8.57K subscribers
3.88K photos
13 videos
56 files
6.33K links
Лучшие материалы по Java на русском и английском

Разместить рекламу: @tproger_sales_bot

Правила общения: https://tprg.ru/rules

Другие каналы: @tproger_channels
Download Telegram
Жмых-жмых и в продакшен: как быстро написать админку

Всем привет, меня зовут Дмитрий Кремнев и я Java-разработчик в команде Jmix. Недавно на конференции смотрел доклад, в котором спикер рассказывал, как его команда справлялась с проблемой быстрого написания админок для внутренних сервисов. Сначала они реализовали дорогое самописное решение для своей команды, затем появилась идея масштабировать его и для остальных команд. Искали готовые альтернативы на рынке, которые удовлетворят все их бизнес-требования, но в итоге остановились на гибридном кастомном решении, основанном на low-code платформе. Проблемы, которые они решали мне показались очень знакомыми, ведь мы в команде тоже с ними сталкивались. В этой статье я хочу показать, как с помощью Jmix решаются типовые задачи при создании админок. Постараюсь быть конкретным, показать плюсы и ограничения.
Сделать красиво

Читать: https://habr.com/ru/companies/haulmont/articles/941668/?utm_campaign=941668

@a_cup_of_java | Другие наши каналы
👍3
Единый дистрибутив, JSpecify, Java 25 и новый Spring Debugger: это и многое другое в IntelliJ IDEA 2025.2

IntelliJ IDEA 2025.2 — это релиз, который уже вызывает горячие обсуждения в комьюнити. JetBrains сделали первые шаги в сторону единого дистрибутива, добавили поддержку свежих технологий вроде JSpecify и Java 25, а ещё представили инструмент, который может изменить подход к отладке Spring-приложений.


Читать: https://habr.com/ru/companies/haulmont/articles/941612/?utm_campaign=941612

@a_cup_of_java | Другие наши каналы
Поддержка Spring 7, Reactive Debugger, работа с БД и HTTP прямо в IDE: это и много другое в Amplicode 2025.2

Amplicode 2025.2 — это релиз, в котором мы закрыли десятки мелких раздражающих моментов, и усилили поддержку ключевых технологий — от Spring и Spring Data JDBC до Docker, Kubernetes и Terraform. А также сделали интеграцию с базами и HTTP-сервисами ещё более бесшовной.


Читать: https://habr.com/ru/companies/haulmont/articles/941604/?utm_campaign=941604

@a_cup_of_java | Другие наши каналы
RAG и векторные БД: НЕ Сизифов LLM на Java и Spring Ai

Привет! Меня зовут Бромбин Андрей, и сегодня я разберу на практике, что такое RAG-системы и как они помогают улучшать поиск. Покажу, как использовать Spring AI, векторные базы данных и LLM. Ты получишь теорию и пример реализации на Java и Spring Boot – от идеи до работающего сервиса. Без сложных формул – только чёткие объяснения и код.
Обновить резюме

Читать: https://habr.com/ru/companies/ruvds/articles/924100/?utm_campaign=924100

@a_cup_of_java | Другие наши каналы
1
xAI представила grok-code-fast-1 — свою первую ИИ-модель для кодинга и агентных задач

xAI выпустила grok-code-fast-1 — первую модель для кодинга и агентных задач. Она поддерживает TypeScript, Python, Java, Rust, C++ и Go, интегрирована в IDE и CLI, работает быстро (до 160 ток/с) и стоит дешевле конкурентов

Читать: «xAI представила grok-code-fast-1 — свою первую ИИ-модель для кодинга и агентных задач»

@a_cup_of_java | Другие наши каналы
Технологии единого входа (SSO) для корпоративных ресурсов

«С ростом числа внутренних сервисов и платформ в компаниях всё актуальнее становится задача унификации доступа сотрудников к корпоративным ресурсам. HR-системы, CRM, документооборот  — каждый из этих инструментов требует авторизации. В итоге у сотрудников накапливается десятки учётных записей, а у администраторов — необходимость управлять ими. Чтобы сократить избыточные точки входа и упростить контроль доступа, компании всё чаще внедряют механизм единого входа — SSO (Single Sign-On)», — рассказывает моя коллега Екатерина.


Читать: https://habr.com/ru/articles/942076/?utm_campaign=942076

@a_cup_of_java | Другие наши каналы
1
Просто будь ленивым

В новом переводе от команды Spring АйО рассматривается JEP 502, который вносит в Java 25 StableValue. StableValue позволяют легко и эффективно реализовывать ленивые конструкции — от кэшей до логгеров. Новое API позволяет компилятору JIT заранее сворачивать вычисления, повышая производительность. Искали Lazy, но нашли золото: StableValue вычисляется один раз и может быть подготовлен ещё до запуска.


Читать: https://habr.com/ru/companies/spring_aio/articles/942118/?utm_campaign=942118

@a_cup_of_java | Другие наши каналы
1
GRPC в деле: проблемы реального сервиса

Привет, Хабр! Я Владислав Кислый, разработчик отказоустойчивых нагруженных сервисов в Т-Банке. Расскажу страшную сказку о том, как в одной компании взялись разрабатывать сервис.

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


Читать: https://habr.com/ru/companies/tbank/articles/942014/?utm_campaign=942014

@a_cup_of_java | Другие наши каналы
Просто о сложном: Нейросети, Графы

Просто о сложном: нейросети
Введение
В этой статье я хочу простыми словами объяснить практическое применение нейронных сетей для решения конкретных задач. Важно отметить, что мы не будем подробно разбирать, как устроены нейросети изнутри – об этом уже написано множество материалов. Вместо этого сосредоточимся на том, как применить нейросеть к конкретной задаче, как подобрать под неё данные и параметры. Мы не будем использовать готовые библиотеки машинного обучения – весь функционал реализован самостоятельно, чтобы наглядно разобраться, как можно написать нейросеть под свою задачу. Первое, с чего начнём: нейросеть имеет смысл применять только там, где действительно существуют закономерности в данных. Простой пример – домашний питомец, услышав будильник утром, с большой вероятностью понимает, что скоро получит свежую еду. Это примитивная закономерность (звук будильника → завтрак). Но бывают и очень сложные закономерности, которые не лежат на поверхности. То, что мы называем интуицией, по сути является распознаванием подобных скрытых закономерностей нашим мозгом. Итак, если в вашей задаче нет никаких паттернов или повторяющихся зависимостей, нейросеть не поможет – она просто будет гадать наугад. Если же вы предполагаете наличие закономерностей, можно попытаться их выявить с помощью обучения сети. Правда, будьте готовы к ситуации: если результат плохой, непонятно, то ли закономерностей нет, то ли вы неправильно обучили модель. В этой статье на конкретном примере мы рассмотрим весь путь: от зарождения идеи до реализации и обучения нейросети, а также разберём сложности, с которыми можно столкнуться. Примером послужит задача прогнозирования исхода спортивного события – будем пытаться угадать, выиграет ли первая команда первую четверть баскетбольного матча по ходу игры, используя нейросеть. Это своего рода модель для ставок на спорт, но сразу подчеркну: цель исключительно научная, а не научиться обыгрывать букмекеров (позже станет ясно почему).
Постановка задачи: нейросеть для ставок на спорт


Читать: https://habr.com/ru/articles/942228/?utm_campaign=942228

@a_cup_of_java | Другие наши каналы
vm5277, пример компиляции для AVR

Пишем один код - собираем на разные 8 бит МК!

https://vm5277.ru- это универсальное решение для embedded-разработки, которое позволяет сократить время создания прошивки для 8 бит микроконтроллеров в разы.

Как это работает:

Пишешь код на Java подобном языке (чистое ООП, без головной боли с указателями и не читабельным кодом)

Компилятор автоматически генерирует оптимизированный ассемблерный код под выбранную платформу

Код работает поверх легковесной RTOS, написанной на ассемблере для максимальной производительности

Ассемблер-сборщик финализирует проект в бинарный файл прошивки


Читать: https://habr.com/ru/articles/942258/?utm_campaign=942258

@a_cup_of_java | Другие наши каналы
Статистика футбольных матчей

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


Читать: https://habr.com/ru/articles/942352/?utm_campaign=942352

@a_cup_of_java | Другие наши каналы
Обратная совместимость в Java-мире

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

Однако 30 лет Java прожила. Давайте посмотрим, как это всё было и что было в начале.


Читать: https://habr.com/ru/companies/axiomjdk/articles/941808/?utm_campaign=941808

@a_cup_of_java | Другие наши каналы
Контрактные тесты CDC на Pact

Привет, Хабр!

Сегодня рассмотрим контрактные тесты потребитель-управляемого формата на Pact.

Consumer-Driven Contracts фиксируют минимальный набор ожиданий клиента к API сервиса. Контракт рождается из автотеста на стороне потребителя. Потом провайдер прогоняет этот контракт против своей реализации и публикует результат в Broker. Выигрыш понятный: проверяем не всё API, а только то, что использует потребитель, и фиксируем совместимость версий до выката. Это основная идея Pact и базовая модель его работы.

Сам по себе CDC закрывает разрыв между быстрыми юнитами и медленными e2e. Контракт не заменяет e2e, но даёт дешёвую гарантию «не сломаем потребителя» на каждом изменении провайдера. CDC эффективнее всего на сетях сервисов с явными границами и стабильными интеграциями.


Читать: https://habr.com/ru/companies/otus/articles/941366/?utm_campaign=941366

@a_cup_of_java | Другие наши каналы
Forwarded from Типичный программист
Please open Telegram to view this post
VIEW IN TELEGRAM
👍2
Новинки Java: Groovy 5.0 и Project Leyden
Вышли Groovy 5.0 с поддержкой JDK 11–25 и Project Leyden с улучшениями старта и производительности Java. Также обновились Helidon MCP, Open Liberty, JReleaser и другие инструменты. Подробности в свежем обзоре Java-новостей.

Подробности: https://www.infoq.com/news/2025/09/java-news-roundup-aug25-2025/

#en

@a_cup_of_java | Другие наши каналы
Разработка на Java без всего

Снова показываю как можно вести разработку «голыми руками» — без IDE, документации и даже интернета. На этот раз с помощью «пользовательской» Ubuntu Linux и OpenJDK.


Читать: https://habr.com/ru/articles/942674/?utm_campaign=942674

@a_cup_of_java | Другие наши каналы
👍2
Kotlin Multiplatform: гибкость и нативная производительность для кроссплатформенной разработки.
KMP позволяет разделять бизнес-логику между iOS, Android и другими платформами, сохраняя при этом возможность создавать нативные интерфейсы. Это снижает затраты и ускоряет разработку без потери качества. Kotlin Multiplatform в действии: как McDonald’s и Philips объединяют команды и код для создания кроссплатформенных приложений. Несмотря на сложности с Bluetooth и ограниченную экосистему, KMP помогает ускорить разработку без потери производительности и нативного опыта.

Подробности: https://www.infoq.com/articles/kotlin-multiplatform-evaluation/

#en

@a_cup_of_java | Другие наши каналы
Как развивалась наблюдаемость в Java и почему OpenTelemetry становится стандартом? В подкасте эксперт Марцин Гжейщак раскрывает важность правильной инструментализации и объясняет, как наблюдаемость помогает контролировать производительность как монолитов, так и микросервисов. Micrometer: новый взгляд на метрики и трассировку в Java

Micrometer предлагает зрелое решение для мониторинга Java-приложений с поддержкой интеграции OpenTelemetry и стандартизированной передачей контекста. Особенность — упор на бизнес-метрики и прозрачность в гетерогенной среде. Micrometer и Spring обеспечивают удобную и надёжную инструментализацию приложений, включая реактивные. Главная идея — встроенная в проект телеметрия позволяет быстро выявлять проблемы и снижать расходы на наблюдаемость без сложностей с настройкой.

Подробности: https://www.infoq.com/podcasts/observability-java-micrometer/

#en

@a_cup_of_java | Другие наши каналы
Почему параметр cursor_tuple_fraction не работает с JDBC драйвером PostgreSQL

Эта статья, своего рода, история фэйла. Изначально Лоренс Альбе хотел написать статью о параметре PostgreSQL cursor_tuple_fraction, но обнаружил, что про это уже писали. Тогда Лоренс подумал, что мог бы изучить влияние этого параметра на драйвер JDBC. Это привело его к невероятно долгой борьбе с библиотекой auto_explain, которая в итоге ничего не дала. Хабр полон историями успеха, почему бы не поделиться историей фэйла? Также есть пара интересных наблюдений о работе JDBC-драйвера, которые стоят вашего внимания.


Читать: https://habr.com/ru/articles/942938/?utm_campaign=942938

@a_cup_of_java | Другие наши каналы
👍2
Explyt 4.1: поддержка Python и MCP, пользовательские Rules и Workflows

Привет, Хабр! Отправив детей в школы и детские сады (а кто-то из нас сам идет преподавать в ИТМО и СПбГУ), делимся первым релизом этой осени. Теперь вы можете использовать возможности ассистента в PyCharm. С поддержкой MCPсерверов больше не нужно реализовывать отдельные интеграции для каждого инструмента. Пользовательские Rules и Workflkows помогут сделать работу агента более удобной и корректной.
Другие улучшения + поддержка OpenAI GPT-5

Читать: https://habr.com/ru/companies/explyt/articles/943132/?utm_campaign=943132

@a_cup_of_java | Другие наши каналы
Shift-Left тестирование с Testcontainers: ловим баги на ранних этапах локальными интеграционными тестами

Баги, пойманные на проде, всегда стоят слишком дорого — и времени, и нервов, и репутации. Юнит-тесты не видят проблем с реальными зависимостями, моки быстро устаревают, а интеграционные среды тормозят разработку. Выход ищут в подходе shift-left: проверять критичную бизнес-логику раньше, прямо в IDE, без ожидания CI. В этой статье разберём, как библиотека Testcontainers позволяет поднимать реальные сервисы в контейнерах, писать интеграционные тесты так же просто, как юнит-тесты, и что это даёт с точки зрения скорости и качества по метрикам DORA.


Читать: https://habr.com/ru/companies/otus/articles/943098/?utm_campaign=943098

@a_cup_of_java | Другие наши каналы