Django 调用 async 异步方法

31 篇文章 0 订阅
17 篇文章 0 订阅

由于某些需求,需要在django内部使用异步方法,并正常的调用。恰好,官方已经支持异步

官方文档参考:异步支持 | Django 文档 | Django

本次仅使用 异步适配函数 

当从异步的上下文中调用同步的代码时,有必要适配调用风格,反之亦然。为此,有两个适配器功能,可从 asgiref.sync 模块中获取:async_to_sync() 和 sync_to_async() 。它们用于调用样式之间转换,同时保持兼容性。

这些适配函数广泛应用于 Django。asgiref 包本身就是 Django 项目的部分,并且它在当你用 pip 方式安装 Django 时,会作为依赖项目自动安装。

 async_to_sync()

 使用异步函数并返回包装它的同步函数。可用作直接包装器或装饰器:

from asgiref.sync import async_to_sync

async def get_data(...):
    ...

sync_get_data = async_to_sync(get_data)
from asgiref.sync import async_to_sync

@async_to_sync
async def get_other_data(...):
    ...

如果存在异步函数,那么它会在当前线程的事件循环中运行。如果没有当前事件循环,则会为单独异步调用专门启动一个新的事件循环,并且会在它完成后再次关闭。无论哪种情况,异步函数会在调用代码的不同线程上执行。

sync_to_async()

使用同步函数并返回包装它的异步函数。可用作直接包装器或装饰器: 

from asgiref.sync import sync_to_async

async_function = sync_to_async(sync_function, thread_sensitive=False)
async_function = sync_to_async(sensitive_sync_function, thread_sensitive=True)

@sync_to_async
def sync_function(...):
    ...

Threadlocals 和 contextvars 值在两个方向的边界上都保持不变。

假设所有同步功能都在主线程中运行时,则倾向于编写同步功能,因此 sync_to_async() 有两个线程模式:

  • thread_sensitive=True (默认使用):同步函数将与所有其它 thread_sensitive 函数在相同线程里运行。如果主线程是同步的并且你正在使用 async_to_sync() 装饰器,则该同步函数将成为主线程。
  • thread_sensitive=False:同步函数将在一个全新的线程中运行,该线程一旦完成,将会关闭。
  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Django 中,使用 async/await 可以方便地处理异步操作。然而,需要注意的是 Django 本身不支持原生的异步操作,但可以通过结合使用异步的第三方库来实现。 以下是一种常见的使用 async/await 的方法: 1. 安装异步支持库:首先,你需要安装异步支持库,比如 `asgiref` 和 `djangorestframework-async`。 ``` pip install asgiref djangorestframework-async ``` 2. 在视图函数中使用 async/await:在视图函数中,可以使用 `async` 关键字定义异步函数,并在需要的地方使用 `await` 关键字等待异步操作完成。 ```python from rest_framework.decorators import api_view from rest_framework.response import Response from asgiref.sync import async_to_sync # 使用 async/await 定义异步视图函数 @api_view(['GET']) async def my_async_view(request): # 模拟一个异步操作,比如调用外部 API response = await async_to_sync(requests.get)('https://api.example.com/data') # 处理异步操作的结果 data = response.json() return Response(data) ``` 在上面的示例中,`my_async_view` 是一个使用 async/await 的异步视图函数。在视图函数中,我们使用 `await` 等待异步操作 `requests.get()` 完成,并将结果赋给 `response`。然后,我们可以继续处理异步操作的结果。 3. 使用 djangorestframework-async 扩展库:如果想要更方便地在 Django 中使用 async/await,可以使用第三方库 `djangorestframework-async`。它提供了一些装饰器和中间件,可以在 Django Rest Framework 中支持异步视图函数。 ```python from rest_framework.decorators import api_view from rest_framework.response import Response from djangorestframework_async.decorators import async_api_view # 使用 @async_api_view 装饰器定义异步视图函数 @async_api_view(['GET']) async def my_async_view(request): # 异步操作... return Response(data) ``` 通过使用 `@async_api_view` 装饰器,你可以将视图函数标记为异步函数,不再需要手动使用 `async_to_sync` 等工具。 需要注意的是,在 Django 中使用异步操作需要考虑到数据库的支持情况,因为大部分的数据库驱动程序不支持异步操作。因此,在涉及到数据库的操作时,可能需要使用同步方式或者结合异步库的数据库驱动程序。 希望以上解答对你有帮助!如果还有其他问题,请继续提问。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值