Возможно, стоит пояснить разницу между синхронизацией из thread/process-safe и синхронизацией с помощью Lock🤔
Наша задача — заставить разные процессы и потоки обращаться к базе данных (или любым другим ресурсам) последовательно. Чтобы не случилось так называемого race condition, то есть состояние гонки. Это когда разные потоки или процессы пытаются одновременно что-то сделать с одним и тем же ресурсом.
В этом случае нам нужна какая-то логика ограничения. Пока один процесс не завершил своё действие, другие не могут получить доступ к ресурсу.
Так вот, thread-safe и process-safe означает что отдельно взятые операции записи в БД гарантированно будут последовательны. Запросы из разных процессов или потоков выстроятся в очередь и не будут мешать друг другу. Лучше всего когда этот блок реализован на уровне БД в виде атомарных операций или ещё как-то.
Но зачем нам тогда еще дополнительный Lock?
Этот способ синхронизации используется когда процесс никак не укладывается в одно действие и должен сделать множество операций прежде чем дать доступ следующему. В этом случае процесс ставит некий глобальный Lock на ресурс и никто другой, даже получив законное право на доступ, не может ничего сделать. Все ждут пока этот Lock не будет снят.
Это решается на уровне приложения и правильность реализации полностью в вашей ответственности. Например, если забыли разблокировать или сделали перекрёстный Lock (Deadlock как на картинке), то всё зависнет в бесконечном ожидании.
#basic
Предлагаем ознакомиться с графиком вебинаров от ведущих международных издательств на неделю:
✅IEEE | Работа на платформе IEEE Xplore
📅 12 сентября 2023 в 10:00 (мск)
Регистрация доступна по ссылке.
✅Wiley | Преимущество открытого доступа: как открытый доступ повышает ваше влияние
📅14 сентября 2023 в 18:00 (мск)
Регистрация доступна по ссылке.
✅ACS | Масс-спектрометрия: как взвесить молекулу
📅14 сентября 2023 в 21:00 (мск)
Регистрация доступна по ссылке.
✅AMS | Как опубликоваться в American Mathematical Society
📅15 сентября 2023 в 10:00 (мск)
Регистрация доступна по ссылке.
#вебинар#исследования#цитирования#электронныересурсы#наука#библиотека#публикации#ACS#AMS#IEEE#Wiley
Предлагаем ознакомиться с графиком вебинаров от ведущих международных издательств на этой неделе:
✅Springer Nature | Публикация в международном издательстве
📅 15 августа 2023 в 12:00 (мск)
Регистрация доступна по ссылке.
✅World Scientific | Исследования в области Математических наук в World Scientific
📅16 августа 2023 в 11:00 (мск)
Регистрация доступна по ссылке.
✅SAE International | Вебинар-интервью от SAE International
📅16 августа 2023 в 18:00 (мск)
Регистрация доступна по ссылке.
✅AMS | Работа на платформе MathSciNet
📅17 августа 2023 в 12:00 (мск)
Регистрация доступна по ссылке.
#вебинар#исследования#цитирования#электронныересурсы#наука#библиотека#публикации#SpringerNature#WorldScientific#SAEInternational#AMS