Redis е неблокиращ асинхронен сървър, няма вградена семантика в redis за блокиране при клиентска връзка до ключ е безплатно.
Забележка:Redis е отдалечено хранилище за NoSQL данни, следователно всяко заключване, което внедрявате с Redis, се „разпределя“ по проект. AcquireLock на ServiceStack използва примитивния SETNX на redis семантика на заключване, за да се гарантира, че само 1 клиентска връзка има заключването, всички останали клиенти/връзки остават блокирани, докато заключването не бъде освободено чрез използване на експоненциален множител за отмяна на повторния опит за анкета.
За да приложите разпределено заключване без допитване, ще трябва да създадете решение, което използва комбинация от поддръжката на SETNX + Pub/Sub на redis, за да уведомява чакащите клиенти, че заключването е освободено.