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


Python asyncpg.connect方法代碼示例

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


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

示例1: connect

# 需要導入模塊: import asyncpg [as 別名]
# 或者: from asyncpg import connect [as 別名]
def connect(self, loop=None, **kwargs):
        conn_info = self.get_connection_spec()
        conn_info.update(kwargs)
        conn = await asyncpg.connect(loop=loop, **conn_info)

        if (not kwargs.get('user')
                and self._default_session_auth
                and conn_info.get('user') != self._default_session_auth):
            # No explicit user given, and the default
            # SESSION AUTHORIZATION is different from the user
            # used to connect.
            await conn.execute(
                f'SET SESSION AUTHORIZATION {self._default_session_auth};'
            )

        return conn 
開發者ID:edgedb,項目名稱:edgedb,代碼行數:18,代碼來源:pgcluster.py

示例2: __aenter__

# 需要導入模塊: import asyncpg [as 別名]
# 或者: from asyncpg import connect [as 別名]
def __aenter__(self) -> PgRenderLocker:
        # pg_connection: asyncpg, not Django database, because we use its
        # transaction asynchronously. (Async is so much easier than threading.)
        pg_config = settings.DATABASES["default"]
        pg_connection = await asyncpg.connect(
            host=pg_config["HOST"],
            user=pg_config["USER"],
            password=pg_config["PASSWORD"],
            database=pg_config["NAME"],
            port=pg_config["PORT"],
            timeout=pg_config["CONN_MAX_AGE"],
            command_timeout=pg_config["CONN_MAX_AGE"],
        )

        self.pg_connection = pg_connection

        loop = asyncio.get_event_loop()
        interval = pg_config["CONN_MAX_AGE"]
        self.heartbeat_task = loop.create_task(
            self.send_pg_heartbeats_forever(interval)
        )

        return self 
開發者ID:CJWorkbench,項目名稱:cjworkbench,代碼行數:25,代碼來源:pg_render_locker.py

示例3: test_auth_password_cleartext_callable

# 需要導入模塊: import asyncpg [as 別名]
# 或者: from asyncpg import connect [as 別名]
def test_auth_password_cleartext_callable(self):
        def get_correctpassword():
            return 'correctpassword'

        def get_wrongpassword():
            return 'wrongpassword'

        conn = await self.connect(
            user='password_user',
            password=get_correctpassword)
        await conn.close()

        with self.assertRaisesRegex(
                asyncpg.InvalidPasswordError,
                'password authentication failed for user "password_user"'):
            await self._try_connect(
                user='password_user',
                password=get_wrongpassword) 
開發者ID:MagicStack,項目名稱:asyncpg,代碼行數:20,代碼來源:test_connect.py

示例4: test_auth_password_cleartext_callable_coroutine

# 需要導入模塊: import asyncpg [as 別名]
# 或者: from asyncpg import connect [as 別名]
def test_auth_password_cleartext_callable_coroutine(self):
        async def get_correctpassword():
            return 'correctpassword'

        async def get_wrongpassword():
            return 'wrongpassword'

        conn = await self.connect(
            user='password_user',
            password=get_correctpassword)
        await conn.close()

        with self.assertRaisesRegex(
                asyncpg.InvalidPasswordError,
                'password authentication failed for user "password_user"'):
            await self._try_connect(
                user='password_user',
                password=get_wrongpassword) 
開發者ID:MagicStack,項目名稱:asyncpg,代碼行數:20,代碼來源:test_connect.py

示例5: test_ssl_connection_custom_context

# 需要導入模塊: import asyncpg [as 別名]
# 或者: from asyncpg import connect [as 別名]
def test_ssl_connection_custom_context(self):
        ssl_context = ssl.SSLContext(ssl.PROTOCOL_SSLv23)
        ssl_context.load_verify_locations(SSL_CA_CERT_FILE)

        con = await self.connect(
            host='localhost',
            user='ssl_user',
            ssl=ssl_context)

        try:
            self.assertEqual(await con.fetchval('SELECT 42'), 42)

            with self.assertRaises(asyncio.TimeoutError):
                await con.execute('SELECT pg_sleep(5)', timeout=0.5)

            self.assertEqual(await con.fetchval('SELECT 43'), 43)
        finally:
            await con.close() 
開發者ID:MagicStack,項目名稱:asyncpg,代碼行數:20,代碼來源:test_connect.py

示例6: test_find_tables

# 需要導入模塊: import asyncpg [as 別名]
# 或者: from asyncpg import connect [as 別名]
def test_find_tables(self):
        tables = importer.find_tables(test_dir / '../testlayers/testmaptiles.yaml')
        self.assertEqual(tables, ['osm_housenumber_point'])

    # async def test_pg_func(self):
    #     conn = None
    #     try:
    #         pghost, pgport, dbname, user, password = parse_pg_args(
    #             dict(args=dict(dict=lambda v: None))
    #         )
    #         conn = await asyncpg.connect(
    #             database=dbname, host=pghost, port=pgport, user=user, password=password,
    #         )
    #         PgWarnings(conn)
    #         await conn.set_builtin_type_codec('hstore', codec_name='pg_contrib.hstore')
    #
    #     finally:
    #         if conn:
    #             await conn.close() 
開發者ID:openmaptiles,項目名稱:openmaptiles-tools,代碼行數:21,代碼來源:test_import_wikidata.py

示例7: DBClient

# 需要導入模塊: import asyncpg [as 別名]
# 或者: from asyncpg import connect [as 別名]
def DBClient():
    return await asyncpg.connect(
        user=DBUSER,
        password=DBPASSWORD,
        database=DBNAME,
        host=DBHOST,
        port=DBPORT,
    ) 
開發者ID:PacktPublishing,項目名稱:Clean-Code-in-Python,代碼行數:10,代碼來源:client.py

示例8: _test_connection

# 需要導入模塊: import asyncpg [as 別名]
# 或者: from asyncpg import connect [as 別名]
def _test_connection(self, timeout=60):
        self._connection_addr = None

        loop = asyncio.new_event_loop()

        try:
            for _ in range(timeout):
                if self._connection_addr is None:
                    conn_addr = self._get_connection_addr()
                    if conn_addr is None:
                        time.sleep(1)
                        continue

                try:
                    con = loop.run_until_complete(
                        asyncpg.connect(database='postgres',
                                        user='postgres',
                                        timeout=5,
                                        loop=loop,
                                        host=self._connection_addr[0],
                                        port=self._connection_addr[1]))
                except (OSError, asyncio.TimeoutError,
                        asyncpg.CannotConnectNowError,
                        asyncpg.PostgresConnectionError):
                    time.sleep(1)
                    continue
                except asyncpg.PostgresError:
                    # Any other error other than ServerNotReadyError or
                    # ConnectionError is interpreted to indicate the server is
                    # up.
                    break
                else:
                    loop.run_until_complete(con.close())
                    break
        finally:
            loop.close()

        return 'running' 
開發者ID:edgedb,項目名稱:edgedb,代碼行數:40,代碼來源:pgcluster.py

示例9: get_remote_pg_cluster

# 需要導入模塊: import asyncpg [as 別名]
# 或者: from asyncpg import connect [as 別名]
def get_remote_pg_cluster(dsn: str) -> RemoteCluster:
    addrs, params = pgconnparams.parse_dsn(dsn)
    if len(addrs) > 1:
        raise ValueError('multiple hosts in Postgres DSN are not supported')
    rcluster = RemoteCluster(addrs[0], params)

    loop = asyncio.new_event_loop()

    async def _is_rds():
        conn = await rcluster.connect()

        try:
            rds_super = await conn.fetch(
                "SELECT * FROM pg_roles WHERE rolname = 'rds_superuser'"
            )
        finally:
            await conn.close()

        return bool(rds_super)

    try:
        is_rds = loop.run_until_complete(_is_rds())
    finally:
        loop.close()

    if is_rds:
        return RDSCluster(addrs[0], params)
    else:
        return rcluster 
開發者ID:edgedb,項目名稱:edgedb,代碼行數:31,代碼來源:pgcluster.py

示例10: new_connection

# 需要導入模塊: import asyncpg [as 別名]
# 或者: from asyncpg import connect [as 別名]
def new_connection(self):
        con_args = self._connect_args.copy()
        con_args['database'] = self._dbname
        try:
            return await asyncpg.connect(**con_args)
        except asyncpg.InvalidCatalogNameError as ex:
            raise errors.AuthenticationError(str(ex)) from ex
        except Exception as ex:
            raise errors.InternalServerError(str(ex)) from ex 
開發者ID:edgedb,項目名稱:edgedb,代碼行數:11,代碼來源:compiler.py

示例11: connect

# 需要導入模塊: import asyncpg [as 別名]
# 或者: from asyncpg import connect [as 別名]
def connect(
        self,
        dbname: str,
        dbver: bytes
    ) -> CompilerDatabaseState:
        self._dbname = dbname
        self._cached_db = None
        await self._get_database(dbver) 
開發者ID:edgedb,項目名稱:edgedb,代碼行數:10,代碼來源:compiler.py

示例12: collect_postgres_stats

# 需要導入模塊: import asyncpg [as 別名]
# 或者: from asyncpg import connect [as 別名]
def collect_postgres_stats(self, ident: str, vacuum_full: bool = True):
        creds = self.postgres_creds

        conn = await asyncpg.connect(
            host=self.internal_host,
            port="5432",
            user=creds["admin_account"],
            password=creds["admin_password"],
            database=self.wallet_name,
        )

        tables = ("items", "tags_encrypted", "tags_plaintext")
        for t in tables:
            await conn.execute(f"VACUUM FULL {t}" if vacuum_full else f"VACUUM {t}")

        sizes = await conn.fetch(
            """
            SELECT relname AS "relation",
                pg_size_pretty(pg_total_relation_size(C.oid)) AS "total_size"
            FROM pg_class C
            LEFT JOIN pg_namespace N ON (N.oid = C.relnamespace)
            WHERE nspname = 'public'
            ORDER BY pg_total_relation_size(C.oid) DESC;
            """
        )
        results = {k: [0, "0B"] for k in tables}
        for row in sizes:
            if row["relation"] in results:
                results[row["relation"]][1] = row["total_size"].replace(" ", "")
        for t in tables:
            row = await conn.fetchrow(f"""SELECT COUNT(*) AS "count" FROM {t}""")
            results[t][0] = row["count"]
        self.wallet_stats.append((ident, results))

        await conn.close() 
開發者ID:hyperledger,項目名稱:aries-cloudagent-python,代碼行數:37,代碼來源:agent.py

示例13: _execute_pg_query

# 需要導入模塊: import asyncpg [as 別名]
# 或者: from asyncpg import connect [as 別名]
def _execute_pg_query(url, query):
    conn = await asyncpg.connect(url)
    if callable(query):
        await query(conn)
    else:
        await conn.execute(query)
    await conn.close() 
開發者ID:Scille,項目名稱:parsec-cloud,代碼行數:9,代碼來源:postgresql.py

示例14: asyncpg_init

# 需要導入模塊: import asyncpg [as 別名]
# 或者: from asyncpg import connect [as 別名]
def asyncpg_init(db_uri):
    import asyncpg

    async def create_conn():
        global asyncpg_conn
        asyncpg_conn = await asyncpg.connect(db_uri)

    async_run(create_conn)


# asyncpg_init(config.DATABASE_URI) 
開發者ID:fy0,項目名稱:slim,代碼行數:13,代碼來源:__init__.py

示例15: setUpClass

# 需要導入模塊: import asyncpg [as 別名]
# 或者: from asyncpg import connect [as 別名]
def setUpClass(cls):
        super().setUpClass()
        cls._connection = None
        cls._cursor = None
        cls._tracer = cls.tracer_provider.get_tracer(__name__)
        AsyncPGInstrumentor().instrument(tracer_provider=cls.tracer_provider)
        cls._connection = _await(
            asyncpg.connect(
                database=POSTGRES_DB_NAME,
                user=POSTGRES_USER,
                password=POSTGRES_PASSWORD,
                host=POSTGRES_HOST,
                port=POSTGRES_PORT,
            )
        ) 
開發者ID:open-telemetry,項目名稱:opentelemetry-python,代碼行數:17,代碼來源:test_asyncpg_functional.py


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