Redis 클러스터의 오류 감지 방법: 먼저 Python 스크립트를 수정하고 1초마다 데이터 조각을 쓴 다음 루프에서 Redis 클러스터에 데이터를 쓴 다음 마스터 노드를 강제로 종료하여 애플리케이션 연결을 관찰합니다. 가동 중지 시간은 8001 노드이면 충분합니다.
Redis 클러스터의 오류 감지 방법: 자동 장애 조치 테스트
Python 스크립트를 수정하고 1초마다 데이터를 작성하는 것이 목적입니다. 마스터 노드가 다운되는 시간을 쉽게 관찰할 수 있습니다. 클러스터는 자동 장애 조치 전후의 기간(약 1초) 내에 애플리케이션 또는 애플리케이션의 성능에 영향을 미칩니다.
다음 스크립트는 Redis 클러스터에 데이터를 쓰기 위해 반복됩니다. 실행 중에 마스터 노드를 강제로 종료하고 애플리케이션 연결 상태를 관찰합니다.
동시에 예외가 발생하면 위에서 구성한 클러스터 장애 조치 시간이 1초이므로 애플리케이션을 2초간 일시 중지하면 장애 조치가 완료되면 건너뛸 수 있습니다. , 애플리케이션이 재개됩니다. 노드 8001이 다운되었지만 애플리케이션은 계속해서 노드 8001에 연결되지만 애플리케이션은 이를 전혀 인식하지 못합니다.
관련 학습 권장사항: redis 동영상 튜토리얼
import timefrom time import ctime,sleepfrom rediscluster import StrictRedisCluster startup_nodes = [ {"host":"111.231.253.***", "port":8001}, {"host":"111.231.253.***", "port":8002}, {"host":"111.231.253.***", "port":8003}, {"host":"111.231.253.***", "port":8004}, {"host":"111.231.253.***", "port":8005}, {"host":"111.231.253.***", "port":8006} ] redis_conn= StrictRedisCluster(startup_nodes=startup_nodes, decode_responses=True,password="root")for i in range(0, 100000): try: redis_conn.set('name' + str(i), str(i)) print('setting name' + str(i) +"--->" + time.strftime('%Y-%m-%d %H:%M:%S',time.localtime(time.time()))) time.sleep(1) except: print("connect to redis cluster error") time.sleep(2)
마스터 노드를 종료한 후 단 한 번의 연결 오류가 발생한 것을 발견했으며 그 후 Redis 클러스터의 자동 장애 조치가 성공했기 때문에 프로그램에 투명했습니다. 따라서 애플리케이션은 마스터 노드 중 하나의 가동 중지 시간에 영향을 받지 않고 정상적으로 작동합니다.
이때 클러스터의 상태는 노드 8001이 다운된 상태입니다. 당연하게도 8001에 해당하는 슬레이브 노드 8004가 마스터 노드를 인계받아 마스터로 업그레이드되어 외부로 서비스를 제공하고 있습니다
마스터 노드로 업그레이드된 8004 인스턴스의 로그를 관찰하면 원래 8001 마스터 노드를 강제 종료한 후 1초 이내에 장애 조치 프로세스 중에 Redis에 액세스하는 애플리케이션이 없으면 8001이 마스터 노드로 성공적으로 업그레이드된 것을 확인할 수 있습니다. , 애플리케이션은 Redis 클러스터가 발생했다는 사실조차 알지 못합니다. 클러스터 내 특정 노드의 마스터 및 슬레이브 노드가 동시에 다운되지 않는 한 전체 클러스터에는 문제가 없으며 이는 애플리케이션에 완전히 투명해집니다.
위 내용은 Redis 클러스터에서 결함을 감지하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!