教你使用spatie/async库来写异步的PHP代码

对于大多数用 PHP 编写的程序,它的唯一目的是执行由多个任务组成的简单进程,其中任务必须按顺序执行,如数据处理。我们总是不得不忍受同步编程的停止和等待。代码执行的同步风格被称为阻塞,这意味着任务将一个接一个地执行。那么,如果我们想要运行任务而不让它们相互阻塞,这意味着我们需要一个非阻塞进程,那该怎么办呢?这种方法需要在 PHP 中应用异步编程方法,这里的任务将在不相互依赖的情况下执行。

在 PHP 中实现非阻塞执行的一种常见方法是实现队列处理。任务被持久保存到 MySQL、Redis、Amazon SQS 等传输系统中,该传输系统由后台 worker 检索并相应地执行,从而不会阻塞创建任务的主进程。Laravel 应用程序提供了一种队列机制,允许将任务(在本例中称为作业)推迟到稍后的时间进行处理。

另一种方法是并行运行所有定义的任务。我们从这种方法中知道的是,特定的任务完成后,它可以立即将控制权交还主进程,并承诺执行代码并在稍后通知我们结果(例如回调)。人们可能很少看到并行处理方法的用例;示例用例可能是执行图像处理并向某些外部服务发出 GET 请求。

让我们通过一个非常简单的用例来看看 PHP 中同步和异步(并行)流程之间的区别。

同步代码

foreach (range(1, 5) as $i) {
    $output = $i * 2;
    echo $output . "\\n";
}

异步代码

use Spatie\\Async\\Pool;

$pool = Pool::create();

foreach (range(1, 5) as $i) {
    $pool[] = async(function () use ($i) {
       $output = $i * 2;
       return $output;
    })->then(function (int $output) {
       echo $output . "\\n";
    });
}
await($pool);

当我们执行第一个代码时,我们将按以下顺序获得输出值:

2
4
6
8
10

重试执行,我们将获得与上面相同的顺序的输出。因此,每个乘法运算都要在下一个乘法运算之前等待执行。接下来,运行第二个代码块,让我们看看我们得到了什么。

6
10
2
8
4

第二次重试执行:

2
6
4
10
8

一个过程产生两个不同的结果。这正是我们使用异步方法所得到的结果。我们的小任务可以以一种互不阻塞的方式执行。每个乘法任务都是独立执行的,有些执行得比其他任务快,因此输出结果混乱无序。另外,请注意我们的异步函数作为 then 方法附加,该方法负责取回控制权,并且它接受回调函数作为其参数,该回调函数现在可以对接收到的输出执行额外的操作。

Spatie 的工作人员开发了这个很好的spacee/async包,它有助于并行执行任务。你可以通过 Composer 安装该包:

composer require spatie/async

该包提供了一种巧妙的方式来与创建的任务进行交互,这些任务将被并行执行。任务的事件监听器描述如下:

  • 当任务完成时再执行一次操作,是因为回调可以通过它的then方法来实现。
  • 当一个特定的任务使用catch方法抛出异常时,错误处理更容易控制。
  • 当一个任务没有完成其操作时,timeout方法允许人们处理这样的场景。

事件监听器与如下所示的任务挂钩:

$pool
    ->add(function () {
        // 要在并行进程中执行的任务
    })
    ->then(function ($output) {
        // 如果成功,进程或者你传递到队列的回调函数会返回`$output`。
    })
    ->catch(function ($exception) {
        // 当进程内抛出异常时,它会被捕获并传递到这里。
    })
    ->timeout(function () {
        // 哦,不! 一个过程花了太长时间才完成。 让我们做点什么吧
    })
;

要了解更多关于这个spacee/async包的信息,请阅读它的贡献者之一的这篇文章,你也可以参考 GitHub 仓库。

原文地址:https://dev.to/webong/using-asynchronous-processes-in-php-7io

译文地址:https://learnku.com/php/t/51334

关于教你使用spatie/async库来写异步的PHP代码的文章就分享到这,如果对你有帮助欢迎继续关注我们哦

本文来自投稿,不代表重蔚自留地立场,如若转载,请注明出处https://www.cwhello.com/41826.html

如有侵犯您的合法权益请发邮件951076433@qq.com联系删除

(0)
php学习php学习订阅用户
上一篇 2022年6月23日
下一篇 2022年6月23日

相关推荐

  • PHP数组的介绍

    说明:一组(一堆)数据的集合,把多个数据进行组合,数组是由“元素”组成。 题:有6头牛,求牛的总体重和平均体重。 改进成数组的方式:

    2018年4月7日
    0407
  • 使用PHP和Haskell进行函数式编程。

    随着互联网的发展,编程语言也随之不断地更新和完善。如今,各种编程语言层出不穷,而其中PHP和Haskell这两种编程语言,都在开发者中备受关注。PHP是一种十分流行的服务器端脚本语言,用于快速开发Web应用程序。PHP…

    2023年5月30日
    00
  • PHP 判断用户的设备是否是移动设备(附代码)

    我们做网站的时候会有做到移动端和pc端,但是为了给用户良好的体验,我们会将pc端的用户和移动端的用户进行区分。下面就通过php判断用户的设备是否是移动设备 代码如下:  

    2018年3月7日
    0367
  • PHP商城开发中施行前后端分离的最佳实践

    随着商业进程的不断加速,网络购物成为了大众消费的一种主流方式。而随着网络购物平台的不断出现,也催生了各种各样的电商系统,其中最常见的就是PHP商城系统。然而,PHP商城系统的开发与维护并不是一项轻松的工作…

    2023年5月19日
    01
  • 如何在PHP中使用RESTful架构。

    随着互联网技术的发展,RESTful架构已经成为了一种主流的Web API设计风格。与传统的Web服务相比,RESTful架构更加灵活、可扩展、易于维护,因此越来越多的Web开发人员开始使用它来设计和开发前后端交互的API。本文…

    2023年5月22日
    03
  • PHP如何自定义的 printf 函数

    大家都知道 libc 的 printf() 及其家族。本章节将详细介绍 PHP 声明和使用的许多克隆,它们的目标是什么,为什么使用它们,以及何时使用它们。你知道这些函数很有用,但有时无法提供足够的功能。另外,你知道向 pri…

    2022年6月12日
    0157
  • PHP实现Memcached数据库异地容灾的方法。

    随着互联网应用规模不断扩大,数据容灾成为了一个不可避免的话题。Memcached是一种高效的缓存数据库,但是它的本地存储方式使得它存在单点故障的风险。因此,为了提高Memcached的可靠性,需要在异地进行容灾。本文…

    2023年5月21日
    00
  • PHP实现MongoDB数据库分片的方法。

    随着数据量的增加,单个MongoDB实例的存储和处理能力可能会受到限制,导致性能下降。为了更好地处理大量数据,MongoDB提供了分片的功能,在多个服务器上分散数据以提高性能和可用性。PHP作为一种常用的Web编程语言…

    2023年5月21日
    02

联系我们

QQ:951076433

在线咨询:点击这里给我发消息邮件:951076433@qq.com工作时间:周一至周五,9:30-18:30,节假日休息