fastapi在vscode中运行推荐环境配置 (二)

要想启动fastapi我们需要依赖一个python服务器,在fastapi中本篇介绍2种.如果使用pycharm启动,可以参考下面类似案例,正常来说vscode能启动,pycharm都没问题。

前提

需要先进行虚拟环境的配置。如果还不知道如何配置,可以参考下面的文章先配置后在下一步。

vscode中的python环境搭建

编写启动配置launch.json

一般有两种常用服务器推荐uvicorn和granian

使用uvicorn

参数--reload运行热更新,端口配置为8888,默认是8000

json 复制代码
{
  "version": "0.2.0",
  "configurations": [
    {
      "name": "lga", // 调试器名称
      "type": "debugpy", // 使用 VS Code 推荐的 Python 调试器
      "request": "launch", // 启动新进程(而非附加到现有进程)
      "module": "uvicorn", // 指定通过 uvicorn 模块启动应用
      "args": ["main:app", "--reload", "--port", "8888",], // 启动参数
      "justMyCode": false, // 允许调试第三方库代码
      "env": {
        "PYDEVD_DISABLE_FILE_VALIDATION": "1" // 禁用冻结模块检测(解决某些环境报错)
      }
    }
  ]
}

使用granian

granian是用rust写的一个python服务器,目前是python中最快的服务器,所以也是比较推荐的一个方案

参数运行热更新,端口8888,access-log参数必须,否则没有任何日志输出

json 复制代码
{
  "version": "0.2.0",
  "configurations": [
    {
      "name": "lga", // 调试器名称
      "type": "debugpy", // 使用 VS Code 推荐的 Python 调试器
      "request": "launch", // 启动新进程(而非附加到现有进程)
      "module": "granian", // 指定通过 granian 模块启动应用
      "args": ["main:app", "--interface", "asgi", "--reload", "--port", "8888","--access-log"], // 启动参数
      "justMyCode": false, // 允许调试第三方库代码
      "env": {
        "PYDEVD_DISABLE_FILE_VALIDATION": "1" // 禁用冻结模块检测(解决某些环境报错)
      }
    }
  ]
}

然后我们可以点击f5进行启动或者左侧的面板按钮启动。

特别说明PYDEVD_DISABLE_FILE_VALIDATION 设置1一般是在有对要打包成可执行文件需要,否则有可能报错。

代码启动方案

这个方案pycharm也能用,需要改一点点的代码

main.py

ini 复制代码
if __name__ == "__main__":
    Env.start()
ini 复制代码
class Env:
    @staticmethod
        def start():
            import uvicorn
            app = FastAPI()
            uvicorn.run(app, host="0.0.0.0", reload=False, port=8888, workers=1)

为啥一个文件就搞定要拆呢?这个是一个优化技巧,如果将uvicorn的导入放在全局,当其他模块导入这个文件时,可能会触发uvicorn的导入,在我打包时候,然后启动了多个worker出现了疯狂的reload,导致不可用。所以如果写在入口文件,实际上这start函数代码是我简化后的。还得处理app的日志配置。全写在入口文件,这代码感觉不是很简洁,入口文件main.py我个人倾向简单点。细节封装里面显得优雅。

最后按启动按钮即可

相关推荐
yaoh.wang5 分钟前
力扣(LeetCode) 28: 找出字符串中第一个匹配项的下标 - 解法思
python·程序人生·算法·leetcode·面试·职场和发展·跳槽
狂炫冰美式8 分钟前
《预言市场进化论:从罗马斗兽场,到 Polymarket 的 K 线图》
前端·后端
手揽回忆怎么睡9 分钟前
win11灵活控制Python版本,使用pyenv-win
开发语言·python
唯唯qwe-10 分钟前
Day20:贪心算法,跳跃游戏
python·算法·贪心算法
@淡 定11 分钟前
动态代理(JDK动态代理/CGLIB动态代理
java·开发语言·python
破烂pan12 分钟前
Python 整合 Redis 哨兵(Sentinel)与集群(Cluster)实战指南
redis·python·sentinel
程序员杰哥20 分钟前
接口测试之文件上传
自动化测试·软件测试·python·测试工具·职场和发展·测试用例·接口测试
2401_8414956421 分钟前
【自然语言处理】单字与双字字频统计算法设计
人工智能·python·算法·自然语言处理·单字·双字·字频统计
fegggye23 分钟前
创建一个rust写的python库[signatures和错误处理]
开发语言·python·rust
hahjee24 分钟前
Go编写的ANSI终端颜色和样式控制库在OpenHarmony PC上的完整适配实战
开发语言·后端·鸿蒙