Lettuce 센티넬 failover 테스트
spring-data-redis 1.7.111RELEASE
lettuce-3.5.0.Final
Redis 5.0
1 master - port 6379
3 replicas - port 6380, 6381, 6382
3 sentinels - port 26379, 26380, 26381
빈 설정
첫 연결 수립
로그 상단을 보면 아래와 같이, 3 개의 센티넬 주소 중 하나로 접근한다고 하는데, 여러 번 시도했지만 항상 첫 번째 주소인 26379 포트로만 접근했다. 순서대로 접근 시도하면서 센티넬이 응답하지 않는 경우 다음 센티넬로 넘어간다. 정상적으로 응답하는 센티넬을 찾으면 나머지 센티넬로는 요청을 보내지 않았다.
Trying to get a Sentinel connection for one of: [RedisURI [host='127.0.0.1', port=26379], RedisURI [host='127.0.0.1', port=26380], RedisURI [host='127.0.0.1', port=26381]]
로그 하단에서는 SENTINEL 커맨드를 통해 마스터 호스트를 얻는다:
Decoded Command [type=SENTINEL, output=ValueListOutput [output=[127.0.0.1, 6379], error='null']] ...
마스터로의 연결 수립
마스터 fails
마스터와 연결이 끊어져도 failover가 수행되기 전까지는 계속 연결 시도한다.
마스터와 연결이 끊어지자, 다시 센티넬로 연결하여 새로운 마스터 정보를 조회하는데, failover가 완료되기 전까지는 기존 마스터 정보를 반환한다.
Failover 완료 후
센티넬이 failover를 완료하고 새로운 마스터 주소(포트 6381)를 반환한다.
새 마스터로의 연결 정상 수립.
NOTE:
- 센티넬이 죽으면 다음 센티넬로 연결한다.
- quorum 값을 2로 하여 3 개의 센티넬이 구동했다가 2 개의 센티넬이 죽으면 failover가 수행되지 못한다. 1 개의 센티넬만 죽으면 failover는 수행되었다. 센티넬의 상태와 상관없이 vote 수를 채우면 failover에는 문제가 없는 것 같다.