RError.com

RError.com Logo RError.com Logo

RError.com Navigation

  • 主页

Mobile menu

Close
  • 主页
  • 系统&网络
    • 热门问题
    • 最新问题
    • 标签
  • Ubuntu
    • 热门问题
    • 最新问题
    • 标签
  • 帮助
主页 / 问题 / 1583050
Accepted
mrBars1k
mrBars1k
Asked:2024-06-07 16:35:39 +0000 UTC2024-06-07 16:35:39 +0000 UTC 2024-06-07 16:35:39 +0000 UTC

无法异步连接到机器人和数据库

  • 772

我正在尝试将Aiogram3和asyncpg结合起来,但我对异步缺乏理解。

我尝试以这种方式启动数据库和机器人:

dp = Dispatcher()
adb = DB(DSN)


@dp.message(CommandStart)
async def start(message: Message):
    async with adb.pool.acquire() as conn: # взять подключение из пула и потом вернуть обратно;
        x = await conn.fetch('SELECT * FROM manga;')
    print(x)
    await message.answer('Работает.')


async def main():
    bot = Bot(token=TOKEN)

    await adb.connect()
    await dp.start_polling(bot)

if __name__ == '__main__':
    asyncio.run(main())
class DB:
    def __init__(self, dsn):
        self.dsn = dsn
        self.pool = None

    async def connect(self):
        self.pool = await asyncpg.create_pool(self.dsn) # создать пулл подключений;

    async def close(self):
        await self.pool.close()

但我意识到这里没有异步的味道,两个协程相互阻塞并按顺序工作,而不是异步。

原则上,我还没有找到任何有价值的使用示例asyncpg,尽管该库在所有类似库中的速度似乎是无与伦比的,因为它不使用文本指令,而是通过 C 访问字节代码。

如果有任何最佳实践,我会很高兴阅读它。

python
  • 2 2 个回答
  • 33 Views

2 个回答

  • Voted
  1. Ben Puls
    2024-06-08T03:38:13Z2024-06-08T03:38:13Z

    或许这个方法能帮助解决问题。我以你的代码为基础,所以类是相同的。

    class DB:
    
        def __init__(self, dsn):
            self.dsn = dsn
            self.pool = None
    
        async def get_connection(self):
            return self.pool
    
        async def connect(self):
            self.pool = await asyncpg.create_pool(self.dsn)
                
        async def close(self):
            await self.pool.close()
    

    我们指示连接参数,在我们的例子中是 dns postgres://user:password@host:port/database。

    db = DB("postgres://user:password@host:port/database")
    

    从变量 中,db我们调用创建池的方法connect(),然后调用get_connection()获取池。然后我们就可以使用数据库了。

    async def main():
        await db.connect()
    
        pool = await db.get_connection()
    
        async with pool.acquire() as conn:
            print(await conn.fetchrow("""SELECT * FROM users"""))
    
    
    asyncio.run(main())
    
    • 1
  2. Best Answer
    mrBars1k
    2024-06-07T16:35:39Z2024-06-07T16:35:39Z

    通过创建任务解决了这个问题:

    async def main():
        bot = Bot(token=TOKEN)
    
        task1 = asyncio.create_task(adb.connect())
        task2 = asyncio.create_task(dp.start_polling(bot))
    
        await task1 
        await task2
    
    if __name__ == '__main__':
        asyncio.run(main())
    

    另外,使用gather,我设法做了同样的事情,但更短更简单。

    async def main():
        bot = Bot(token=TOKEN)
    
        task1 = asyncio.create_task(adb.connect())
        task2 = asyncio.create_task(dp.start_polling(bot))
    
        await asyncio.gather(task1, task2)
    
    if __name__ == '__main__':
        asyncio.run(main())
    

    但即使使用这种方法,有时也会出现没有这种方法的错误.acquire(),因为当机器人已经运行时,数据库没有时间创建连接池。或类似的东西。

    • 0

相关问题

  • 是否可以以某种方式自定义 QTabWidget?

  • telebot.anihelper.ApiException 错误

  • Python。检查一个数字是否是 3 的幂。输出 无

  • 解析多个响应

  • 交换两个数组的元素,以便它们的新内容也反转

Sidebar

Stats

  • 问题 10021
  • Answers 30001
  • 最佳答案 8000
  • 用户 6900
  • 常问
  • 回答
  • Marko Smith

    我看不懂措辞

    • 1 个回答
  • Marko Smith

    请求的模块“del”不提供名为“default”的导出

    • 3 个回答
  • Marko Smith

    "!+tab" 在 HTML 的 vs 代码中不起作用

    • 5 个回答
  • Marko Smith

    我正在尝试解决“猜词”的问题。Python

    • 2 个回答
  • Marko Smith

    可以使用哪些命令将当前指针移动到指定的提交而不更改工作目录中的文件?

    • 1 个回答
  • Marko Smith

    Python解析野莓

    • 1 个回答
  • Marko Smith

    问题:“警告:检查最新版本的 pip 时出错。”

    • 2 个回答
  • Marko Smith

    帮助编写一个用值填充变量的循环。解决这个问题

    • 2 个回答
  • Marko Smith

    尽管依赖数组为空,但在渲染上调用了 2 次 useEffect

    • 2 个回答
  • Marko Smith

    数据不通过 Telegram.WebApp.sendData 发送

    • 1 个回答
  • Martin Hope
    Alexandr_TT 2020年新年大赛! 2020-12-20 18:20:21 +0000 UTC
  • Martin Hope
    Alexandr_TT 圣诞树动画 2020-12-23 00:38:08 +0000 UTC
  • Martin Hope
    Air 究竟是什么标识了网站访问者? 2020-11-03 15:49:20 +0000 UTC
  • Martin Hope
    Qwertiy 号码显示 9223372036854775807 2020-07-11 18:16:49 +0000 UTC
  • Martin Hope
    user216109 如何为黑客设下陷阱,或充分击退攻击? 2020-05-10 02:22:52 +0000 UTC
  • Martin Hope
    Qwertiy 并变成3个无穷大 2020-11-06 07:15:57 +0000 UTC
  • Martin Hope
    koks_rs 什么是样板代码? 2020-10-27 15:43:19 +0000 UTC
  • Martin Hope
    Sirop4ik 向 git 提交发布的正确方法是什么? 2020-10-05 00:02:00 +0000 UTC
  • Martin Hope
    faoxis 为什么在这么多示例中函数都称为 foo? 2020-08-15 04:42:49 +0000 UTC
  • Martin Hope
    Pavel Mayorov 如何从事件或回调函数中返回值?或者至少等他们完成。 2020-08-11 16:49:28 +0000 UTC

热门标签

javascript python java php c# c++ html android jquery mysql

Explore

  • 主页
  • 问题
    • 热门问题
    • 最新问题
  • 标签
  • 帮助

Footer

RError.com

关于我们

  • 关于我们
  • 联系我们

Legal Stuff

  • Privacy Policy

帮助

© 2023 RError.com All Rights Reserve   沪ICP备12040472号-5