키가 만료되거나 DEL 삭제 명령이 사용되면 Redis는 전역 해시 테이블에서 객체를 제거할 뿐만 아니라 객체에 할당된 메모리도 해제합니다. 큰 키가 발견되면 메모리를 해제하면 메인 스레드가 차단됩니다.
이를 위해 Redis 4.0에서는 개체 메모리 해제 작업을 바이오 백그라운드 스레드에 넣어 실행하는 UNLINK 명령을 도입했습니다. 이는 메인 스레드 차단을 효과적으로 줄여줍니다.
Redis 6.0은 한 단계 더 나아가 Lazy-Free 관련 구성을 도입합니다. 구성이 활성화되면 "개체 해제" 작업이 키 만료 및 DEL 명령 내에서 "비동기적으로 실행"됩니다.
void delCommand(client *c) { delGenericCommand(c,server.lazyfree_lazy_user_del);}void delGenericCommand(client *c, int lazy) { int numdel = 0, j; for (j = 1; j < c->argc; j++) { expireIfNeeded(c->db,c->argv[j]); // 开启 lazy free 则使用异步删除 int deleted = lazy ? dbAsyncDelete(c->db,c->argv[j]) : dbSyncDelete(c->db,c->argv[j]); ... }}
Redis 6 이상으로 업그레이드하고 Lazy-free를 활성화하는 것이 좋습니다.
위 내용은 Redis에서 지연 삭제를 사용하는 방법 Lazy free의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!