|
Совет по архитектуре Spring MVC
|
|||
---|---|---|---|
#18+
Добрый день! Пишу бэкенд сервера для работы с кассами. Стек технологий Java/Spring Boot/MySql В качестве БД взял MySQL (ибо фронт уже на нем). По сути сервер должен принимать задания в виде json, а кассы эти задания должны выполнять. Внутри кассы нет очереди и работают они только в одном потоке, грубо говоря так: Код: java 1. 2. 3. 4.
Идея была следующая: храним кассы в таблице devices, задания в таблице tasks. При старте сервера запускаем столько потоков, сколько девайсов в таблице devices. Потоки с определенным периодом делают селект из таблицы с заданиями и поочередно их выполняют. Апи для заданий асинхронное, т.е. снаружи прилетает post запрос, создается запись в таблице tasks и назад клиенту отдается id этого задания. По id задания клиент может отследить прогресс и результат. (GET /task/{id}) В результате получились следующие классы: Контроллеры - спринговые @RestControllerы: DeviceController TaskController Модели - стандартные Entity: Device Task Репозитории - спринговые JpaRepository: DeviceRepository TaskRepository Сервис: DeviceService - спринговый @Service, при инициализации сервис читает из базы список касс и создает на каждую по потоку (экземпляр DeviceWorker) и запускает их. Worker: DeviceWorker - собственно класс наследник thread, который получает и задания из базы и работает с кассой. Каким компонентом спринга должен быть DeviceWorker в данной ситуации, чтобы было удобно инжектить внутрь него репозитории и нормально работали транзакции. Я читал и про спринговые TaskExecutor и про Scheduler, но так и не смог понять как их применить в данной ситуации. Сейчас я передаю экземпляры репозиториев через конструктор из DeviceService при создании воркеров. Но такое ощущение, что это кривое решение и могут быть проблемы с транзакциями(хотя и работает). Репозитории внутри воркера нужны для обновления статуса девайса, таска и записи результата выполнения таска. ... |
|||
:
Нравится:
Не нравится:
|
|||
26.09.2019, 18:53 |
|
Совет по архитектуре Spring MVC
|
|||
---|---|---|---|
#18+
capfreedom228Апи для заданий асинхронное, т.е. снаружи прилетает post запрос, создается запись в таблице tasks игде обоснование нужности асинхронности? ... |
|||
:
Нравится:
Не нравится:
|
|||
26.09.2019, 21:41 |
|
Совет по архитектуре Spring MVC
|
|||
---|---|---|---|
#18+
capfreedom228, Post кто делает? Человек? Тогда вариант без асинхронности - делает задание и вкладка кассы1 висит 15 сек. Вполне допустимо. Надо быстрее, жмакает новую вкладку касса2 и тоже ждет. Вариант асинхронный - 2 веб приложения. Приложение А просто пишет в бд задание. Приложение Б это демон или сервис без ГУИ круглосуточно их выполняет. ... |
|||
:
Нравится:
Не нравится:
|
|||
26.09.2019, 22:00 |
|
Совет по архитектуре Spring MVC
|
|||
---|---|---|---|
#18+
PetroNotC Sharp, Асинхронность нужна, т.к. задания могут выполняться неопределенно долго. И если будет 5 одновременных заданий то последний зависнет больше чем на минуту, а это неприемлимо. ... |
|||
:
Нравится:
Не нравится:
|
|||
26.09.2019, 22:18 |
|
Совет по архитектуре Spring MVC
|
|||
---|---|---|---|
#18+
PetroNotC Sharp, Post из фронта прилетает из браузера. ... |
|||
:
Нравится:
Не нравится:
|
|||
26.09.2019, 22:19 |
|
Совет по архитектуре Spring MVC
|
|||
---|---|---|---|
#18+
capfreedom228PetroNotC Sharp, Асинхронность нужна, т.к. задания могут выполняться неопределенно долго. И если будет 5 одновременных заданий то последний зависнет больше чемн на минуту, а это неприемлимо.контейнер веб сервера при занятом сервлете запускает новый экземпляр. Значит 5 вкладок выполнятся вместе за 15 сек. Проверь ... |
|||
:
Нравится:
Не нравится:
|
|||
26.09.2019, 22:23 |
|
Совет по архитектуре Spring MVC
|
|||
---|---|---|---|
#18+
Дмитрий Мухcapfreedom228, в мире Java нет аналогов Hangfire ?в мире шарпа нет контейнера? https://ru.m.wikipedia.org/wiki/Контейнер_сервлетов ... |
|||
:
Нравится:
Не нравится:
|
|||
26.09.2019, 22:35 |
|
Совет по архитектуре Spring MVC
|
|||
---|---|---|---|
#18+
capfreedom228Каким компонентом спринга должен быть DeviceWorker в данной ситуации, чтобы было удобно инжектить внутрь него репозитории и нормально работали транзакции Я бы попробовал обыкновенный спринговый bean с одним публичным методом и аннотацией Async - почитай про нее. Если кол-во девайсов число постоянное на момент старта, то просто настроить taskexecutor с пулом нужного размера ... |
|||
:
Нравится:
Не нравится:
|
|||
26.09.2019, 22:53 |
|
Совет по архитектуре Spring MVC
|
|||
---|---|---|---|
#18+
PetroNotC Sharpcapfreedom228PetroNotC Sharp, Асинхронность нужна, т.к. задания могут выполняться неопределенно долго. И если будет 5 одновременных заданий то последний зависнет больше чемн на минуту, а это неприемлимо.контейнер веб сервера при занятом сервлете запускает новый экземпляр. Значит 5 вкладок выполнятся вместе за 15 сек. Проверь касса в 1 поток работает ... |
|||
:
Нравится:
Не нравится:
|
|||
26.09.2019, 23:20 |
|
Совет по архитектуре Spring MVC
|
|||
---|---|---|---|
#18+
chpashacapfreedom228Каким компонентом спринга должен быть DeviceWorker в данной ситуации, чтобы было удобно инжектить внутрь него репозитории и нормально работали транзакции Я бы попробовал обыкновенный спринговый bean с одним публичным методом и аннотацией Async - почитай про нее. Если кол-во девайсов число постоянное на момент старта, то просто настроить taskexecutor с пулом нужного размера хотелось иметь возможность добавлять кассы без рестарта ... |
|||
:
Нравится:
Не нравится:
|
|||
26.09.2019, 23:21 |
|
Совет по архитектуре Spring MVC
|
|||
---|---|---|---|
#18+
capfreedom228, Не понял. Касса синглетон или можно сделать Kassa a = new Kassa(settings); Kassa б = new Kassa(settings); ? ... |
|||
:
Нравится:
Не нравится:
|
|||
26.09.2019, 23:24 |
|
Совет по архитектуре Spring MVC
|
|||
---|---|---|---|
#18+
PetroNotC Sharpcapfreedom228, Не понял. Касса синглетон или можно сделать Kassa a = new Kassa(settings); Kassa б = new Kassa(settings); ? сделать можно, но когда ты вызовешь a.open(); то b.open(); - выдаст ошибку подключения. ... |
|||
:
Нравится:
Не нравится:
|
|||
26.09.2019, 23:26 |
|
Совет по архитектуре Spring MVC
|
|||
---|---|---|---|
#18+
capfreedom228выдаст ошибку подключения.то есть нужна асинхронность, но касса категорически однопоточна? Фиктивная нужна? Зачем? ... |
|||
:
Нравится:
Не нравится:
|
|||
26.09.2019, 23:32 |
|
Совет по архитектуре Spring MVC
|
|||
---|---|---|---|
#18+
Чтобы касса не простаивала))))))))? ... |
|||
:
Нравится:
Не нравится:
|
|||
26.09.2019, 23:33 |
|
Совет по архитектуре Spring MVC
|
|||
---|---|---|---|
#18+
chpasha, Выяснили что аннотация не подходит ... |
|||
:
Нравится:
Не нравится:
|
|||
26.09.2019, 23:34 |
|
Совет по архитектуре Spring MVC
|
|||
---|---|---|---|
#18+
PetroNotC SharpЧтобы касса не простаивала))))))))? Такое тз ... |
|||
:
Нравится:
Не нравится:
|
|||
26.09.2019, 23:34 |
|
Совет по архитектуре Spring MVC
|
|||
---|---|---|---|
#18+
capfreedom228PetroNotC SharpЧтобы касса не простаивала))))))))? Такое тзтогда один вариант Второй в 21980326 ... |
|||
:
Нравится:
Не нравится:
|
|||
26.09.2019, 23:37 |
|
Совет по архитектуре Spring MVC
|
|||
---|---|---|---|
#18+
PetroNotC Sharpcapfreedom228выдаст ошибку подключения.то есть нужна асинхронность, но касса категорически однопоточна? Фиктивная нужна? Зачем? Чеки электронные и клиенту нет смысла ждать. ... |
|||
:
Нравится:
Не нравится:
|
|||
26.09.2019, 23:39 |
|
Совет по архитектуре Spring MVC
|
|||
---|---|---|---|
#18+
capfreedom228Чеки электронные и клиенту нет смысла ждать.все хуже. Касса синглетон. Решение выше. Удачи. ... |
|||
:
Нравится:
Не нравится:
|
|||
26.09.2019, 23:46 |
|
Совет по архитектуре Spring MVC
|
|||
---|---|---|---|
#18+
chpashacapfreedom228Каким компонентом спринга должен быть DeviceWorker в данной ситуации, чтобы было удобно инжектить внутрь него репозитории и нормально работали транзакции Я бы попробовал обыкновенный спринговый bean с одним публичным методом и аннотацией Async - почитай про нее. Если кол-во девайсов число постоянное на момент старта, то просто настроить taskexecutor с пулом нужного размера Можно еще лоадбалансер настроить на пару тройку серверов, чтоб уж совсем все было хорошо. ... |
|||
:
Нравится:
Не нравится:
|
|||
27.09.2019, 00:10 |
|
Совет по архитектуре Spring MVC
|
|||
---|---|---|---|
#18+
capfreedom228chpashaпропущено... Я бы попробовал обыкновенный спринговый bean с одним публичным методом и аннотацией Async - почитай про нее. Если кол-во девайсов число постоянное на момент старта, то просто настроить taskexecutor с пулом нужного размера хотелось иметь возможность добавлять кассы без рестарта А параметром номер кассы никак нельзя передать? ... |
|||
:
Нравится:
Не нравится:
|
|||
27.09.2019, 00:12 |
|
Совет по архитектуре Spring MVC
|
|||
---|---|---|---|
#18+
Sergunkacapfreedom228пропущено... хотелось иметь возможность добавлять кассы без рестарта А параметром номер кассы никак нельзя передать? В таске зафиксирован id кассы, т.е. каждый таск предназначен конкретной кассе. ... |
|||
:
Нравится:
Не нравится:
|
|||
27.09.2019, 00:32 |
|
Совет по архитектуре Spring MVC
|
|||
---|---|---|---|
#18+
capfreedom228Sergunkaпропущено... А параметром номер кассы никак нельзя передать? В таске зафиксирован id кассы, т.е. каждый таск предназначен конкретной кассе. Как то уж совсем тупенько. Вот к примеру мой учебный пример на основе пулэкзекьютора написанный пятью годам ранее. Классическая задача Дейкстры - спящий парикмахер https://vyatkins.wordpress.com/2013/12/21/sleeping-barber-problem/ https://github.com/SVyatkin/KafkaSleepingBarberProblem/blob/master/src/main/java/com/sleeping/barber/blockingQueue/BlockingQueueSleepingBarbersPoolExecutor.java Нет там большой проблемы передать параметр Код: java 1. 2. 3. 4. 5. 6. 7. 8. 9. 10. 11. 12. 13. 14. 15. 16. 17. 18. 19. 20. 21. 22. 23. 24. 25. 26. 27. 28. 29. 30. 31. 32. 33. 34.
Что там за таск такой? Код покажи? ... |
|||
:
Нравится:
Не нравится:
|
|||
27.09.2019, 04:33 |
|
Совет по архитектуре Spring MVC
|
|||
---|---|---|---|
#18+
capfreedom228Идея была следующая: храним кассы в таблице devices, задания в таблице tasks. При старте сервера запускаем столько потоков, сколько девайсов в таблице devices. Потоки с определенным периодом делают селект из таблицы с заданиями и поочередно их выполняют. Апи для заданий асинхронное, т.е. снаружи прилетает post запрос, создается запись в таблице tasks и назад клиенту отдается id этого задания. По id задания клиент может отследить прогресс и результат. (GET /task/{id}) ИМХО не делать брокер/очередь сообщений на БД, а воспользоваться соответствующим инструментом (MQ, Kafka и т.д.) Результат отправлять так же по тому же брокеру сообщений. Связь можно сделать, по CorellationID. Создается в сессии контролера и там же храниться, нужен чтобы получить соответствующий ответ. ... |
|||
:
Нравится:
Не нравится:
|
|||
27.09.2019, 07:00 |
|
Совет по архитектуре Spring MVC
|
|||
---|---|---|---|
#18+
Sergunka, Он же говорит что райзе будет при одновременной работе двух экземпляров, а при async так и слуится. ... |
|||
:
Нравится:
Не нравится:
|
|||
27.09.2019, 08:03 |
|
Совет по архитектуре Spring MVC
|
|||
---|---|---|---|
#18+
mad_nazgulcapfreedom228Идея была следующая: храним кассы в таблице devices, задания в таблице tasks. При старте сервера запускаем столько потоков, сколько девайсов в таблице devices. Потоки с определенным периодом делают селект из таблицы с заданиями и поочередно их выполняют. Апи для заданий асинхронное, т.е. снаружи прилетает post запрос, создается запись в таблице tasks и назад клиенту отдается id этого задания. По id задания клиент может отследить прогресс и результат. (GET /task/{id}) ИМХО не делать брокер/очередь сообщений на БД, а воспользоваться соответствующим инструментом (MQ, Kafka и т.д.) Результат отправлять так же по тому же брокеру сообщений. Связь можно сделать, по CorellationID. Создается в сессии контролера и там же храниться, нужен чтобы получить соответствующий ответ. Не хотелось ради одной очереди тянуть какое то дополнительное ПО. ... |
|||
:
Нравится:
Не нравится:
|
|||
27.09.2019, 11:17 |
|
Совет по архитектуре Spring MVC
|
|||
---|---|---|---|
#18+
capfreedom228, Очередь либо в базе, либо в аппСервере чере ПО. Больше никак. В базе свою очередь сделать элементарно. ... |
|||
:
Нравится:
Не нравится:
|
|||
27.09.2019, 11:20 |
|
Совет по архитектуре Spring MVC
|
|||
---|---|---|---|
#18+
Попробую использовать подход из этой статьи https://thebackendguy.com/spring-schedule-tasks-or-cron-jobs-dynamically/ ... |
|||
:
Нравится:
Не нравится:
|
|||
27.09.2019, 11:27 |
|
Совет по архитектуре Spring MVC
|
|||
---|---|---|---|
#18+
capfreedom228Попробую использовать подход из этой статьи https://thebackendguy.com/spring-schedule-tasks-or-cron-jobs-dynamically/ шедулер это будильник. А тебе надо загрузить зданиями СВОБОДНУЮ кассу. Периодичности тут нет. Не выйдет. Либо ТЗ коряво описал. ... |
|||
:
Нравится:
Не нравится:
|
|||
27.09.2019, 11:35 |
|
Совет по архитектуре Spring MVC
|
|||
---|---|---|---|
#18+
PetroNotC Sharpcapfreedom228Попробую использовать подход из этой статьи https://thebackendguy.com/spring-schedule-tasks-or-cron-jobs-dynamically/ шедулер это будильник. А тебе надо загрузить зданиями СВОБОДНУЮ кассу. Периодичности тут нет. Не выйдет. Либо ТЗ коряво описал. Шедулер выполняет действия с определенным периодом, в моем случае действия - селект из базы заданий для конкретной кассы и их выполнение. Соответственно могу запустить на каждую кассу по такому шедулеру. ... |
|||
:
Нравится:
Не нравится:
|
|||
27.09.2019, 11:42 |
|
Совет по архитектуре Spring MVC
|
|||
---|---|---|---|
#18+
PetroNotC Sharpcapfreedom228Попробую использовать подход из этой статьи https://thebackendguy.com/spring-schedule-tasks-or-cron-jobs-dynamically/ шедулер это будильник. А тебе надо загрузить зданиями СВОБОДНУЮ кассу. Периодичности тут нет. Не выйдет. Либо ТЗ коряво описал. На счет свободной кассы: В таске прописано на какой кассе оно должно быть выполнено, т.е. не свободную. ... |
|||
:
Нравится:
Не нравится:
|
|||
27.09.2019, 11:43 |
|
Совет по архитектуре Spring MVC
|
|||
---|---|---|---|
#18+
capfreedom228Шедулер выполняет действия с определенным периодом , ПО ВРЕМЕНИ карл! Например, каждый вторник на 10 утра. Или запуск задачи через 10 минут после POST юзверя. capfreedom228могу запустить на каждую кассу Ты гоаорил что касса А Б не могут одновременно. ... |
|||
:
Нравится:
Не нравится:
|
|||
27.09.2019, 11:46 |
|
Совет по архитектуре Spring MVC
|
|||
---|---|---|---|
#18+
capfreedom228На счет свободной кассы: В таске прописано на какой кассе оно должно быть выполнено, т.е. не свободнуюэто ТЗ или твоя придумка? Если ТЗ покажи цитату из первой страницы топика. ... |
|||
:
Нравится:
Не нравится:
|
|||
27.09.2019, 11:49 |
|
Совет по архитектуре Spring MVC
|
|||
---|---|---|---|
#18+
PetroNotC Sharpcapfreedom228На счет свободной кассы: В таске прописано на какой кассе оно должно быть выполнено, т.е. не свободнуюэто ТЗ или твоя придумка? Если ТЗ покажи цитату из первой страницы топика. Это ТЗ, я забыл это написать в первом посте. ... |
|||
:
Нравится:
Не нравится:
|
|||
27.09.2019, 11:53 |
|
Совет по архитектуре Spring MVC
|
|||
---|---|---|---|
#18+
PetroNotC Sharpcapfreedom228Шедулер выполняет действия с определенным периодом , ПО ВРЕМЕНИ карл! Например, каждый вторник на 10 утра. Или запуск задачи через 10 минут после POST юзверя. capfreedom228могу запустить на каждую кассу Ты гоаорил что касса А Б не могут одновременно. Я говорил, что ты не можешь к одной и той же кассе подключиться одновременно разными потоками. ... |
|||
:
Нравится:
Не нравится:
|
|||
27.09.2019, 11:54 |
|
Совет по архитектуре Spring MVC
|
|||
---|---|---|---|
#18+
capfreedom228PetroNotC Sharpпропущено... ПО ВРЕМЕНИ карл! Например, каждый вторник на 10 утра. Или запуск задачи через 10 минут после POST юзверя. пропущено... Ты гоаорил что касса А Б не могут одновременно. Я говорил, что ты не можешь к одной и той же кассе подключиться одновременно разными потоками. На счет ПО ВРЕМЕНИ - не вижу противоречия. Раз 5 секунд например будет делать селект из таблицы с заданиями и их выполнять. ... |
|||
:
Нравится:
Не нравится:
|
|||
27.09.2019, 11:57 |
|
Совет по архитектуре Spring MVC
|
|||
---|---|---|---|
#18+
capfreedom228Это ТЗ, я забыл это написать в первом посте.поэтому мы копаемся вторую страницу в детском вопросе capfreedom228Я говорил, что ты не можешь к одной и той же кассе подключиться одновременно разными потоками. Выше мой вопрос с ДВУМЯ ЭКЗЕМЛЯРАМИ var a =, var b= видим? Ответь еще раз. ... |
|||
:
Нравится:
Не нравится:
|
|||
27.09.2019, 12:12 |
|
Совет по архитектуре Spring MVC
|
|||
---|---|---|---|
#18+
capfreedom228Не хотелось ради одной очереди тянуть какое то дополнительное ПО. Тогда имплементация embedded MQ. Есть еще Spring Integration... Но мне лично не очень понравилось, но вы можете посмотреть. ... |
|||
:
Нравится:
Не нравится:
|
|||
27.09.2019, 12:13 |
|
Совет по архитектуре Spring MVC
|
|||
---|---|---|---|
#18+
capfreedom228Раз 5 секунд например будет делать селект из таблицы с заданиями и их выполнять.да. Выше сказал, это приложение #2 демон в линукс. Никакого отношения к приложению с post он не имеет. Тогда согласен. ... |
|||
:
Нравится:
Не нравится:
|
|||
27.09.2019, 12:14 |
|
Совет по архитектуре Spring MVC
|
|||
---|---|---|---|
#18+
mad_nazgulcapfreedom228Не хотелось ради одной очереди тянуть какое то дополнительное ПО. Тогда имплементация embedded MQ. Есть еще Spring Integration... Но мне лично не очень понравилось, но вы можете посмотреть.это тоже дополнительное ПО ... |
|||
:
Нравится:
Не нравится:
|
|||
27.09.2019, 12:15 |
|
Совет по архитектуре Spring MVC
|
|||
---|---|---|---|
#18+
PetroNotC Sharpcapfreedom228Это ТЗ, я забыл это написать в первом посте.поэтому мы копаемся вторую страницу в детском вопросе capfreedom228Я говорил, что ты не можешь к одной и той же кассе подключиться одновременно разными потоками. Выше мой вопрос с ДВУМЯ ЭКЗЕМЛЯРАМИ var a =, var b= видим? Ответь еще раз. Если делать так: Код: java 1. 2. 3. 4.
то конфликта не будет, разные кассы могут работать одновременно(что мне казалось очевидным). В твоем примере было так: Код: java 1. 2.
т.е. оба экземпляра смотрят на одну кассу. ... |
|||
:
Нравится:
Не нравится:
|
|||
27.09.2019, 12:24 |
|
Совет по архитектуре Spring MVC
|
|||
---|---|---|---|
#18+
capfreedom228 Код: java 1. 2.
т.е. оба экземпляра смотрят на одну кассу.ну ты даешь)))))) ... |
|||
:
Нравится:
Не нравится:
|
|||
27.09.2019, 12:28 |
|
Совет по архитектуре Spring MVC
|
|||
---|---|---|---|
#18+
PetroNotC Sharpcapfreedom228 Код: java 1. 2.
т.е. оба экземпляра смотрят на одну кассу.ну ты даешь)))))) ??? ... |
|||
:
Нравится:
Не нравится:
|
|||
27.09.2019, 12:28 |
|
Совет по архитектуре Spring MVC
|
|||
---|---|---|---|
#18+
capfreedom228, Если мне кто из java скажет что это было очевидно - посыплю голову пеплом))). Mayton, это было очевидно? ... |
|||
:
Нравится:
Не нравится:
|
|||
27.09.2019, 12:34 |
|
Совет по архитектуре Spring MVC
|
|||
---|---|---|---|
#18+
capfreedom228т.е. оба экземпляра смотрят на одну кассу.если Kassa синглтон ... |
|||
:
Нравится:
Не нравится:
|
|||
27.09.2019, 12:36 |
|
Совет по архитектуре Spring MVC
|
|||
---|---|---|---|
#18+
В первом посте, я писал, что если сделать a.open(); то больше никто не может подключиться к этой кассе. Извиняюсь, если расписал недостаточно подробно. ... |
|||
:
Нравится:
Не нравится:
|
|||
27.09.2019, 12:39 |
|
Совет по архитектуре Spring MVC
|
|||
---|---|---|---|
#18+
capfreedom228В первом посте, я писал, что если сделать a.open(); то больше никто не может подключиться к этой кассе. Извиняюсь, если расписал недостаточно подробно.проехали ... |
|||
:
Нравится:
Не нравится:
|
|||
27.09.2019, 12:44 |
|
Совет по архитектуре Spring MVC
|
|||
---|---|---|---|
#18+
capfreedom228 Код: java 1.
получается, нас в контексте задачи не интересует параметер settings1 или 2... Это твои проблемы. ЗАЧЕМ ЗАДАНИЕ ПРИВЯЗЫВАТЬ К КАССЕ? ... |
|||
:
Нравится:
Не нравится:
|
|||
27.09.2019, 12:46 |
|
Совет по архитектуре Spring MVC
|
|||
---|---|---|---|
#18+
вадяcapfreedom228т.е. оба экземпляра смотрят на одну кассу.если Kassa синглтоннет). Если в переменной settings одна и та же КассаИменемПети) ... |
|||
:
Нравится:
Не нравится:
|
|||
27.09.2019, 12:48 |
|
Совет по архитектуре Spring MVC
|
|||
---|---|---|---|
#18+
PetroNotC Sharpcapfreedom228 Код: java 1.
получается, нас в контексте задачи не интересует параметер settings1 или 2... Это твои проблемы. ЗАЧЕМ ЗАДАНИЕ ПРИВЯЗЫВАТЬ К КАССЕ? Я в курсе, что это мои проблемы. Клиент формирует задание для конкретной кассы, такова бизнес логика. Заданием может быть например перезагрузка кассы, или обновление каких то настроек или печать чека, все это относится к конкретной кассе. ... |
|||
:
Нравится:
Не нравится:
|
|||
27.09.2019, 12:52 |
|
Совет по архитектуре Spring MVC
|
|||
---|---|---|---|
#18+
PetroNotC Sharpнет). Если в переменной settings одна и та же КассаИменемПети) ну да если PetroNotC Sharpполучается, нас в контексте задачи не интересует параметер settings1 или 2... ... |
|||
:
Нравится:
Не нравится:
|
|||
27.09.2019, 12:53 |
|
Совет по архитектуре Spring MVC
|
|||
---|---|---|---|
#18+
capfreedom228, Наконец то ты сформировал все ТЗ. Решение в моем первом посте. Гадал на кофейной гуще. ... |
|||
:
Нравится:
Не нравится:
|
|||
27.09.2019, 13:04 |
|
Совет по архитектуре Spring MVC
|
|||
---|---|---|---|
#18+
PetroNotC Sharpcapfreedom228, Наконец то ты сформировал все ТЗ. Решение в моем первом посте. Гадал на кофейной гуще. Спасибо, но это абстрактное решение. В нем ни слова про Spring. Вопрос то был именно в том, чтобы выяснить, как в рамках спринга это красиво реализовать. Или выяснить, что стандартные компоненты не подходят и надо либо искать другие, либо писать свои. ... |
|||
:
Нравится:
Не нравится:
|
|||
27.09.2019, 13:19 |
|
Совет по архитектуре Spring MVC
|
|||
---|---|---|---|
#18+
capfreedom228В нем ни слова про Spring.а задача не для спринга)) Что поделать. Тут противоречие. Либо просто и логично, либо спринг, будь он неладен)) ... |
|||
:
Нравится:
Не нравится:
|
|||
27.09.2019, 13:25 |
|
Совет по архитектуре Spring MVC
|
|||
---|---|---|---|
#18+
capfreedom228, Стоп. Спинг MVC это ГУИ. Образец - Цветочный магазин. И не мешай сюда свои кассы убогие. ... |
|||
:
Нравится:
Не нравится:
|
|||
27.09.2019, 13:27 |
|
Совет по архитектуре Spring MVC
|
|||
---|---|---|---|
#18+
Sergunkacapfreedom228пропущено... В таске зафиксирован id кассы, т.е. каждый таск предназначен конкретной кассе. Как то уж совсем тупенько. Вот к примеру мой учебный пример на основе пулэкзекьютора написанный пятью годам ранее. Классическая задача Дейкстры - спящий парикмахер https://vyatkins.wordpress.com/2013/12/21/sleeping-barber-problem/ https://github.com/SVyatkin/KafkaSleepingBarberProblem/blob/master/src/main/java/com/sleeping/barber/blockingQueue/BlockingQueueSleepingBarbersPoolExecutor.java Нет там большой проблемы передать параметр Код: java 1. 2. 3. 4. 5. 6. 7. 8. 9. 10. 11. 12. 13. 14. 15. 16. 17. 18. 19. 20. 21. 22. 23. 24. 25. 26. 27. 28. 29. 30. 31. 32. 33. 34.
Что там за таск такой? Код покажи? Заданием может быть например перезагрузка кассы, или обновление каких то настроек или печать чека, все это относится к конкретной кассе. Вот например задание на печать чека: Код: javascript 1. 2. 3. 4. 5. 6. 7. 8. 9. 10. 11. 12. 13. 14. 15. 16. 17. 18. 19. 20. 21. 22. 23. 24. 25. 26. 27. 28. 29. 30. 31. 32. 33. 34. 35. 36. 37. 38. 39. 40. 41. 42. 43. 44. 45. 46.
... |
|||
:
Нравится:
Не нравится:
|
|||
27.09.2019, 13:30 |
|
Совет по архитектуре Spring MVC
|
|||
---|---|---|---|
#18+
capfreedom228как в рамках спринга это красиво реализовать что мешает заинжектить applicationcontext и инстанциировать нужное кол-во бинов-касс? ... |
|||
:
Нравится:
Не нравится:
|
|||
27.09.2019, 13:54 |
|
Совет по архитектуре Spring MVC
|
|||
---|---|---|---|
#18+
chpashacapfreedom228как в рамках спринга это красиво реализовать что мешает заинжектить applicationcontext и инстанциировать нужное кол-во бинов-касс? Думаю ничего не мешает, я только толкового примера не нашел как это делать. ... |
|||
:
Нравится:
Не нравится:
|
|||
27.09.2019, 15:44 |
|
Совет по архитектуре Spring MVC
|
|||
---|---|---|---|
#18+
PetroNotC Sharpcapfreedom228, Стоп. Спинг MVC это ГУИ. Образец - Цветочный магазин. И не мешай сюда свои кассы убогие. Если ГУИ в твоем мире выглядит как json, то да ГУИ. ... |
|||
:
Нравится:
Не нравится:
|
|||
27.09.2019, 15:49 |
|
Совет по архитектуре Spring MVC
|
|||
---|---|---|---|
#18+
capfreedom228PetroNotC Sharp, Post из фронта прилетает из браузера. capfreedom228Если ГУИ в твоем мире выглядит как json, то да ГУИ. У меня с памятью все отлично. А у вас? ... |
|||
:
Нравится:
Не нравится:
|
|||
27.09.2019, 15:53 |
|
Совет по архитектуре Spring MVC
|
|||
---|---|---|---|
#18+
capfreedom228Думаю ничего не мешает, я только толкового примера не нашел как это делать 1) scope = prototype у бина 2) инжектим ApplicationContext в то место, где бины создавать надо, context.getBean(DeviceWorker.class) дальше как по архитектуре удобнее - либо с помощью async, либо вручную с помощью Executors ... |
|||
:
Нравится:
Не нравится:
|
|||
27.09.2019, 16:22 |
|
Совет по архитектуре Spring MVC
|
|||
---|---|---|---|
#18+
chpashacapfreedom228Думаю ничего не мешает, я только толкового примера не нашел как это делать 1) scope = prototype у бина 2) инжектим ApplicationContext в то место, где бины создавать надо, context.getBean(DeviceWorker.class) дальше как по архитектуре удобнее - либо с помощью async, либо вручную с помощью Executors Спасибо, попробую. ... |
|||
:
Нравится:
Не нравится:
|
|||
27.09.2019, 17:51 |
|
Совет по архитектуре Spring MVC
|
|||
---|---|---|---|
#18+
chpashacapfreedom228Думаю ничего не мешает, я только толкового примера не нашел как это делать 1) scope = prototype у бина 2) инжектим ApplicationContext в то место, где бины создавать надо, context.getBean(DeviceWorker.class) дальше как по архитектуре удобнее - либо с помощью async, либо вручную с помощью Executors Это антипаттерн, дети, не делайте так. Для просветления смотреть Жеку Борисова ... |
|||
:
Нравится:
Не нравится:
|
|||
27.09.2019, 19:55 |
|
Совет по архитектуре Spring MVC
|
|||
---|---|---|---|
#18+
fixxerЭто антипаттерн, дети с удовольствием посмотрю на более кошерный способ создать N экземпляров в рантайме. дядя. fixxerДля просветления смотреть какая минута? fixxerЖеку Борисова Жеке привет ... |
|||
:
Нравится:
Не нравится:
|
|||
27.09.2019, 22:16 |
|
Совет по архитектуре Spring MVC
|
|||
---|---|---|---|
#18+
fixxerсороковая минутаобъяснение про контекст имело смысл во времена xml - говорить о том, что у нас в классе появилась явная зависимость от spring при наличии N аннотаций того же спринга в этом же классе, серьезно? Но метод с абстрактным классом действительно неплох. Я даже когда-то о нем помнил ... |
|||
:
Нравится:
Не нравится:
|
|||
28.09.2019, 00:13 |
|
Совет по архитектуре Spring MVC
|
|||
---|---|---|---|
#18+
chpashafixxerсороковая минутаобъяснение про контекст имело смысл во времена xml - говорить о том, что у нас в классе появилась явная зависимость от spring при наличии N аннотаций того же спринга в этом же классе, серьезно? Но метод с абстрактным классом действительно неплох. Я даже когда-то о нем помнил Вообще method-injection был с первой версии спринга (когда он еще назывался interface21). За 13 лет использования спринга в проектах, мне такой способ di ни разу не понадобился. Написания собственного скопа так же ни разу не понадобилось, вполне хватало (protoype, singleton) + 3 которые добавлены в SpringMVC. Вообщем просветления при просмотре не наступило. Вообще если бы в проекте было бы > 50 бинов с method-injection, то я бы как раз такой вариант посчитал за антипатерн. Конфигурационного кода много, а только от него близко к нулю. Ну и вариант с переопределением scope, тоже так себе. В Spring-е такое можно сделать кучей способов. Я бы наверно выбрал просто реализовав @Component ColorProvider и просто заинжектил бы его. ... |
|||
:
Нравится:
Не нравится:
|
|||
28.09.2019, 14:47 |
|
Совет по архитектуре Spring MVC
|
|||
---|---|---|---|
#18+
Нашел кстати еще 2 вариации на тему lookup-метода, собственно @Lookup анотация (по сути тоже самое без явного конфига) и паттерн Provider (через ObjectFactoryCreatingFactoryBean или ProviderCreatingFactoryBean). Последний вариант мне нравится больше всего, т.к. в нем меньше всего магии. когда видишь вариант с Lookup год спустя Код: java 1. 2. 3. 4. 5. 6. 7. 8.
то можно слегка прифигеть, что за чудеса тут творятся. с абстрактным методом чутка лучше, т.к. можно скакнуть к его имплементации и понять, что происходит. Но имхо лучший вариант, если мы инжектим фабрику объектов. К счастью случай действительно довольно редкий. ... |
|||
:
Нравится:
Не нравится:
|
|||
28.09.2019, 15:49 |
|
|
start [/forum/topic.php?all=1&fid=59&tid=2121100]: |
0ms |
get settings: |
8ms |
get forum list: |
14ms |
check forum access: |
4ms |
check topic access: |
4ms |
track hit: |
169ms |
get topic data: |
10ms |
get forum data: |
2ms |
get page messages: |
79ms |
get tp. blocked users: |
1ms |
others: | 12ms |
total: | 303ms |
0 / 0 |