Возможно, стоит пояснить разницу между синхронизацией из thread/process-safe и синхронизацией с помощью Lock🤔
Наша задача — заставить разные процессы и потоки обращаться к базе данных (или любым другим ресурсам) последовательно. Чтобы не случилось так называемого race condition, то есть состояние гонки. Это когда разные потоки или процессы пытаются одновременно что-то сделать с одним и тем же ресурсом.
В этом случае нам нужна какая-то логика ограничения. Пока один процесс не завершил своё действие, другие не могут получить доступ к ресурсу.
Так вот, thread-safe и process-safe означает что отдельно взятые операции записи в БД гарантированно будут последовательны. Запросы из разных процессов или потоков выстроятся в очередь и не будут мешать друг другу. Лучше всего когда этот блок реализован на уровне БД в виде атомарных операций или ещё как-то.
Но зачем нам тогда еще дополнительный Lock?
Этот способ синхронизации используется когда процесс никак не укладывается в одно действие и должен сделать множество операций прежде чем дать доступ следующему. В этом случае процесс ставит некий глобальный Lock на ресурс и никто другой, даже получив законное право на доступ, не может ничего сделать. Все ждут пока этот Lock не будет снят.
Это решается на уровне приложения и правильность реализации полностью в вашей ответственности. Например, если забыли разблокировать или сделали перекрёстный Lock (Deadlock как на картинке), то всё зависнет в бесконечном ожидании.
#basic
3 августа в Алматы собрали наших друзей и единомышленников в рамках #AXELOTLOGISTICSGAP. Все участники – из сферы торговли и логистики, кто-то уже работал с AXELOT, а кто-то только интересуется автоматизацией логистики. В дружеской обстановке удалось обсудить практически все вопросы от строительства новых складов до оптимизации и автоматизации цепей поставок. Но самое главное, что участники мероприятия принимали активное участие в обсуждении на тему логистики, автоматизации и развития бизнеса в Казахстане. Было круто! Спасибо всем участникам!
Отдельное спасибо нашим партнерам: #SystemGroupKazakhstan#ZEBRA#LOGAREON Следующий #AXELOTLOGISTICSGAP пройдёт в Ереване и Тбилиси!
UP!Date: AXELOT и LOGAREON на «передовой» цифровизации Центрально-Азиатского региона
14 ноября в Алматы состоится конференция UP!Date от SG Kazakhstan, объединяющая представителей бизнес-сообщества Центральной Азии и ведущих экспертов в области цифровых решений.
В рамках деловой программы спикеры AXELOT и LOGAREON представят совместный доклад о ключевых стратегиях цифровизации региона.
Конференция соберет вокруг себя специалистов из самых разных отраслей: торговли, логистики, производства и других направлений, нуждающихся в автоматизации и модернизации бизнес-процессов.
Эксперты AXELOT и LOGAREON расскажут о специфике цифровизации логистики в Центральной Азии, опираясь на богатый опыт проектного взаимодействия с компаниями в этом регионе. В числе наших клиентов такие крупные игроки рынка, как и другие.
Участники UP!Date смогут познакомиться с передовыми ИТ-решениями, представленными на демо-стендах, обсудить вопросы внедрения новых программных продуктов и наладить контакты с лидерами рынка цифровизации бизнес-процессов.
Завершится конференция гала-ужином, предоставляющим возможность для непринужденного общения и обмена идеями и опытом.
Не упустите шанс узнать о передовых инструментах автоматизации, пообщаться с профессионалами и открыть новые перспективы для бизнеса в Центральной Азии!
Регистрация по ссылке: https://fs11.formsite.com/fSxnfi/rwcuqpzt4k/index
#AXELOT#SYSTEMGROUPKAZAKHSTAN#UPDATE#14НОЯБРЯ#АЛМАТЫ#ZEBRA