Задать вопрос
  • Зачем нужен WebFlux?

    azerphoenix
    @azerphoenix Куратор тега Java
    Java Software Engineer
    Чем хорош вебфлакс... асинхронностью.
    По своему опыту скажу, что он имеет преимущества в плане отзывчивости перед вебом.

    Пока не вижу кейсов, при которых не хватало SpringBoot, либо MicroProfile-фреймворков.

    Уж поверьте, когда понадобится, тогда увидите нужные кейсы.

    Мне например, приходилось разрабатывать приложение, который на вход принимает огромное количество точек (более 1000), строит маршруты и возвращает инструкции. Тав вот, асинхронно (flux) я возвращал данные по мере готовности. А если вы работаете с БД, то можете вместо jdbc подключить r2dbc.
    Ответ написан
    Комментировать
  • Как спроектировать отправку данных по консюмерам?

    azerphoenix
    @azerphoenix Куратор тега Java
    Java Software Engineer
    Есть API, Который принимает на вход ID платежа. Далее кроном ходит бд и вытягивает по ID детали платежа
    (сумма, реквизит и т.п) и присваивается статус: NEW.

    Попробуйте фреймворк spring quartz. Или spring batch. С их помощью можно реализовать то, что вы хотите
    Ответ написан
    Комментировать
  • Подскажете по архитектуре "мультисервисного" приложения?

    azerphoenix
    @azerphoenix Куратор тега Java
    Java Software Engineer
    Приложение будет предоставлять несколько WEB-сервисов, за каждый будет отвечать отдельный микросервис :) Но все они будут обращаться к одной базе данных.

    Может быть вам нужны не микросервисы, а distributed monolith? Ну и реализовать паттерн shared database access

    Я хочу сделать микросервис (или модуль?), который абстрагирует БД. Т.е. он умеет читать (пока только читать, а в перспективе и писать, и кэшировать запросы) записи из БД и раздавать их другим частям приложения. Все остальные части ничего не знают про БД, а пользуются готовыми объектами.

    Тут можно и про SAGA задуматься.

    Но допустим, у меня БД на 1000 таблиц (плюс ещё таблицы взаимосвязаны что порождает вложенные Java-объекты). Это значит, мне надо сделать 1000 репозиториев, в каждом Х методов (получение по ID, получение по значению поля, одного объекта, коллекции...). И ещё 1000*Х методов в контроллерах....

    Честно, не уловил сути между количеством таблиц в БД и количеством репозиториев. Но если что можно же монорепо сделать.

    Думаю, вам не нужны микросервисы. Вам понадобится monolith, ну или максимумdistributed monolith.
    Много чего можно вынести в отдельные модули. Например, создать модуль persistence и вынести DAO туда
    Ответ написан
    2 комментария
  • Где есть приватный maven/gradle репозиторий?

    azerphoenix
    @azerphoenix Куратор тега Java
    Java Software Engineer
    Вы можете поднять Nexus репозиторий и использовать сколько угодно
    https://habr.com/ru/post/473358/
    https://www.sonatype.com/products/nexus-repository
    Ответ написан
    Комментировать
  • Как отобразить картинку на сайте из MySQL используя Spring?

    azerphoenix
    @azerphoenix Куратор тега Java
    Java Software Engineer
    Добрый день
    Вам необходимо byte{} перевести в base64.

    Чтобы получить массив байтов -
    String image = "this is base 64 image";
    byte[] photoByteArr = Base64.getDecoder().decode(String image);

    Чтобы получить base64
    String image = Base64.getEncoder().encodeToString(photo.getImage())

    А дальше гляньте, как вставить картинку в base64 - https://stackoverflow.com/questions/8499633/how-to...
    Ответ написан
    1 комментарий
  • Где выучить Spring Framework?

    azerphoenix
    @azerphoenix Куратор тега Java
    Java Software Engineer
    Вдобавок к тому, что указал коллега - https://www.youtube.com/watch?v=5ePo08sqcpk&list=P...
    Ответ написан
    2 комментария
  • В каком случае целесообразно изучать Java если ты php разработчик микросервисов?

    azerphoenix
    @azerphoenix Куратор тега Java
    Java Software Engineer
    Сам когда-то перешел из рнр разработки в Java и скажу, что очень этому рад.
    Вряд ли при переходе с рнр на джава вы начнете, как джун. Некоторые мои знакомые перешли из джава в с шарп и сохранили свои позиции миддла.
    Так что, если нравится язык, то можете смело переходить.
    Ответ написан
    2 комментария
  • Куда и как лучше перенести константу, из сервиса чтобы Spring находил её и подставлял в запрос?

    azerphoenix
    @azerphoenix Куратор тега Spring
    Java Software Engineer
    Доброго дня.
    Соглашусь с коллегой. Вам необходимо константы хранить в properties || yml файле.
    Далее ознакомьтесь с такими аннотациями, как @Value и @ConfigurationProperties
    Ответ написан
    Комментировать
  • Как принимать аргумент с командной строки во время работы приложения?

    azerphoenix
    @azerphoenix Куратор тега Java
    Java Software Engineer
    Как вариант, можете использовать JCommander
    Ответ написан
    Комментировать
  • Как связать Spring Boot и React?

    azerphoenix
    @azerphoenix Куратор тега Spring
    Java Software Engineer
    Доброго дня!
    Соглашусь с коллегой
    Лучше поднять фронт и бэк поотдельности.
    Притом, можете каждый из них засунуть поотдельности в докер. + добавить nginx.
    И будет вам счастье
    Ответ написан
    Комментировать
  • Как реализовать фильтр данных по критерию?

    azerphoenix
    @azerphoenix Куратор тега Java
    Java Software Engineer
    Добрый день.
    Конечно же есть... По факту вам нужно реализовать поиск.
    Если нужна готовая либа. то вот:
    https://github.com/tkaczmarzyk/specification-arg-r...

    Если хотите обойтись без либы, то расширьте репозиторий интерфейсом.
    JpaSpecificationExecutor<Book>
    А дальше можете передавать туда нужные спецификации (Specification)
    https://www.baeldung.com/rest-api-search-language-...
    Ответ написан
    Комментировать
  • Какой алгоритм можно использовать для оптимального распределения задач?

    azerphoenix
    @azerphoenix Автор вопроса
    Java Software Engineer
    В качестве решения данной задачи была выбрана библиотека OptaPlanner.
    https://www.optaplanner.org/
    Позволяет решать проблемы оптимизации
    Ответ написан
    Комментировать
  • Как правильно использовать данный репозиторий?

    azerphoenix
    @azerphoenix Куратор тега Java
    Java Software Engineer
    С учетом того, что этой либы нет в Maven Central и др. репозиториях, то вам нужно скачать проект себе. Сбилдить его при помощи Gradle. Созданный jar добавить в виде dependency.
    Ответ написан
    1 комментарий
  • Could not commit JPA transaction. Как исправить?

    azerphoenix
    @azerphoenix Куратор тега Java
    Java Software Engineer
    Доброго времени суток!
    1)
    ConstraintViolationException: Validation failed for classes

    Судя по всему у вас есть некий constraint, который был нарушен и потому объект не был сохранен.
    Попробуйте подебажить этот момент: Скорее всего проблема тут.
    @Getter
        @Setter
        @ElementCollection(targetClass = Role.class, fetch = FetchType.EAGER)
        @CollectionTable(name = "user_role", joinColumns = @JoinColumn(name = "user_id"))
        @Enumerated(EnumType.STRING)
        private Set<Role> roles;


    Некоторые рекомендации не связанные с вопросом:
    2) рекомендую ознакомитсья с паттерном DTO. Вам нужно принять DTO, замаппить его в Entity. Это более корректный способ.
    3) нет смысла дублировать @Getter @Setter, если эти аннотации стоят над каждым полем. Попробуйте перенести его на уровен класса.
    4)
    Ответ написан
    Комментировать
  • Как писать микросервсиы на Java + Docker?

    azerphoenix
    @azerphoenix Куратор тега Java
    Java Software Engineer
    Добрый день.
    Как отметил коллега, каждый микросервис может быть написан на разных языках и это нормальная практика.
    Теперь, что касается Java. Ну во-первых, касаемо используемых фреймворков. Удобонее писать микросервисы на Spring (Spring Boot) или Quarkus.
    Приложения могут быть запущены в Tomcat, Jetty, Netty, GlassFish и т.д.
    По умолчанию в Spring Boot есть embedded зависимость для самозапускающихся приложений. Например, embedded tomcat.

    В Node.js сервисы обычно запускают в Docker, я слышал что в Java для этого используют Tomcat, в чем разница между ними? (или это вообще разные вещи?)

    Это разные вещи. Приложения написанные в Java тоже можно контейнезировать и запустить внутри докера.

    В Node.js для запуска сервера обычно используют express.js, а что для этого используется в Java? (Servlet, Spring или что-то еще?)

    Сервлет, есть сервлет. Spring это фреймворк. А для запуска используется то, что я указал выше.

    Допустим я сделал сервер на Servlet, как запускать это в docker контейнере?

    https://sematext.com/blog/docker-java-tutorial/

    Если я запущу 10 Java сервисов в отдельных Docker контейнерах, в каждом из них будет отдельный экземпляр JRE\JDK?

    В этом и есть суть докер контейнера и микросервисов. Каждый микросервис является автономным модулем. Каждый контенер является полноценной системой.

    Преимущество Java мискросервисов перед Node.js? (или наоборот)

    Не хочу холиварить. У каждого языка и фреймворка свои преимущества. Потому, микросервисы могут быть написаны на разных языках и не только на ноде, но и на Rust, Kotlin, Go и т.д.
    https://runnable.com/docker/java/dockerize-your-ja...
    Ответ написан
    2 комментария
  • Как реализовать фоновую авторизацию?

    azerphoenix
    @azerphoenix Куратор тега Java
    Java Software Engineer
    Ну для этого обычно используют 2 токена.
    1-й access token, время жизни которого меньше. Например, 30 мин.
    2-й refresh token, время жизни которого больше. Например, 12 ч.
    Когда исстекается срок действия access token, то нужно отправить запрос с refresh token и получить новый access token
    Ответ написан
    Комментировать
  • Почему liquibase не работает в docker?

    azerphoenix
    @azerphoenix Куратор тега Java
    Java Software Engineer
    Вариантов может быть несколько.
    Например, вы указали некорректный путь до БД в конфигах liquibase. Как вариант, вы могли указать localhost вместо названия самого докер контейнера в jdbc url или еще что...
    Ответ написан
    Комментировать
  • Как правильнее сравнить на практике языки программирования, чтобы понять, какой изучать?

    azerphoenix
    @azerphoenix Куратор тега Java
    Java Software Engineer
    Мой совет следующий: в первую очередь выберите направление, в котором вы хотите развиваться.
    Если вас интересует фронт-энд, то вряд ли C# & Java вам в этом помогут.
    С другой стороны, противореча своей первой мысли, скажу что вам нужно выбрать язык со строгой типизацией и с поддержкой ООП. Например, C#, Java, Kotlin. Потому, что изучив основы работы с ООП и строгую типизацию вы сможете с легкостью изучить другие языки. Т.е. отталкиваться стоит от этих аспектов.
    Не буду начинать холливар про c# & java, так как оба языка хорошие. Оба языка "очень хорошо себя чувствуют".
    Что касается направлений, то:
    Enterprise - C#, Java, Scala, Kotlin
    Web backend (e-commerce, erp) - Python, ruby, javascript, php, typescript
    front-end - javascript, typescript
    data science - python
    Ответ написан
    4 комментария
  • Как снизить нагрузку на API?

    azerphoenix
    @azerphoenix Куратор тега Spring
    Java Software Engineer
    Клиент отправляет файл в апи и на стороне создаётся задача, далее клиенту передается идентификатор задачи по которому он будет время от времени спрашивает прогресс обработки.

    Посмотрите в сторону:
    - Spring Quartz
    - Spring Batch
    - Spring Webflux
    - DeferredResult

    Дальше профилирование, возможно вертикальное расширение.
    Ответ написан
    Комментировать
  • Как обновить большие данные в Hibernate?

    azerphoenix
    @azerphoenix Куратор тега Spring
    Java Software Engineer
    Добрый день.
    Читать все данные из БД разом в List<Foo> или любую другую коллекцию не самая лучшая идея.
    Соответственно, можно вместо коллекций использовать стримы.
    Т.е. Получить Stream<Foo>

    Пример,
    FooRepository {
    
    @QueryHints(value = {
                @QueryHint(name = HINT_FETCH_SIZE, value = "1000"),
                @QueryHint(name = HINT_CACHEABLE, value = "false"),
                @QueryHint(name = READ_ONLY, value = "true")
        })
        @Query(value = "SELECT DISTINCT f FROM Foo f")
        @Transactional(readOnly = true)
        Stream<Foo> findFoos();
    
    }


    Ну а дальше остается распараллелить стрим при помощи parallelStream()
    И произвести необходимые операции. Например, вызвать метод map() и в конце сохранить...

    Если нужно данную операцию производить периодически, то к методу, который будет производить операцию, добавьте @Async и используйте @Scheduled (или возможности Spring Batch, Spring Quartz)

    Для более подробного ответа нужно больше информации.
    Ответ написан