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


Python aioredis.create_pool方法代碼示例

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


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

示例1: __init__

# 需要導入模塊: import aioredis [as 別名]
# 或者: from aioredis import create_pool [as 別名]
def __init__(self, redis_pool, *, cookie_name="AIOHTTP_SESSION",
                 domain=None, max_age=None, path='/',
                 secure=None, httponly=True,
                 key_factory=lambda: uuid.uuid4().hex,
                 encoder=json.dumps, decoder=json.loads):
        super().__init__(cookie_name=cookie_name, domain=domain,
                         max_age=max_age, path=path, secure=secure,
                         httponly=httponly,
                         encoder=encoder, decoder=decoder)
        if aioredis is None:
            raise RuntimeError("Please install aioredis")
        if StrictVersion(aioredis.__version__).version < (1, 0):
            raise RuntimeError("aioredis<1.0 is not supported")
        self._key_factory = key_factory
        if isinstance(redis_pool, aioredis.pool.ConnectionsPool):
            warnings.warn(
                "using a pool created with aioredis.create_pool is deprecated"
                "please use a pool created with aioredis.create_redis_pool",
                DeprecationWarning
            )
            redis_pool = aioredis.commands.Redis(redis_pool)
        elif not isinstance(redis_pool, aioredis.commands.Redis):
            raise TypeError("Expexted aioredis.commands.Redis got {}".format(
                    type(redis_pool)))
        self._redis = redis_pool 
開發者ID:aio-libs,項目名稱:aiohttp-session,代碼行數:27,代碼來源:redis_storage.py

示例2: init

# 需要導入模塊: import aioredis [as 別名]
# 或者: from aioredis import create_pool [as 別名]
def init(loop):
    redis_pool = await create_pool(('localhost', 6379))
    db_engine = await create_engine(user='aiohttp_security',
                                    password='aiohttp_security',
                                    database='aiohttp_security',
                                    host='127.0.0.1')
    app = web.Application()
    app.db_engine = db_engine
    setup_session(app, RedisStorage(redis_pool))
    setup_security(app,
                   SessionIdentityPolicy(),
                   DBAuthorizationPolicy(db_engine))

    web_handlers = Web()
    web_handlers.configure(app)

    handler = app.make_handler()
    srv = await loop.create_server(handler, '127.0.0.1', 8080)
    print('Server started at http://127.0.0.1:8080')
    return srv, app, handler 
開發者ID:aio-libs,項目名稱:aiohttp-security,代碼行數:22,代碼來源:main.py

示例3: _get_pool

# 需要導入模塊: import aioredis [as 別名]
# 或者: from aioredis import create_pool [as 別名]
def _get_pool(self):
        async with self._pool_lock:
            if self._pool is None:
                kwargs = {
                    "db": self.db,
                    "password": self.password,
                    "loop": self._loop,
                    "encoding": "utf-8",
                    "minsize": self.pool_min_size,
                    "maxsize": self.pool_max_size,
                }
                if not AIOREDIS_BEFORE_ONE:
                    kwargs["create_connection_timeout"] = self.create_connection_timeout

                self._pool = await aioredis.create_pool((self.endpoint, self.port), **kwargs)

            return self._pool 
開發者ID:argaen,項目名稱:aiocache,代碼行數:19,代碼來源:redis.py

示例4: main

# 需要導入模塊: import aioredis [as 別名]
# 或者: from aioredis import create_pool [as 別名]
def main():
    pool = await aioredis.create_pool(
        'redis://localhost',
        minsize=5, maxsize=10)
    with await pool as conn:    # low-level redis connection
        await conn.execute('set', 'my-key', 'value')
        val = await conn.execute('get', 'my-key')
    print('raw value:', val)
    pool.close()
    await pool.wait_closed()    # closing all open connections 
開發者ID:aio-libs,項目名稱:aioredis,代碼行數:12,代碼來源:pool.py

示例5: pubsub

# 需要導入模塊: import aioredis [as 別名]
# 或者: from aioredis import create_pool [as 別名]
def pubsub():
    pool = await aioredis.create_pool(
        'redis://localhost',
        minsize=5, maxsize=10)

    async def reader(channel):
        while (await channel.wait_message()):
            msg = await channel.get(encoding='utf-8')
            # ... process message ...
            print("message in {}: {}".format(channel.name, msg))

            if msg == STOPWORD:
                return

    with await pool as conn:
        await conn.execute_pubsub('subscribe', 'channel:1')
        channel = conn.pubsub_channels['channel:1']
        await reader(channel)  # wait for reader to complete
        await conn.execute_pubsub('unsubscribe', 'channel:1')

    # Explicit connection usage
    conn = await pool.acquire()
    try:
        await conn.execute_pubsub('subscribe', 'channel:1')
        channel = conn.pubsub_channels['channel:1']
        await reader(channel)  # wait for reader to complete
        await conn.execute_pubsub('unsubscribe', 'channel:1')
    finally:
        pool.release(conn)

    pool.close()
    await pool.wait_closed()    # closing all open connections 
開發者ID:aio-libs,項目名稱:aioredis,代碼行數:34,代碼來源:pool_pubsub.py

示例6: pool_or_redis

# 需要導入模塊: import aioredis [as 別名]
# 或者: from aioredis import create_pool [as 別名]
def pool_or_redis(_closable, server):
    version = tuple(map(int, aioredis.__version__.split('.')[:2]))
    if version >= (1, 0):
        factory = aioredis.create_redis_pool
    else:
        factory = aioredis.create_pool

    async def redis_factory(maxsize):
        redis = await factory(server.tcp_address,
                              minsize=1, maxsize=maxsize)
        _closable(redis)
        return redis
    return redis_factory 
開發者ID:aio-libs,項目名稱:aioredis,代碼行數:15,代碼來源:integration_test.py

示例7: create_pool

# 需要導入模塊: import aioredis [as 別名]
# 或者: from aioredis import create_pool [as 別名]
def create_pool(_closable):
    """Wrapper around aioredis.create_pool."""

    async def f(*args, **kw):
        redis = await aioredis.create_pool(*args, **kw)
        _closable(redis)
        return redis
    return f 
開發者ID:aio-libs,項目名稱:aioredis,代碼行數:10,代碼來源:conftest.py

示例8: pool

# 需要導入模塊: import aioredis [as 別名]
# 或者: from aioredis import create_pool [as 別名]
def pool(create_pool, server, loop):
    """Returns RedisPool instance."""
    return loop.run_until_complete(create_pool(server.tcp_address)) 
開發者ID:aio-libs,項目名稱:aioredis,代碼行數:5,代碼來源:conftest.py

示例9: start

# 需要導入模塊: import aioredis [as 別名]
# 或者: from aioredis import create_pool [as 別名]
def start(self, *args, **kwargs):
        t = threading.Thread(target=block_check, args=(self.loop,))
        t.setDaemon(True)
        t.start()
        self.redis = aioredis.Redis(await aioredis.create_pool("redis://" + self.config.redis_host))
        # self.loop.create_task(self._shards_reader())

        return await super().start(*args, **kwargs) 
開發者ID:Xenon-Bot,項目名稱:xenon,代碼行數:10,代碼來源:bot.py

示例10: test_redis_from_create_pool

# 需要導入模塊: import aioredis [as 別名]
# 或者: from aioredis import create_pool [as 別名]
def test_redis_from_create_pool(redis_params):

    async def handler(request):
        pass

    redis = await aioredis.create_pool(**redis_params)
    with pytest.warns(DeprecationWarning):
        create_app(handler=handler, redis=redis) 
開發者ID:aio-libs,項目名稱:aiohttp-session,代碼行數:10,代碼來源:test_redis_storage.py

示例11: event_handler

# 需要導入模塊: import aioredis [as 別名]
# 或者: from aioredis import create_pool [as 別名]
def event_handler(self):
        self.redis = await aioredis.create_pool("redis://localhost", minsize=1, maxsize=2)
        await self.redis.execute_pubsub("SUBSCRIBE", config.ipc_channel)
        channel = self.redis.pubsub_channels[bytes(config.ipc_channel, "utf-8")]
        while await channel.wait_message():
            payload = await channel.get_json(encoding="utf-8")
            if payload.get("scope") != "launcher" or not payload.get("action"):
                pass
            elif payload.get("action") == "restart":
                print(f"[Cluster Manager] Received signal to restart cluster {payload.get('id')}.")
                self.loop.create_task(self.get_instance(self.instances, payload.get("id")).restart())
            elif payload.get("action") == "stop":
                print(f"[Cluster Manager] Received signal to stop cluster {payload.get('id')}.")
                self.loop.create_task(self.get_instance(self.instances, payload.get("id")).stop())
            elif payload.get("action") == "start":
                print(f"[Cluster Manager] Received signal to start cluster {payload.get('id')}.")
                self.loop.create_task(self.get_instance(self.instances, payload.get("id")).start())
            elif payload.get("action") == "statuses" and payload.get("command_id"):
                statuses = {}
                for instance in self.instances:
                    statuses[str(instance.id)] = {
                        "active": instance.is_active,
                        "status": instance.status,
                        "started_at": instance.started_at,
                    }
                await self.redis.execute(
                    "PUBLISH",
                    config.ipc_channel,
                    json.dumps({"command_id": payload["command_id"], "output": statuses}),
                )
            elif payload.get("action") == "roll_restart":
                print("[Cluster Manager] Received signal to perform a rolling restart.")
                for instance in self.instances:
                    self.loop.create_task(instance.restart())
                    await asyncio.sleep(config.shards_per_cluster * 10) 
開發者ID:CHamburr,項目名稱:modmail,代碼行數:37,代碼來源:launcher.py

示例12: connect_redis

# 需要導入模塊: import aioredis [as 別名]
# 或者: from aioredis import create_pool [as 別名]
def connect_redis(self):
        self.redis = await aioredis.create_pool("redis://localhost", minsize=5, maxsize=10, loop=self.loop, db=0)
        info = (await self.redis.execute("INFO")).decode()
        for line in info.split("\n"):
            if line.startswith("redis_version"):
                self.redis_version = line.split(":")[1]
                break 
開發者ID:CHamburr,項目名稱:modmail,代碼行數:9,代碼來源:bot.py

示例13: connect_postgres

# 需要導入模塊: import aioredis [as 別名]
# 或者: from aioredis import create_pool [as 別名]
def connect_postgres(self):
        self.pool = await asyncpg.create_pool(**self.config.database, max_size=20, command_timeout=60) 
開發者ID:CHamburr,項目名稱:modmail,代碼行數:4,代碼來源:bot.py

示例14: _create_redis_pool

# 需要導入模塊: import aioredis [as 別名]
# 或者: from aioredis import create_pool [as 別名]
def _create_redis_pool(*args, **kwargs):
        """
        Adapter to support both aioredis-0.3.0 and aioredis-1.0.0
        For aioredis-1.0.0 and later calls:
            aioredis.create_redis_pool(*args, **kwargs)
        For aioredis-0.3.0 calls:
            aioredis.create_pool(*args, **kwargs)
        """

        if StrictVersion(aioredis.__version__) >= StrictVersion('1.0.0'):  # pragma no cover
            return await aioredis.create_redis_pool(*args, **kwargs)
        else:  # pragma no cover
            return await aioredis.create_pool(*args, **kwargs) 
開發者ID:joanvila,項目名稱:aioredlock,代碼行數:15,代碼來源:redis.py

示例15: __init__

# 需要導入模塊: import aioredis [as 別名]
# 或者: from aioredis import create_pool [as 別名]
def __init__(self, server, loop):
        self.pool = aioredis.create_pool(
            server,
            minsize=5, maxsize=15,
            loop=loop
        ) 
開發者ID:guilhermelawless,項目名稱:nano-dpow,代碼行數:8,代碼來源:redis_db.py


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