Redis 데이터는 메모리에 저장되므로 지속성이 구성되지 않으면 Redis를 다시 시작한 후 모든 데이터가 손실되므로 Redis의 지속성 기능을 활성화하고 Redis를 다시 시작할 때 데이터를 디스크에 저장해야 합니다. 데이터를 복구하려면 디스크에서 검색해야 합니다.
redis는 지속성을 위한 두 가지 방법을 제공합니다, 하나는 RDB 지속성(메모리에 있는 Reids의 데이터베이스 레코드를 주기적으로 디스크의 RDB 지속성으로 덤프하는 것이 원칙)이고, 다른 하나는 AOF(append only file) 지속성입니다. (파일에 레이드의 작업 로그를 첨부하여 기록하는 것이 원칙입니다.)
RDB: RDB 지속성은 현재 프로세스 데이터의 스냅샷을 생성하여 하드 디스크에 저장하는 프로세스입니다. RDB 지속성을 트리거하는 프로세스는 수동 트리거와 자동 트리거로 구분됩니다. (권장 학습: Redis 비디오 튜토리얼)
트리거 메커니즘
수동 트리거는 각각 save 및 bgsave 명령에 해당합니다.
save 명령: RDB 프로세스가 완료될 때까지 현재 Redis 서버를 차단합니다. 대용량 메모리 장기간 정체를 유발하므로 온라인 사용을 권장하지 않습니다.
DB saved on disk
bgseve 명령: Redis 프로세스는 하위 프로세스를 생성하기 위해 포크 작업을 수행합니다. RDB 지속성 프로세스는 하위 프로세스를 담당하며 완료 후 자동으로 종료됩니다. 차단은 포크 단계에서만 발생하며 일반적으로 수명이 매우 짧습니다.
* Background saving started by pid 3151 * DB saved on disk * RDB: 0 MB of memory used by copy-on-write * Background saving terminated with success
자동으로 실행됨
다음 시나리오에서 실행됩니다
1) "save m n"과 같은 저장 관련 구성을 사용하세요. 데이터 세트가 m초 내에 n번 수정되면 bgsave가 자동으로 트리거됨을 나타냅니다.
2) 슬레이브 노드가 전체 복사 작업을 수행하면 마스터 노드는 자동으로 bgsave를 실행하여 RDB 파일을 생성하고 이를 슬레이브 노드로 보냅니다.
3) Redis를 다시 로드하기 위해 debug reload 명령을 실행하면 저장 작업도 자동으로 트리거됩니다.
4) 기본적으로 shutdown 명령을 실행할 때 AOF 지속성 기능이 활성화되지 않은 경우 bgsave가 자동으로 실행됩니다.
AOF: 기록된 각 명령을 독립적인 로그에 기록하고, 데이터를 복원하기 위해 다시 시작할 때 AOF 파일에 있는 명령을 다시 실행하세요. 주요 기능: 실시간 데이터 지속성 문제를 해결합니다.
AOF 사용
AOF 기능을 활성화하려면 기본적으로 활성화되어 있지 않은 추가 전용 yes 구성을 설정해야 합니다. 파일 이름은appendfilename 구성을 통해 설정되며 기본값은appendonly.aof입니다.
1) 모든 쓰기 명령은 aof_buf(버퍼)에 추가됩니다.
2) AOF 버퍼는 해당 전략에 따라 하드 디스크에 대한 동기화 작업을 수행합니다.
3) AOF 파일이 점점 커지면 압축을 위해 AOF 파일을 정기적으로 다시 작성해야 합니다.
4) Redis 서버가 다시 시작되면 데이터 복구를 위해 AOF 파일을 로드할 수 있습니다.
더 많은 Redis 관련 기술 기사를 보려면 Redis 시작 튜토리얼 칼럼을 방문하여 알아보세요!
위 내용은 Redis를 지속하는 방법의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!