>데이터 베이스 >Redis >Redis에서 지연 삭제를 사용하는 방법 Lazy free

Redis에서 지연 삭제를 사용하는 방법 Lazy free

WBOY
WBOY앞으로
2023-05-26 23:37:041926검색

지연 삭제 사용 Lazy free

키가 만료되거나 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 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
이 기사는 yisu.com에서 복제됩니다. 침해가 있는 경우 admin@php.cn으로 문의하시기 바랍니다. 삭제