首页 > 其他分享 >FastAPI-9 服务层

FastAPI-9 服务层

时间:2024-06-13 20:55:47浏览次数:31  
标签:服务 explorer get FastAPI py test data creature

9 服务层

本章阐述了服务层,即中间层。

9.1 定义服务

服务层是网站的核心,它接收来自多个来源的请求,访问作为网站DNA的数据,并返回响应。
常见的服务模式包括以下组合:

  • 创建/检索/更改(部分或全部)/删除
  • 一件事/多件事
    在 RESTful 路由器层,名词是资源。在本书中,我们的资源最初将包括隐形生物(想象中的生物)和人(隐形生物探险家)。

以后,我们还可以定义类似的相关资源:

  • 地点
  • 事件(如探险、目击等)

9.2 布局

以下是当前的文件和目录布局:

main.py
web
├── __init__.py
├── creature.py
├── explorer.py
service
├── __init__.py
├── creature.py
├── explorer.py
data
├── __init__.py
├── creature.py
├── explorer.py
model
├── __init__.py
├── creature.py
├── explorer.py
fake
├── __init__.py
├── creature.py
├── explorer.py
└── test

9.3 函数

让我们从 creature.py 开始。在这一点上,explorer.py 的需求几乎相同,我们可以借用几乎所有的东西。我们很想编写一个服务文件来处理这两个文件,但几乎不可避免的是,在某些时候我们需要以不同的方式处理它们。
另外,在这一点上,服务文件几乎就是一个直通层。在这种情况下,一开始就增加一些额外的结构,以后就会有所回报。就像第8章中的 web/creature.py和web/explorer.py,我们将为这两个文件定义服务模块,并暂时将它们与相应的假数据模块挂钩。

service/creature.py

from models.creature import Creature
import fake.creature as data

def get_all() -> list[Creature]:
    return data.get_all()

def get_one(name: str) -> Creature | None:
    return data.get(id)

def create(creature: Creature) -> Creature:
    return data.create(creature)

def replace(id, creature: Creature) -> Creature:
    return data.replace(id, creature)

def modify(id, creature: Creature) -> Creature:
    return data.modify(id, creature)

def delete(id, creature: Creature) -> bool:
    return data.delete(id)

service/explorer.py

from models.explorer import Explorer
import fake.explorer as data

def get_all() -> list[Explorer]:
    return data.get_all()

def get_one(name: str) -> Explorer | None:
    return data.get(name)

def create(explorer: Explorer) -> Explorer:
    return data.create(explorer)

def replace(id, explorer: Explorer) -> Explorer:
    return data.replace(id, explorer)

def modify(id, explorer: Explorer) -> Explorer:
    return data.modify(id, explorer)

def delete(id, explorer: Explorer) -> bool:
    return data.delete(id)

9.4 测试

现在,代码库正在逐渐充实,是引入自动测试的好时机,让我们创建一些目录:

  • test:顶级目录,与web, service, data和model目录并列。
    • unit: 测试单个函数,但不跨层。
      • web: 网络层单元测试。
      • service: 服务层单元测试。
      • data:数据层单元测试。
  • full: 也称为端到端或合约测试,这些测试同时跨越所有层。它们涉及网络层的 API 端点。

这些目录有test_前缀或_test 后缀,供pytest使用 。
在测试之前,需要对 API 的设计做出一些选择。如果找不到匹配的 Creature 或 Explorer,get_one() 函数应该返回什么?可以返回 None,或者引发异常。没有一个内置的Python异常类型可以直接处理缺失值:

  • TypeError可能是最接近的,因为 None与Creature 是不同的类型。
  • ValueError 更适用于给定类型的错误值,但我想你也可以说,向 get_one(id)传递一个缺失的字符串 id 也符合条件。
  • 如果你真的需要,也可以定义自己的MissingError。

test/unit/service/test_creature.py

from model.creature import Creature
from service import creature as code

sample = Creature(name="yeti",
        country="CN",
        area="Himalayas",
        description="Hirsute Himalayan",
        aka="Abominable Snowman",
        )

def test_create():
    resp = code.create(sample)
    assert resp == sample

def test_get_exists():
    resp = code.get_one("yeti")
    assert resp == sample

def test_get_missing():
    resp = code.get_one("boxturtle")
    assert data is None

执行:

$ pytest -v test/unit/service/test_creature.py
test_creature.py::test_create PASSED                         [ 16%]
test_creature.py::test_get_exists PASSED                     [ 50%]
test_creature.py::test_get_missing PASSED                    [ 66%]

======================== 3 passed in 0.06s =========================

参考资料

9.5 其他服务层内容

我们现在正处于堆栈的中间部分--真正定义网站目的的部分。到目前为止,我们只用它将网络请求转发到(下一章的)数据层。
到目前为止,本书以迭代的方式开发了网站,为今后的工作打下了最基本的基础。当你对你所拥有的、你所能做的以及用户可能需要的有了更多了解后,你就可以进行扩展和尝试。有些想法可能只对大型网站有益,但这里有一些技术性的网站辅助想法:

  • Logging
  • Metrics
  • Monitoring
  • Tracing

9.5.1 Logging

FastAPI会记录每次对端点的API调用,包括时间戳、方法和 URL,但不会记录通过正文或标头传递的任何数据。

9.5.2 指标、监控和可观察性

如果你运行一个网站,你可能想知道它的运行情况。对于 API 网站,你可能想知道哪些端点正在被访问、有多少人在访问等等。对这些因素的统计称为度量,收集度量是监控或可观察性。
时下流行的度量工具包括用于收集度量数据的Prometheus和用于显示度量数据的Grafana。

9.5.3 跟踪

您的网站性能如何?常见的情况是,度量指标总体良好,但某些地方或某些地方的结果令人失望。或者整个网站一团糟。无论哪种情况,有一个工具可以测量 API 调用从头到尾所需的时间--不仅是整体时间,还包括每个中间步骤的时间,这非常有用。如果某项工作进展缓慢,就可以找到链条中的薄弱环节。这就是跟踪。

一个新的开源项目采用了早期的跟踪产品(如 Jaeger),并将其命名为 OpenTelemetry。它有一个Python API,并至少与FastAPI 进行了一次集成。

9.5.4 其他

除此以外,我们的域密码和与之相关的任何内容又是怎样的呢?除了探索者和生物的基本细节外,你还想做什么?你可能会想出需要修改模型和其他层的新想法。以下是一些你可以尝试的想法:

  • 探险者与他们寻找的生物的链接
  • 目击数据
  • 探险
  • 照片和视频
  • 大脚野人马克杯和T恤衫

9.6 小结

在本章中,你复制了网络层中的一些函数,并移动了它们所使用的假数据。目的是启动新的服务层。到目前为止,这个过程都是按部就班地进行的,但在此之后,它还会不断发展和变化。下一章将构建最终的数据层,形成一个真正的实时网站。

标签:服务,explorer,get,FastAPI,py,test,data,creature
From: https://www.cnblogs.com/testing-/p/18242828

相关文章

  • 6.13API接口服务类漏洞探针
    ip地址解析:www.x.x.x.com,对应网站目录为d:/wwwroot/xiaodi/而127.x.x.x,对应网站目录为d:/wwwroot/,可能存在网站备份文件zip,所以ip网址端口都的扫描;协议端弱口令爆破:超级弱口令检查工具;端口服务安全问题(用于无思路时)思路:利用探针对端口探测后,对口令安全、Web漏洞、中间......
  • 基于SpringBoot+Vue+uniapp的高校图书馆个性化服务的详细设计和实现(源码+lw+部署文档
    文章目录前言详细视频演示具体实现截图技术栈后端框架SpringBoot前端框架Vue持久层框架MyBaitsPlus系统测试系统测试目的系统功能测试系统测试结论为什么选择我代码参考数据库参考源码获取前言......
  • linux中FTP文件传输服务
    ftp是一种文件传输协议:用来上传和下载,实现远程共享文件,和统一管理文件。工作原理:用于互联网上的控制文件的双向传输是一个应用程序。工作在TCP/IP协议簇的,其传输协议是TCP协议提高文件传输的共享性和可靠性,使用C/S模式的工作方式连接时同时处理服务器和客户端的连接命令和数......
  • FastAPI-7:框架比较(Flask、Django及FastAPI)
    7框架比较(Flask、Django及FastAPI)关于一个新的Web框架,您可能想知道的第一件事就是如何入门,而一种自上而下的方法就是定义路由(从URL和HTTP方法到函数的映射)。7.1FlaskFlask自称是微框架。它提供基本功能,你可以根据需要下载第三方软件包进行补充。它比Django小,入门时学习......
  • 如何搭建边缘服务器,部署 Cloudflare Worker,实现Internet网络代理。
    何为CloudflareWorker?CloudflareWorker是Cloudflare提供的一种服务,它允许开发者在全球分布的边缘服务器上运行自定义的JavaScript代码。CloudflareWorker可以用来处理HTTP请求,从而允许开发者通过编写JavaScript代码来实现各种功能,例如路由请求、修改请求和响......
  • 代理离线服务器yum、curl命令访问网络
    在CentOS7上,你可以使用Squid作为代理服务器。以下是在CentOS7上设置代理的简要步骤:1.在可以上网的服务器上安装Squid:sudoyuminstallsquid2.配置Squid:打开Squid配置文件进行编辑:sudonano/etc/squid/squid.conf找到并编辑以下行(确保取消注释并设置合适的值):http_access......
  • 42、k8s-数据存储-高级存储-pv和pvc、NFS服务器
    PV(PersistentVolume)是持久化卷的意思、是对底层的共享存储的一种抽象、一般情况下PV有kubernetes管理员进行创建和配置、他与底层具体的共享存储技术有关、并通过插件完成于共享存储的对接PVC(PersistentVolumeClaim)是持久卷声明的意思、是用户对于存储需求的一种声明、换句话......
  • 清洁取暖监管服务应用
    随着科技的飞速发展,工业物联网(IoT)技术正在逐步渗透到我们生活的方方面面,其中包括了取暖领域。在传统行业中,取暖方式往往伴随着高能耗和高污染,而清洁取暖监管服务应用的出现,正是为了解决这一问题,推动取暖方式向更加环保、高效的方向转变。所谓“清洁取暖”,是指利用清洁能源进行取......
  • IBM服务器阵列卡损坏恢复案例
    一台IBM服务器,型号是7944IBM的3550M3的服务器差不多有10年左右,有4块1TB的SAS硬盘,开机面板有报错,系统进不了,是一台金蝶K3的就是ERP的财务服务器资料相当重要,客户的需求是希望就是数据不丢的前提下,把系统启动起来,给它修复。好在实际检测了硬件后发现,是阵列卡损坏,导致raid的信......
  • 微服务架构qiankun集成react子应用
    前一篇文章讲了qiankun集成vue子应用,这篇随笔讲集成react子应用。1、创建react子应用用react脚手架初始化一个react项目,至于项目的数据仓库store和路由、以及UI组件库这里就不做讲解,可以自己自行网上找资料配置。create-react-appmy-react-app2、在src路径下创建publicPat......