uz
Feedback
Java Portal | Программирование

Java Portal | Программирование

Kanalga Telegram’da o‘tish

Присоединяйтесь к нашему каналу и погрузитесь в мир для Java-разработчика Связь: @devmangx РКН: https://clck.ru/3H4WUg

Ko'proq ko'rsatish

📈 Telegram kanali Java Portal | Программирование analitikasi

Java Portal | Программирование (@java_iibrary) Rus til segmentidagi kanali faol ishtirokchi. Hozirda hamjamiyat 12 109 obunachidan iborat bo'lib, Texnologiyalar & Aralashmalar toifasida 10 407-o'rinni va Rossiya mintaqasida 54 513-o'rinni egallagan.

📊 Auditoriya ko‘rsatkichlari va dinamika

невідомо sanasidan buyon loyiha tez o‘sib, 12 109 obunachiga ega bo‘ldi.

09 Iyun, 2026 dagi oxirgi ma’lumotlarga ko‘ra kanal barqaror faollikka ega. Oxirgi 30 kunda obunachilar soni -147 ga, so‘nggi 24 soatda esa -12 ga o‘zgardi va umumiy qamrov yuqori darajada qolmoqda.

  • Tasdiqlash holati: Tasdiqlanmagan
  • Jalb etish (ER): Auditoriya o‘rtacha 11.15% darajada jalb etiladi. Nashrdan keyingi dastlabki 24 soatda kontent odatda umumiy obunachilar sonining 6.42% ini tashkil etuvchi reaksiyalarni to‘playdi.
  • Post qamrovi: Har bir post o‘rtacha 1 351 marta ko‘riladi; birinchi sutkada odatda 778 ta ko‘rish yig‘iladi.
  • Reaksiyalar va o‘zaro ta’sir: Auditoriya faol: har bir postga o‘rtacha 4 ta reaksiya keladi.
  • Tematik yo‘nalishlar: Kontent boot, string, void, архитектура, resttemplate kabi asosiy mavzularga jamlangan.

📝 Tavsif va kontent siyosati

Muallif resursni shaxsiy fikrni ifoda etish maydoni sifatida ta’riflaydi:
Присоединяйтесь к нашему каналу и погрузитесь в мир для Java-разработчика Связь: @devmangx РКН: https://clck.ru/3H4WUg

Yuqori yangilanish chastotasi (oxirgi ma’lumot 10 Iyun, 2026 da olingan) sababli kanal doimo dolzarb va katta qamrovli bo‘lib qoladi. Analitika auditoriya kontent bilan faol hamkorlik qilishini, uni Texnologiyalar & Aralashmalar toifasidagi muhim ta’sir nuqtasiga aylantirishini ko‘rsatadi.

12 109
Obunachilar
-1224 soatlar
-387 kunlar
-14730 kunlar
Postlar arxiv
В новых приложениях на Spring Boot у тебя есть выбор использовать WebClient вместо RestTemplate. Он реактивный и неблокирующи
В новых приложениях на Spring Boot у тебя есть выбор использовать WebClient вместо RestTemplate. Он реактивный и неблокирующий Работает на основе event loop, а не модели «один поток на один запрос» (thread-per-request) #SpringBoot #JavaDev 👉 Java Portal

Новое в Java 25: гибкие тела конструкторов (Flexible Constructor Bodies, JEP 513)! Теперь можно выполнять валидацию аргументо
Новое в Java 25: гибкие тела конструкторов (Flexible Constructor Bodies, JEP 513)! Теперь можно выполнять валидацию аргументов или подготовительную инициализацию до явного вызова другого конструктора (this(...) или super(...)) — больше не нужны шаблонные вспомогательные методы (helper methods) ради такой логики. 👉 Java Portal

@ConditionalOnClass — это аннотация Spring Boot, которая используется в auto-configuration. ✅ Она условно активирует bean или
@ConditionalOnClass — это аннотация Spring Boot, которая используется в auto-configuration. ✅ Она условно активирует bean или configuration только в том случае, если указанный класс присутствует в classpath. #SpringBoot #Microservices 👉 Java Portal

@Sql или @SqlGroup позволяют заранее загружать тестовые данные для выполнения воспроизводимых тестов. Позволяет: ✅ Вставлять
@Sql или @SqlGroup позволяют заранее загружать тестовые данные для выполнения воспроизводимых тестов. Позволяет: ✅ Вставлять тестовые данные ✅ Очищать таблицы ✅ Сбрасывать состояние базы данных #SpringBoot #IntegrationTesting 👉 Java Portal

🔴 Завтра тестовое собеседование с Java-разработчиком 13 мая(уже завтра!) в 19:00 по мск приходи онлайн на открытое собеседов
🔴 Завтра тестовое собеседование с Java-разработчиком 13 мая(уже завтра!) в 19:00 по мск приходи онлайн на открытое собеседование, чтобы посмотреть на настоящее интервью на Middle Java-разработчика. Как это будет: 📂 Виктор Анохин, старший разработчик из WildBerries, будет задавать реальные вопросы и задачи разработчику-добровольцу 📂 Виктор будет комментировать каждый ответ респондента, чтобы дать понять чего от вас ожидает собеседующий на интервью 📂 В конце можно будет задать любой вопрос Виктору Это бесплатно. Эфир проходит в рамках менторской программы от ШОРТКАТ для Java-разработчиков, которые хотят повысить свой грейд, ЗП и прокачать скиллы. Переходи в нашего бота, чтобы получить ссылку на эфир → @shortcut_sh_bot Реклама. О рекламодателе.

Spring Boot: используй @EntityGraph для управления стратегиями загрузки и предотвращения N+1 запросов. #SpringBoot #SoftwareE
Spring Boot: используй @EntityGraph для управления стратегиями загрузки и предотвращения N+1 запросов. #SpringBoot #SoftwareEngineering 👉 Java Portal

Концепции Spring Security: OAuth2 Resource Server С одной декларацией OAuth2ResourceServer Spring Security будет: 1- Извлекат
Концепции Spring Security: OAuth2 Resource Server С одной декларацией OAuth2ResourceServer Spring Security будет: 1- Извлекать заголовок Authorization: Bearer <token> из каждого запроса 2- Валидировать подпись токена через публичный ключ Authorization Server’а (полученный через JWKS URI) 3 Проверять claims: срок действия (exp), issuer и audience 4- Заполнять SecurityContext аутентифицированным principal’ом 👉 Java Portal

Совет на ближайшие годы — изучайте ВАЙБ-КОДИНГ ИИ уже пишет код, чинит баги, генерирует тесты, документацию и помогает запуск
Совет на ближайшие годы — изучайте ВАЙБ-КОДИНГ ИИ уже пишет код, чинит баги, генерирует тесты, документацию и помогает запускать продукты быстрее, чем это делали классические команды разработки. И это уже не "будущее когда-нибудь", а реальность, которая меняет рынок уже сегодня И те, кто научится вайбкодить сейчас, будут увереннее конкурировать на рынке и зарабатывать больше тех, кто по-прежнему делает всё вручную. Стартовать с нуля поможет канал Вайб-кодинг. Там ребята круглосуточно мониторят более 320 российских и зарубежных источников и публикуют только главное: релизы, инструменты, гайды, курсы и практические кейсы. Подписывайтесь, нас уже 30 тысяч: @vibecoding_tg

Завершаемые фьючеры для чистого асинхронного программирования Устал от вложенных колбэков и шаблонного кода службы исполнения потоков. Встроенный механизм асинхронных вычислений в стандартной библиотеке версии 8 позволяет строить читаемые цепочки обработки задач без лишнего обвязочного кода. Реальный сценарий: параллельные HTTP-вызовы к нескольким API с последующим объединением результатов, цепочкой преобразований и централизованной обработкой ошибок. 👉 Java Portal

Spring Boot: с org.hibernate.SQL=DEBUG можно получить более детальный вывод Hibernate-запросов прямо в логах. #SpringBoot #Hi
Spring Boot: с org.hibernate.SQL=DEBUG можно получить более детальный вывод Hibernate-запросов прямо в логах. #SpringBoot #Hibernate 👉 Java Portal

Микросервисы — плохой выбор по умолчанию для 94% команд. Зачем разбивать приложение на набор сервисов, которым нужно общаться
Микросервисы — плохой выбор по умолчанию для 94% команд. Зачем разбивать приложение на набор сервисов, которым нужно общаться через сеть. На бумаге это выглядит как «правильный» подход. Масштабирование звучит привлекательно. Но на практике я видел, как это ломается, шесть раз. Команды из 5 инженеров поднимали 11 сервисов с несколькими очередями сообщений. Всё становилось медленнее. Деплой, который занимал минуты, растягивался до 35 минут из-за зависимостей. Отладка превращалась в кошмар: один баг — и приходится трейсить запрос через несколько сервисов и кодовых баз. Сложность не уменьшилась. Она просто распределилась. Микросервисы — это решение под масштабирование, но большинство команд внедряют их слишком рано, когда проблемы масштаба ещё нет. Если ты всё ещё работаешь на localhost, основная проблема — не масштаб. Это стабильный релиз. Когда микросервисы имеют смысл: - команды блокируют работу друг друга - части системы требуют независимого масштабирования - есть нормальная трассировка в проде, и можно отлаживать без угадывания Если этого нет — платишь налог распределённых систем без реальной выгоды. Начинай с монолита и держи модульность. Делить стоит только тогда, когда связность начинает тормозить разработку. Большинство обсуждений «нам нужны микросервисы» на деле не про архитектуру. Они про грязную кодовую базу или болезненные деплои. Сначала решаются эти проблемы. Простые системы легче понимать. Перегруженные обычно разваливаются под собственным весом. 👉 Java Portal

Spring Boot: используйте @Async только для небольших задач на оффлоадинг и только с явно заданным исполнителем. #SpringBoot #
Spring Boot: используйте @Async только для небольших задач на оффлоадинг и только с явно заданным исполнителем. #SpringBoot #SoftwareDevelopment 👉 Java Portal

Возможно, один из самых безумных репозиториев с Docker Он позволяет запускать полноценную macOS внутри Docker -контейнера и открывать её прямо из браузера. - Поднимается macOS одной командой Докера - Запуск полноценной macOS на Linux через QEMU/KVM - Открывается сразу в браузере - Поддержка нескольких версий macOS - Подходит для тестирования, CI и macOS-специфичных инструментов Такие проекты хорошо показывают, насколько далеко можно зайти с Docker и виртуализацией. Репозиторий: https://github.com/dockur/macos 👉 Java Portal

POST не идемпотентен. PUT — идемпотентен. PATCH — зависит от реализации. Ошибка в этих свойствах ломает ретраи. Идемпотентнос
POST не идемпотентен. PUT — идемпотентен. PATCH — зависит от реализации. Ошибка в этих свойствах ломает ретраи. Идемпотентность означает: один и тот же запрос даёт один и тот же результат. Это важно, потому что сеть нестабильна, а клиенты делают повторные запросы. Неидемпотентные эндпоинты дублируют побочные эффекты. Два запроса могут означать две оплаты или два заказа. GET — идемпотентен. PUT — идемпотентен. DELETE — идемпотентен. POST — не идемпотентен. PATCH — зависит (инкремент vs установка значения). Для неидемпотентных эндпоинтов используют идемпотентные ключи: клиент отправляет уникальный ключ, сервер сохраняет ключ и ответ, повтор с тем же ключом возвращает тот же результат. Так устроены платёжные системы. Без этого ретраи превращаются в дублирование операций. 👉 Java Portal

Совет по Java Используйте осмысленные имена методов, которые отражают их назначение. #JavaDev #CleanCode 👉 Java Portal
Совет по Java Используйте осмысленные имена методов, которые отражают их назначение. #JavaDev #CleanCode 👉 Java Portal

JetBrains использует IDE-нативные возможности понимания кода, чтобы делать ИИ-агентов эффективнее на больших кодовых базах. Зачем тратить время и токены на grep, если в IDE уже есть семантический поиск, навигация по символам и рефакторинги? Интересный момент: Codex, судя по наблюдениям, заметно лучше использует такие инструменты, чем Claude Code. 👉 Java Portal

Java: начиная с Java 14 можно использовать records для создания коротких неизменяемых объектов, предназначенных для хранения
Java: начиная с Java 14 можно использовать records для создания коротких неизменяемых объектов, предназначенных для хранения данных. ✅ короче обычных POJO ✅ имеют встроенные equals(), hashCode(), toString() ✅ по умолчанию неизменяемые #JavaDev #Records 👉 Java Portal

Spring Boot: использование Spring Cloud Config для централизованного управления конфигурацией — важная практика. Вместо того
Spring Boot: использование Spring Cloud Config для централизованного управления конфигурацией — важная практика. Вместо того чтобы каждый сервис хранил свой application.yml, конфигурация подтягивается из единого источника. Сначала нужно сконфигурировать сервер конфигурации. Поднимается отдельное приложение сервера конфигурации с аннотацией @EnableConfigServer и Git-репозиторий, где лежат все .yml файлы. Сервер отдает конфигурацию по HTTP, клиенты подтягивают её при старте.
<!-- Setting Up the Config Server -->
<dependency>
    <groupId>org.springframework.cloud</groupId>
    <artifactId>spring-cloud-config-server</artifactId>
</dependency>
// Enable it with @EnableConfigServer annotation

@SpringBootApplication
@EnableConfigServer
public class ConfigServerApplication {

    public static void main(String[] args) {
        SpringApplication.run(ConfigServerApplication.class, args);
    }
}
# Point it to your Git repository

spring:
  cloud:
    config:
      server:
        git:
          uri: https://github.com/your-org/config-repo
          default-label: main
          clone-on-start: true

server:
  port: 8888
Структура Git-репозитория следует соглашениям именования Spring Boot: {application-name}-{profile}.yml или {application-name}/{profile}.yml Клиентское приложение нужно настроить: добавить стартовую зависимость и минимальную конфигурацию.
<!-- Add the client dependency -->
<dependency>
    <groupId>org.springframework.cloud</groupId>
    <artifactId>spring-cloud-starter-config</artifactId>
</dependency>
# Configure the application to fetch config from the config server

spring:
  application:
    name: order-service

  config:
    import: "optional:configserver:http://localhost:8888"

  cloud:
    config:
      profile: dev

server:
  port: 8080
Динамическое обновление конфигурации без рестарта достигается через перезагружаемые бины с аннотацией @RefreshScope:
package ...;

import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;
import org.springframework.cloud.config.server.EnableConfigServer;

@SpringBootApplication
@EnableConfigServer
public class ConfigServerApplication {

    public static void main(String[] args) {
        SpringApplication.run(ConfigServerApplication.class, args);
    }
}
Конфиденциальные данные должны быть зашифрованы в файлах конфигурации:
@Service
@RefreshScope
public class PricingService {

    @Value("${pricing.discount.percentage:0}")
    private int discountPercentage;

    // This value updates when config changes, no restart needed

}
curl -X POST http://localhost:8080/actuator/refresh
👉 Java Portal

Значения области видимости финализированы в Java 25. Более чистая альтернатива переменным, привязанным к потоку, с ограниченн
Значения области видимости финализированы в Java 25. Более чистая альтернатива переменным, привязанным к потоку, с ограниченным временем жизни и хорошей совместимостью с виртуальными потоками.
static final ScopedValue<User> USER = ScopedValue.newInstance();

ScopedValue.where(USER, user)
    .run(() -> UserService.updateUser());
👉 Java Portal

Java-совет : можно использовать List.of() и Set.of() для создания неизменяемых коллекций. ✅ Это быстрый способ создать немоди
Java-совет : можно использовать List.of() и Set.of() для создания неизменяемых коллекций. ✅ Это быстрый способ создать немодифицируемые списки и множества без использования Collections.unmodifiableList(). #Java #Коллекции 👉 Java Portal