>데이터 베이스 >Redis >Redis 클러스터에서 결함을 감지하는 방법은 무엇입니까?

Redis 클러스터에서 결함을 감지하는 방법은 무엇입니까?

coldplay.xixi
coldplay.xixi원래의
2020-06-30 12:56:292696검색

Redis 클러스터의 오류 감지 방법: 먼저 Python 스크립트를 수정하고 1초마다 데이터 조각을 쓴 다음 루프에서 Redis 클러스터에 데이터를 쓴 다음 마스터 노드를 강제로 종료하여 애플리케이션 연결을 관찰합니다. 가동 중지 시간은 8001 노드이면 충분합니다.

Redis 클러스터에서 결함을 감지하는 방법은 무엇입니까?

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 클러스터의 자동 장애 조치가 성공했기 때문에 프로그램에 투명했습니다. 따라서 애플리케이션은 마스터 노드 중 하나의 가동 중지 시간에 영향을 받지 않고 정상적으로 작동합니다.

Redis 클러스터에서 결함을 감지하는 방법은 무엇입니까?

이때 클러스터의 상태는 노드 8001이 다운된 상태입니다. 당연하게도 8001에 해당하는 슬레이브 노드 8004가 마스터 노드를 인계받아 마스터로 업그레이드되어 외부로 서비스를 제공하고 있습니다

Redis 클러스터에서 결함을 감지하는 방법은 무엇입니까?

마스터 노드로 업그레이드된 8004 인스턴스의 로그를 관찰하면 원래 8001 마스터 노드를 강제 종료한 후 1초 이내에 장애 조치 프로세스 중에 Redis에 액세스하는 애플리케이션이 없으면 8001이 마스터 노드로 성공적으로 업그레이드된 것을 확인할 수 있습니다. , 애플리케이션은 Redis 클러스터가 발생했다는 사실조차 알지 못합니다. 클러스터 내 특정 노드의 마스터 및 슬레이브 노드가 동시에 다운되지 않는 한 전체 클러스터에는 문제가 없으며 이는 애플리케이션에 완전히 투명해집니다.

Redis 클러스터에서 결함을 감지하는 방법은 무엇입니까?

그런 다음 다운된 8001 노드를 다시 시작하면 8001 노드가 자동으로 원래 슬레이브 노드(8004)의 슬레이브 노드가 되는 것을 확인할 수 있습니다.

Redis 클러스터에서 결함을 감지하는 방법은 무엇입니까?

위 내용은 Redis 클러스터에서 결함을 감지하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.