您好, 欢迎来到 !    登录 | 注册 | | 设为首页 | 收藏本站

UNLINK命令是否总是比DEL命令好?

UNLINK命令是否总是比DEL命令好?

在讨论哪种更好之前,让我们看一下这些命令之间的区别。双方DELUNLINK释放阻塞模式的重要组成部分。区别在于他们释放价值部分的方式。

DEL总是在阻塞模式下释放值部分。但是,如果该值太大,例如对于LIST或分配过多HASH,则会长时间阻止Redis。为了解决该问题,Redis实现了UNLINK命令,即“非阻塞”删除

其实,UNLINK是 。如果该值很小,例如的大小LISTHASH小于64,则该值将立即释放。这样,UNLINK与几乎相同DEL,除了它比花费更多的函数调用DEL。但是,如果值很大,则Redis会将值放入列表中,并且该值将由另一个线程释放,即非阻塞释放。这样,主线程必须与后台线程进行一些同步,这也是一个代价。

总之,如果该值很小,DEL则至少等于和UNLINK。如果值非常大(例如,LIST包含成千上万个项目),UNLINK则比更好DEL。您始终可以安全地替换DELUNLINK。但是,如果发现线程同步成为问题(多线程总是令人头疼),则可以回滚到DEL

其他 2022/1/1 18:15:56 有516人围观

撰写回答


你尚未登录,登录后可以

和开发者交流问题的细节

关注并接收问题和回答的更新提醒

参与内容的编辑和改进,让解决方法与时俱进

请先登录

推荐问题


联系我
置顶