成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

如何快速把你的 Python 代碼變為 API

開發 前端
Sanic,是 Python3.7+ Web 服務器和 Web 框架,旨在提高性能。它允許使用 Python3.5 中添加的 async/await 語法,這可以有效避免阻塞從而達到提升響應速度的目的。

提到 API 開發,你可能會想到 Django REST Framework,Flask,FastAPI,沒錯,它們完全可以用來編寫 API,不過,今天分享的這個框架可以讓你更快把現有的函數轉化為 API,它就是 Sanic。

Sanic 簡介

Sanic[1],是 Python3.7+ Web 服務器和 Web 框架,旨在提高性能。它允許使用 Python3.5 中添加的 async/await 語法,這可以有效避免阻塞從而達到提升響應速度的目的。Sanic致力于提供一種簡單且快速,集創建和啟動于一體的方法,來實現一個易于修改和拓展的 HTTP 服務,Sanic 具備開箱即用的功能,它可以用于編寫,部署和擴展生產級 Web 應用程序。目前 Github 有 16.3k 的星,有廣泛的社區支持。

有以下特性:

  • 內置極速 web server
  • 生產準備就緒
  • 極高的拓展性
  • 支持 ASGI
  • 簡單直觀的 API 設計
  • 社區保障
  • 如何將現有代碼快速轉化為 API

現在讓我們看,如何將代碼轉為 API,假如有已經在 functions.py 寫好的兩個函數:

import datetime


def get_datetime():
return datetime.datetime.now().strftime("%Y-%m-%d %H:%M:%S")


def sum_x_y(x, y):
return x + y

轉化為 API 只需再編寫一個 sanic_app.py :

from sanic import Sanic, json
from functions import get_datetime, sum_x_y

app = Sanic("CodeToAPI")
HOST = "localhost"
PORT = 8000

@app.route("/getdatetime")
async def getdatetime(request):
return json({"now": get_datetime()})

@app.get('/sumxy')
async def sumxy(request):
parameters = request.args
result = sum_x_y(int(parameters['x'][0]), int(parameters['y'][0]))
return json({'result': result})


if __name__ == "__main__":
app.run(host=HOST, port=PORT, debug=False)

然后,只需要執行 python sanic_app.py 就可以啟動 API 服務:

圖片

從運行結果可以得知,sanic 已經運行在生產環境模式,這與其他 Web 框架不同,其他框架帶有一個內置的開發服務器,并明確表示它只用于開發。而 Sanic 的情況恰好相反,內置的服務器可以直接用于生產環境。

可以用 curl 進行接口測試:

? curl "http://localhost:8000/getdatetime"
{"now":"2022-07-25 06:34:25"}% ? curl "http://localhost:8000/sumxy?x=12&y=34"
{"result":46}%

如果用 post,且使用 json 傳參,也是簡單的:

@app.post('/sumxy')
async def sumxy(request):
parameters = request.json
print(parameters)
result = sum_x_y(int(parameters['x']), int(parameters['y']))
return json({'result': result})

curl 這樣測試:

? curl -X 'POST' 'http://localhost:8000/sumxy' -H "Content-Type: application/json" -d '{"x":10,"y":20}'
{"result":30}%

部署在其他

Sanic 除了自帶的服務器(大多數情況推薦自帶的服務器用于生產),同樣兼容 ASGI。這意味著您可以使用你喜歡的 ASGI 服務器來運行 Sanic。現在有三大主流的 ASGI 服務器, Daphne、Uvicorn (FastAPI 用的就是這個)、Hypercorn。

也可以部署在 Gunicorn:

gunicorn myapp:app --bind 0.0.0.0:1337 --worker-class sanic.worker.GunicornWorker

靜態文件的處理,及記錄請求訪問日志,又想獲得更好的性能,可以考慮使用 Nginx 作為代理,讓 Nginx 來處理訪問日志和靜態文件,這種方式要比用 Python 處理快得多得多。

責任編輯:武曉燕 來源: Python七號
相關推薦

2021-11-17 21:58:02

Python編程語言

2011-03-04 14:39:32

Vsftpd啟動xinetd

2024-07-18 12:41:49

2023-03-31 08:25:08

零代碼開源項目

2025-03-11 08:30:00

Pythonretrying代碼

2024-08-13 08:56:22

2020-04-20 11:09:18

Python開發語言

2013-03-25 09:41:20

PythonCython

2012-06-18 15:18:32

JS

2025-02-18 11:02:01

2018-07-19 16:50:53

2022-09-04 15:54:10

Node.jsAPI技巧

2018-03-30 10:02:08

代碼規范維護工程師

2023-09-04 10:10:47

插件頁面元素

2024-05-23 11:26:02

2020-01-06 15:00:43

Linux電腦發行版

2012-03-12 09:33:04

JavaScript

2017-06-28 16:18:22

編程程序員開發

2020-07-07 10:55:01

C++C語言代碼

2022-05-29 12:57:32

GNOMEUbuntu桌面
點贊
收藏

51CTO技術棧公眾號

主站蜘蛛池模板: 99久久视频 | av网站在线播放 | www.国产日本 | 中文字幕乱码视频32 | 男人天堂久久 | 国产精品美女久久久av超清 | 青青草华人在线视频 | 欧美性tv| 亚洲精品日韩精品 | 日韩精品视频在线免费观看 | 日本免费一区二区三区视频 | 日本在线免费看最新的电影 | 欧美激情久久久 | 国产高清在线视频 | 久久精品免费看 | 欧美一级毛片在线播放 | 99re在线视频 | 亚洲欧美综合 | 人人精品| 99国产精品一区二区三区 | 一区二区三区四区毛片 | 精品国产91乱码一区二区三区 | 亚洲一区二区三区在线观看免费 | 免费视频二区 | 久久99久久| 国产欧美在线一区 | 激情一区 | 日韩精品一区二区三区中文字幕 | 久久中文视频 | 97国产精品视频人人做人人爱 | 一区二区三区免费观看 | av在线一区二区 | 亚洲欧美一区二区三区国产精品 | 91免费电影| 午夜精品| 超碰网址| 亚州精品天堂中文字幕 | 中文字幕免费视频 | 欧洲一区二区在线 | 国产精品久久亚洲 | 国产精品毛片一区二区三区 |