當前位置: 首頁>>代碼示例>>Python>>正文


Python hiredis.Reader方法代碼示例

本文整理匯總了Python中hiredis.Reader方法的典型用法代碼示例。如果您正苦於以下問題:Python hiredis.Reader方法的具體用法?Python hiredis.Reader怎麽用?Python hiredis.Reader使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在hiredis的用法示例。


在下文中一共展示了hiredis.Reader方法的12個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Python代碼示例。

示例1: reconnect_init

# 需要導入模塊: import hiredis [as 別名]
# 或者: from hiredis import Reader [as 別名]
def reconnect_init(self, connection):
        connection.xid = 1
        connection.redis_replyxid = 1
        connection.redis_ping = -1
        connection.redis_pingreply = -1
        connection.redis_bufferedxid = 0
        connection.redis_sendbuffer = []
        connection.redis_sender = False
        write_buffer = []
        if self.usehiredis:
            connection.redis_reader = hiredis.Reader(protocolError = RedisProtocolException, replyError = RedisReplyException)
        else:
            connection.redis_reader = RedisParser()
        if connection.redis_select:
            write_buffer.append(self.format_request(b'SELECT', connection.redis_select))
            connection.xid += 1
        if connection.redis_subscribe:
            if connection.redis_subscribe_keys:
                write_buffer.append(self.format_request(b'SUBSCRIBE', *tuple(connection.redis_subscribe_keys)))
            if connection.redis_subscribe_pkeys:
                write_buffer.append(self.format_request(b'PSUBSCRIBE', *tuple(connection.redis_subscribe_pkeys)))
        connection.scheduler.emergesend(ConnectionWriteEvent(connection, connection.connmark, data=b''.join(write_buffer)))
        await connection.wait_for_send(RedisConnectionStateEvent(RedisConnectionStateEvent.CONNECTION_UP, connection, connection.connmark, self)) 
開發者ID:hubo1016,項目名稱:vlcp,代碼行數:25,代碼來源:redis.py

示例2: __init__

# 需要導入模塊: import hiredis [as 別名]
# 或者: from hiredis import Reader [as 別名]
def __init__(self):
        self.dictionary = dictionary
        self.response = collections.deque()
        self.parser = hiredis.Reader()
        self.transport = None  # type: asyncio.transports.Transport
        self.commands = {
            b"COMMAND": self.command,
            b"SET": self.set,
            b"GET": self.get,
            b"PING": self.ping,
            b"INCR": self.incr,
            b"LPUSH": self.lpush,
            b"RPUSH": self.rpush,
            b"LPOP": self.lpop,
            b"RPOP": self.rpop,
            b"SADD": self.sadd,
            b"HSET": self.hset,
            b"SPOP": self.spop,
            b"LRANGE": self.lrange,
            b"MSET": self.mset,
        } 
開發者ID:boramalper,項目名稱:pydis,代碼行數:23,代碼來源:__main__.py

示例3: on_connect

# 需要導入模塊: import hiredis [as 別名]
# 或者: from hiredis import Reader [as 別名]
def on_connect(self, connection):
        self._sock = connection._sock
        self._socket_timeout = connection.socket_timeout
        kwargs = {
            'protocolError': InvalidResponse,
            'replyError': self.parse_error,
        }

        # hiredis < 0.1.3 doesn't support functions that create exceptions
        if not HIREDIS_SUPPORTS_CALLABLE_ERRORS:
            kwargs['replyError'] = ResponseError

        if connection.encoder.decode_responses:
            kwargs['encoding'] = connection.encoder.encoding
        if HIREDIS_SUPPORTS_ENCODING_ERRORS:
            kwargs['errors'] = connection.encoder.encoding_errors
        self._reader = hiredis.Reader(**kwargs)
        self._next_response = False 
開發者ID:wistbean,項目名稱:learn_python3_spider,代碼行數:20,代碼來源:connection.py

示例4: _connect

# 需要導入模塊: import hiredis [as 別名]
# 或者: from hiredis import Reader [as 別名]
def _connect(self):
        if self._closed:
            raise PyRedisConnError('Connection Gone')
        if self.host:
            sock = self._connect_inet46()
        else:
            sock = self._connect_unix()
        self._sock = sock
        if self._encoding:
            self._reader = Reader(encoding=self._encoding)
        else:
            self._reader = Reader()
        self._authenticate()
        if not self._sentinel:
            self._setdb()
            self._set_read_only()
        self._sock.settimeout(self._read_timeout) 
開發者ID:schlitzered,項目名稱:pyredis,代碼行數:19,代碼來源:connection.py

示例5: __init__

# 需要導入模塊: import hiredis [as 別名]
# 或者: from hiredis import Reader [as 別名]
def __init__(self, host, port, timeout=5):
        self.host = host
        self.port = port
        self.sock = socket.socket(socket.AF_INET, socket.SOCK_STREAM)
        self.reader = hiredis.Reader()
        self.last_raw_message = EMPTY

        self.sock.settimeout(timeout)
        logging.debug('Connect to %s:%d', host, port)
        self._conn() 
開發者ID:projecteru,項目名稱:redis-trib.py,代碼行數:12,代碼來源:connection.py

示例6: _recv

# 需要導入模塊: import hiredis [as 別名]
# 或者: from hiredis import Reader [as 別名]
def _recv(self):
        while True:
            m = self.sock.recv(16384)
            self.last_raw_message += m
            self.reader.feed(m)
            r = self.reader.gets()
            # From hiredis.Reader : https://github.com/redis/hiredis-py#usage
            # > When the buffer does not contain a full reply, gets returns False.
            if r != False:
                return r 
開發者ID:projecteru,項目名稱:redis-trib.py,代碼行數:12,代碼來源:connection.py

示例7: on_connect

# 需要導入模塊: import hiredis [as 別名]
# 或者: from hiredis import Reader [as 別名]
def on_connect(self, connection):
        self._sock = connection._sock
        kwargs = {
            'protocolError': InvalidResponse,
            'replyError': self.parse_error,
        }

        # hiredis < 0.1.3 doesn't support functions that create exceptions
        if not HIREDIS_SUPPORTS_CALLABLE_ERRORS:
            kwargs['replyError'] = ResponseError

        if connection.decode_responses:
            kwargs['encoding'] = connection.encoding
        self._reader = hiredis.Reader(**kwargs)
        self._next_response = False 
開發者ID:leancloud,項目名稱:satori,代碼行數:17,代碼來源:connection.py

示例8: on_connect

# 需要導入模塊: import hiredis [as 別名]
# 或者: from hiredis import Reader [as 別名]
def on_connect(self, connection):
        self._stream = connection._reader
        kwargs = {
            'protocolError': InvalidResponse,
            'replyError': ResponseError,
        }
        if connection.decode_responses:
            kwargs['encoding'] = connection.encoding
        self._reader = hiredis.Reader(**kwargs)
        self._next_response = False 
開發者ID:NoneGG,項目名稱:aredis,代碼行數:12,代碼來源:connection.py

示例9: __init__

# 需要導入模塊: import hiredis [as 別名]
# 或者: from hiredis import Reader [as 別名]
def __init__(self,
                 hosts,
                 on_close=None,
                 io_loop=None,
                 clustering=False,
                 auto_connect=True):
        """Create a new instance of the ``Client`` class.

        :param hosts: A list of host connection values.
        :type hosts: list(dict)
        :param io_loop: Override the current Tornado IOLoop instance
        :type io_loop: tornado.ioloop.IOLoop
        :param method on_close: The method to call if the connection is closed
        :param bool clustering: Toggle the cluster support in the client
        :param bool auto_connect: Toggle the auto-connect on creation feature

        """
        self._buffer = bytes()
        self._busy = locks.Lock()
        self._closing = False
        self._cluster = {}
        self._clustering = clustering
        self._connected = locks.Event()
        self._connect_future = concurrent.Future()
        self._connection = None
        self._discovery = False
        self._hosts = hosts
        self._on_close_callback = on_close
        self._reader = hiredis.Reader()
        self.io_loop = io_loop or ioloop.IOLoop.current()
        if not self._clustering:
            if len(hosts) > 1:
                raise ValueError('Too many hosts for non-clustering mode')
        if auto_connect:
            LOGGER.debug('Auto-connecting')
            self.connect() 
開發者ID:gmr,項目名稱:tredis,代碼行數:38,代碼來源:client.py

示例10: __init__

# 需要導入模塊: import hiredis [as 別名]
# 或者: from hiredis import Reader [as 別名]
def __init__(self):
        self.req_reader = hiredis.Reader()
        self.req_reader.setmaxbuf(0)
        self.resp_reader = hiredis.Reader()
        self.resp_reader.setmaxbuf(0)

        self.commands = []
        self.responses = 0
        self.request_size = 0
        self.response_size = 0 
開發者ID:jplesperance,項目名稱:redis-sniffer,代碼行數:12,代碼來源:sniffer.py

示例11: connect

# 需要導入模塊: import hiredis [as 別名]
# 或者: from hiredis import Reader [as 別名]
def connect(self):
        """Connects the client object to redis.

        It's safe to use this method even if you are already connected.
        Note: this method is useless with autoconnect mode (default).

        Returns:
            a Future object with True as result if the connection was ok.
        """
        if self.is_connected():
            raise tornado.gen.Return(True)
        cb1 = self._read_callback
        cb2 = self._close_callback
        self.__callback_queue = collections.deque()
        self._reply_list = []
        self.__reader = hiredis.Reader(replyError=ClientError)
        kwargs = self.connection_kwargs
        self.__connection = Connection(cb1, cb2, **kwargs)
        connection_status = yield self.__connection.connect()
        if connection_status is not True:
            # nothing left to do here, return
            raise tornado.gen.Return(False)
        if self.password is not None:
            authentication_status = yield self._call('AUTH', self.password)
            if authentication_status != b'OK':
                # incorrect password, return back the result
                LOG.warning("impossible to connect: bad password")
                self.__connection.disconnect()
                raise tornado.gen.Return(False)
        if self.db != 0:
            db_status = yield self._call('SELECT', self.db)
            if db_status != b'OK':
                LOG.warning("can't select db %s", self.db)
                raise tornado.gen.Return(False)
        raise tornado.gen.Return(True) 
開發者ID:thefab,項目名稱:tornadis,代碼行數:37,代碼來源:client.py

示例12: setUp

# 需要導入模塊: import hiredis [as 別名]
# 或者: from hiredis import Reader [as 別名]
def setUp(self):
        test_redis_uds_or_raise_skiptest()
        super(AbstractConnectionTestCase, self).setUp()
        self.reader = hiredis.Reader()
        self.reply_queue = tornado.queues.Queue() 
開發者ID:thefab,項目名稱:tornadis,代碼行數:7,代碼來源:test_connection.py


注:本文中的hiredis.Reader方法示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。