Python 如何使asyncpg驱动程序通过守护进程线程从同步代码工作?
我有一个既有同步代码又有非同步代码的应用程序(因为它进行计算) Asyncpg声称比psycopg2快得多,如下所示: 我提出了在数据库管理器上动态修补的代码,数据库管理器本身使用asyncpg和协同路由方法。目标是使相同的接口可以通过同步代码使用。有更好的方法吗 AsyncioWorkerThread只是在守护进程线程中运行的eventloop。(见此)linkhttps://stackoverflow.com/questions/67199459/asyncio-loop-in-daemon-thread)Python 如何使asyncpg驱动程序通过守护进程线程从同步代码工作?,python,python-asyncio,monkeypatching,concurrent.futures,asyncpg,Python,Python Asyncio,Monkeypatching,Concurrent.futures,Asyncpg,我有一个既有同步代码又有非同步代码的应用程序(因为它进行计算) Asyncpg声称比psycopg2快得多,如下所示: 我提出了在数据库管理器上动态修补的代码,数据库管理器本身使用asyncpg和协同路由方法。目标是使相同的接口可以通过同步代码使用。有更好的方法吗 AsyncioWorkerThread只是在守护进程线程中运行的eventloop。(见此)linkhttps://stackoverflow.com/questions/67199459/asyncio-loop-in-daemo
class DatabaseManager(DatabaseManager):
async def test():
asyncio.sleep(1)
print('pretend we are doing work with asyncpg')
class SyncDatabaseManager(DatabaseManager):
"""A sync version of the DatabaseManager."""
def __init__(self, *args, **kwargs):
"""Construct."""
super().__init__(*args, **kwargs)
self.workerThread = AsyncioWorkerThread(daemon=True)
self.workerThread.start()
self.__patch_all_coroutine_methods()
def __patch_all_coroutine_methods(self):
methods = inspect.getmembers(DatabaseManager, predicate=inspect.isfunction)
coro_methods = [(func_name, func_addr) for (func_name, func_addr) in methods if inspect.iscoroutinefunction(func_addr)]
def sync_method_factory(func_addr):
@functools.wraps(func_addr)
def sync_func(*args, **kwargs):
return self.workerThread.submit(func_addr(self, *args, **kwargs))
return sync_func
for func_name, func_addr in coro_methods:
setattr(self, func_name, sync_method_factory(func_addr))