오늘 이 컴퓨터(windows)에서 Python을 사용하여 redis에 액세스할 때 오류가 발생했습니다. 오류에는 두 가지 유형이 있습니다.
sentinel을 구성하면 알 수 없는 명령 'SENTINEL'과 같은 오류가 보고됩니다. 🎜>StrictRedis를 구성하면 NOAUTH 인증이 필요하다는 오류가 보고됩니다.
첫 번째 오류에 대해 회사에서는 최근에 온라인에 접속했는데 이런 오류가 발생했습니다. 주된 이유는 sentinel이 시작되지 않았기 때문입니다. 그러나 회사에서는 세 대의 redis sentinel 머신이 다운된 후 문제가 발생했습니다. 다른 두 머신은 선출할 수 없었습니다. 한 머신은 마스터로 사용됩니다. 왜냐하면 redis 구성을 할 때 어느 임시 작업자가 선거 머신을 3으로 구성했는지 알 수 없기 때문입니다. 결과적으로 한 머신이 다운되는 한은 할 수 없습니다. 선출되다. 실제로 구성을 n-m으로 변경해야 합니다. n은 머신 수, m은 실패가 허용되는 머신 수입니다.
import redis import ConfigParser import redis.sentinel class RedisConn: _rp = None def __init__(self): cp = ConfigParser.SafeConfigParser() cp.read('avatar_redis.conf') host = cp.get('redis', 'host') port = cp.get('redis', 'port') db_name = cp.get('redis', 'dbName') pass_word = cp.get('redis', 'passWord') self._rp = redis.StrictRedis(host=host, port=port, db=0, password=pass_word) # = redis.ConnectionPool(host=host, port=port, db=0, password='') #sentinel = redis.sentinel.Sentinel([(host, port)], socket_timeout=0.1) #self._rp = sentinel.master_for(db_name, socket_timeout=0.1) #self._rp = redis.Redis(connection_pool=conn_pool) def get_conn(self): return self._rp def set_value(self, key, value): self._rp.set(key, value) def get_value(self, key): return self._rp.get(key)