美文网首页
FastAPI简单操作

FastAPI简单操作

作者: AsdilFibrizo | 来源:发表于2020-06-11 15:32 被阅读0次

FastAPI
首先讲一下基础操作,然后在介绍这些操作的意义

1. 创建

假设你创建了一个main.py的函数,并保存

from fastapi import FastAPI
app = FastAPI()

@app.get("/")
def read_root():
    return {"Hello": "World"}
uvicorn main:app --reload

然后你可以在cmd中使用启动这个程序, 然后会显示一下信息:

localhost@asdil:/tmp/study$ uvicorn mian:app --reload
INFO:     Uvicorn running on http://127.0.0.1:8000 (Press CTRL+C to quit)
INFO:     Started reloader process [2414126] using statreload
INFO:     Started server process [2414128]
INFO:     Waiting for application startup.
INFO:     Application startup complete.

接下来你在浏览器中打开http://127.0.0.1:8000就会显示一个最基础的get页面


基础get页面

如果不是在本地,而是使用远程服务器,那么你的启动命令变成:

uvicorn main:app --host '远程机器ip' --port 端口 --reload
比如:
uvicorn main:app --host '192.168.30.17' --port 8000 --reload

uvicorn参数解释:
main: 指定主程序文件main.py文件, 如果main.py文件改成test.py 则命令也需要改为uvicorn test:app
app:在main.py中使用app = FastAPI()创建的对象
--host:远程主机ip,如果是本地则可以不要这个参数
--host:端口号
--reload:在修改源代码后程序会自动重新加载不用退出重新启动

注意:

在使用 uvicorn main:app --reload启动后,如果想shutdown请使用ctrl+c, 而不是ctrl+z,后者其实是退出前台,如果ctrl+z后你想在启动会报端口被占用

2. get

这个是最常见的请求形式
(1) url参数
修改main.py

from fastapi import FastAPI
app = FastAPI()
# url参数定义在这个修饰器里面
@app.get("/{url}")
def read_root():
    return {"Hello": "World"}

我们在@app.get中定义了url参数,那么我们下次get请求时就不能直接输入http://127.0.0.1:8000而是http://127.0.0.1:8000/xxxx(xxxx表示任意字符串)

(2) param参数
修改main.py

from fastapi import FastAPI
app = FastAPI()
# url参数可以和param重合
@app.get("/{url}")
def read_root(url: str, parms_1: str, parms_2: str=None):
    return {'url地址是: ': url, "parms_1参数是 ": parms_1, "parms_2参数是 ": parms_2}

这是输入http://192.168.30.17:8000/anywords?parms_1=abc&parms_2=def就可以了,这里我使用的是远程服务器,因此我指定了ip和端口

parm参数
说明:
1.如果有parm参数则在地址后面加 ?,多个parm参数使用 & 连接
2.return中单引号和双引号没有区别
3.从上面可以看出url参数可以和parm参数合一,这是第一个url参数就不需要?url=,而是直接跟在端口80000/后面

3. post

post方法参数不是直接接在url后面,安全性会好一些
使用post时需要继承BaseModel这个类
(1)body参数

from fastapi import FastAPI
from pydantic import BaseModel    #fastapi的一个依赖,需要从pydantic中引入
app = FastAPI()
class Args(BaseModel):    #继承BaseModel
    data_str: str    #定义一个字符串型参数
    data_int: int    #定义一个整形参数
    data_list: list  #定义一个列表
        
@app.post("/test_post")
async def postEchoApi(args:Args):    #设置刚才定义的参数
    dict_args = args.dict() # 也可以转化为字典
    return {"str data":args.data_str, 
            'int data': args.data_int, 
            'list data':args.data_list, 
            'args 数据类型': str(type(args))}
postman

测试post的时候就用postman就可以了,注意是在Body选择Raw在选择Json形式传入参数

3. 在服务器部署fastapi

第一种使用方式

uvicorn main:app --host '0.0.0.0' --port 8000 --reload --workers 1

第二种使用方式(推荐)
Gunicorn是一个成熟的、功能齐全的服务器和流程管理器。
Uvicorn包含一个Gunicorn worker类,允许您运行ASGI应用程序,具有Uvicorn的所有性能优势,同时还为您提供了Gunicorn的全功能流程管理。
这允许您动态地增加或减少工作进程的数量,正常地重新启动工作进程,或者在不停机的情况下执行服务器升级。
对于生产部署,我们建议将gunicorn与uvicorn worker类一起使用。

gunicorn main:app -b 0.0.0.0:8000 -w 1 -k uvicorn.workers.UvicornWorker

===============================下次再写===========================

相关文章

  • FastAPI简单操作

    FastAPI首先讲一下基础操作,然后在介绍这些操作的意义 1. 创建 假设你创建了一个main.py的函数,并保...

  • fastapi教程翻译(一):了解FastAPI结构

    一、编写一个简单的FastAPI程序 最简单的FastAPI文件可能如下: 将上面代码块复制到 main.py. ...

  • FastAPI操作database

    简单记录一下使用FastAPI完成对数据库的CRUD操作。在参考文档的基础上,增加了U、D部分,全部代码可以参考G...

  • fastapi介绍(二):运行Hello, FastAPI应用

    下面,让我们创建一个超级简单的fastapi项目。 一、创建fastapi项目 1、创建main.py文件 如果你...

  • FastAPI+SQLServer 中文乱码问题

    因为在FastAPI相关博客里没有搜到答案,于是分享出来~最近在用FastAPI给App写一个简单的登录注册系统的...

  • FastAPI使用小结

    以一个实际构建API的例子介绍FastAPI在已有数据情况下的简单应用 简介 FastAPI是一个现代、快速(高性...

  • 1.FastAPI介绍

    一、 Fastapi是什么 FastAPI 框架,高性能,易于学习,高效编码,生产可用 FastAPI 是一个用于...

  • FastAPI -- python 后端开发 01

    FastAPI 是啥 FastAPI framework, high performance, easy to l...

  • FastAPI官档精编002 - 特性

    呆鸟云:发布本系列旨在推广 FastAPI 以及推进 FastAPI 中文官档翻译,目前,FastAPI 官档已完...

  • FastAPI官档精编001 - 简介

    呆鸟云:发布本系列旨在推广 FastAPI 以及推进 FastAPI 中文官档翻译,目前,FastAPI 官档已完...

网友评论

      本文标题:FastAPI简单操作

      本文链接:https://www.haomeiwen.com/subject/ccnvtktx.html