首页 >后端开发 >php教程 >Laravel 资源还是定制存储库?

Laravel 资源还是定制存储库?

PHPz
PHPz原创
2024-08-21 16:37:32439浏览

本周早些时候,在使用 Laravel Rest API 时,我遇到了超时错误的烦恼。它导致最终用户对开发问题感到沮丧。让我简单介绍一下整个场景:

我需要从外部数据源加载数据,过滤它,然后准备 json 返回。数据量不大,单次请求只有10K左右。当我在检索和过滤它们后尝试格式化它们时,出现了主要问题。所以,我开始使用以下步骤进行调试:

  • 检查查询是否已优化以及列是否已建立索引。

  • 确保使用 chunk 方法

  • 检查格式化仓库没有使用任何不必要的方法/引用/实现/未使用的函数/外部API调用。

所有检查均已完成,但仍然显示网关超时错误,因为它超过了 1 分钟。服务类如下所示:

Laravel Resource or Customized Repo?

repo 类如下所示:

Laravel Resource or Customized Repo?

肉眼看来,10K+数据处理和操作不应该抛出超时错误。我们将在最后讨论为什么会发生这种情况(可能不是实际的具体原因,但很可能),现在讨论如何使用 Laravel Api 资源解决它。


实施起来很简单。首先,从命令行生成 Laravel Api 资源:

php artisan make:resource DataFormatterResource

然后,将您的模型对象发送到资源并按照下面给出的要求格式化/操作您的数据:

Laravel Resource or Customized Repo?

Laravel Resource or Customized Repo?

令人惊讶的是,只用了3.7秒就回复了?!
我试图在这里挖掘出真正的问题,并发现了一些可能的情况,上面提到了最后的定义。给出案例:

  1. Laravel API 资源提供了一个一致的接口来访问和操作数据,我使用存储库并在其中进行一些依赖项注入。这使得编写高效代码并避免常见的性能瓶颈变得更加容易。
  2. Laravel API 资源针对性能进行了优化,因为它们使用缓存和其他技术来提高数据检索和处理的速度,而我只选择数组原始格式的块。
  3. Laravel API 资源根据请求标头自动将数据库查询结果序列化为 JSON 或 XML。这为您省去了编写自己的序列化代码的麻烦。

在我的项目的大多数服务中,我在服务层使用了存储库或功能格式化程序,但在这种情况下,我遇到了困难,因为可能有其他原因导致此问题发生。
我想强调的是,在使用模型时,Laravel Resources 在一些棘手的情况下可能会派上用场。

如果您喜欢这篇文章,请点赞或评论。 =“编码愉快!……” ?>

以上是Laravel 资源还是定制存储库?的详细内容。更多信息请关注PHP中文网其他相关文章!

声明:
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
上一篇:Stone Game II下一篇:PHP Property Hooks