FastAPI(63)- Concurrency and async / await 并发、异步/等待

await

如果使用的第三方库说明调用它们要通过 await

results = await some_library()

 

声明路径操作函数

@app.get('/')

async def read_results():

    results = await some_library()
    return results

await 只能在 async def 函数中使用

 

注意

  • 如果正在使用与某些内容(数据库、API、文件系统等)通信的第三方库,并且不支持 await, (目前大多数数据库库都是这种情况)
  • 路径操作需要声明为普通函数 def,例如
@app.get('/')

def results():

    results = some_library()
    return results 
  • 如果应用程序(以某种方式)不必与其他任何东西通信并等待它响应,可以使用 async def(就是异步函数啦)
  • 如果不知道的话,使用普通 def
  • 可以根据需要在路径操作函数中混合使用 def 和 async def
  • 无论如何,在上述任何一种情况下,FastAPI 仍然会异步工作并且非常快
  • 但是按照上面的步骤,它将能够做一些性能优化

 

路径操作函数

当使用普通 def 而不是 async def 声明路径操作函数时,它在一个外部线程池中运行,然后等待,而不是直接调用(因为它会阻塞服务器)

 

依赖关系

  • 这同样适用于依赖项
  • 如果依赖项是标准 def 函数而不是 async def,则它在外部线程池中运行

 

子依赖

  • 可以有多个相互依赖的依赖项和子依赖项(作为函数定义的参数)
  • 其中一些可能是用 async def 创建的,有些可能是用普通 def 创建的
  • 使用普通 def 创建的那些将在外部线程池上调用,而不是被“等待”

 

比较概念性的东西,还是等实际使用时再补充代码栗子吧

posted @ 2021-10-09 09:24  小菠萝测试笔记  阅读(778)  评论(0编辑  收藏  举报