Swoole定时器实现毫秒级任务调度

news2025/1/18 10:49:00

简介

`Timer` 毫秒精度的定时器,底层基于 `epoll_wait` 和 `setitimer` 实现,数据结构使用`最小堆`,可支持添加大量定时器,使用最小堆数据结构实现的定时器,类似 JavaScript 的 `setInterval`,`Swoole` 定时器的添加和删除,全部为内存操作,因此性能是非常高的。

Swoole 中的 `Timer` 与 `PHP` 本身的 `pcntl_alarm` 是不同的。`pcntl_alarm` 是基于 `时钟信号 + tick` 函数实现,一个是最大仅支持到秒,另一个是不支持同时设定多个定时器程序,性能相对来说会比较差。

间隔时钟定时器

我们可以通过 `Timer::tick` 来实现间隔时钟定时器,定时器会持续触发,每隔指定时间自动触发执行回调函数, 直到调用 `Timer::clear` 来清除指定的定时器。

$i = 0;

Swoole\Timer::tick(1000, function($id) use ($i) {

   global $i;

   echo "tick id:$id i:$i \n";

   $i++;

});

- 每隔1秒时间触发一次回调函数, 回调函数会自动打印一行信息到控制台。

一次性定时器

需要执行一次定时器的时候可以使用 `Timer::after` , 此函数是一个一次性定时器,与间隔时钟定时器不同,执行完成后就会销毁,需要注意的是 `Timer::after` 是非阻塞的。

Swoole\Timer::after(2000, function () {

   echo "执行一次的after\n";

});

- 2秒后执行回调函数,执行完成后自动退出。

清除定时器

​ `Timer::after`  执行完成后会自动退出,不需要清除,而 `Timer::tick` 没有清除定时器操作,会一直执行,直到程序退出。 当不需要定时器的时候,我们可以使用 `Timer::clear` 来达到停止定时器的目的,将对应定时器 `id` 传入该方法即可。

​ 注意,`Timer::clear` 不能用于清除其他进程的定时器,只作用于当前进程。

$i = 0;

Swoole\Timer::tick(1000, function ($id) use ($i) {

   global $i;

   echo "tick id:$id i:$i \n";

   $i++;

   if ($i > 10) {

       Swoole\Timer::clear($id);

   }

});

- 每隔1秒执行一次回调函数,当 `$i` 自增到10时,关闭定时器,此时程序会自动退出。

清除所有定时器

​ `Timer::clearAll` 用来清除同一进程空间中的计时器。基本上与 `Timer::clear` 相同,但 `Timer::clearAll` 可以一次性清除所有活动的计时器。

Swoole\Timer::tick(2000, function () {

  echo "tick \n";

});

$str = "Swoole";

Swoole\Timer::after(1000, function() use ($str) {

   echo "Hello, $str\n";

});

Swoole\Timer::clearAll();

结尾

​ 定时器功能可以很方便的实现定时任务,例如 `CRMEB Pro系统` 中的自动取消订单、自动确认收货、自动商品上下架、自动到期租户等操作就是基于 `Timer::tick` 来实现的。

​ [CRMEB Pro系统](https://crmeb.com/web/index/pro) 以卓越的系统性能,个性的后台操作,丰富的营销功能,精细化的用户运营,裂变式分销,个性化传播,解决电商引流、推广难题,帮助企业打造生态级B2C盈利模式商城。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/528229.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

I2C通信协议原理和MPU6050

一、串口通讯 只能在两个设备之间进行 若要三台设备两两通信,则每个设备得需要两组窗口,为3组相互独立的窗口通讯 为解决这个问题:设计了总线通讯,有多种,I2C为其中一种 二、I2C通信 (1&#…

(java)异常 (详解)

目录 1. 异常的概念 1. 算术异常 2.空指针异常 3.数组越界异常 4.在编译时就发现了异常 2.异常的体系结构 总结: 3.异常的分类 4.异常的处理 1 .防御式编程 2.异常的抛出 3 .异常的捕获 3.1 .异常声明throws throw和throws的区别? …

【笔试强训选择题】Day13.习题(错题)解析

作者简介:大家好,我是未央; 博客首页:未央.303 系列专栏:笔试强训选择题 每日一句:人的一生,可以有所作为的时机只有一次,那就是现在!!! 文章目录…

昨天的测试岗面试,仅仅4个问题,轻松让面试者破防了

目录 引言 你看,一不小心,就要被虐!! 自动化测试到底该如何学? 一、Python编程学习内容 二、WEB自动化测试学习内容 三、APP自动化测试学习内容 四、Postman接口测试工具学习内容 五、接口自动化测试学习内容 …

微服务框架【Nacos配置管理-Feign远程调用-Gateway服务网关】

一、Nacos配置管理 1.统一配置管理 在Nacos中添加配置信息 填写配置信息 点击发布 完成配置的统一管理 配置获取的步骤: 项目启动->读取本地配置文件application.yml->创建spring容器->加载bean 但是现在多了一个nacos中的配置文件,我们…

IntelliJ IDEA 统一设置编码为utf-8编码 及 SpringBoot 打 jar 包运行 在windows 平台控制台和日志 乱码解决

文章目录 一、背景二、知识准备三、程序运行源代码历经处理阶段四、问题描述五、解决方法1.修改项目编码格式统一为UTF-82.将项目中的.idea文件夹中的encodings.xml文件中的编码格式改为uft-83.File->Settings->Build,Execution,Deployment -> Compiler -> Java Co…

架构师日记-从数据库发展历程到数据结构设计探析 | 京东云技术团队

作者:京东零售 刘慧卿 一、数据库发展史 起初,数据的管理方式是文件系统,数据存储在文件中,数据管理和维护都由程序员完成。后来发展出树形结构和网状结构的数据库,但都存在着难以扩展和维护的问题。直到七十年代&am…

分布式补充知识 02.AOP的重要注解@annotation ,使用添加缓存和清空缓存

01.在项目中创建一个包annotation包: 在创建新的java.class文件时候,选择annotation 写一个自定义的注解,名字叫做RequiredCache package com.cy.annotation;package com.cy.annotation;import java.lang.annotation.ElementType; import j…

企业远程工作安全及简化

员工远程面临哪些挑战 大多数企业已将远程工作模式作为其新常态,这使得保护远程端点成为比以往更高的优先级。然而,在寻求远程工作支持的安全性时,企业有时会忽视用户体验。过于严格的远程工作解决方案没有考虑到经常在工作场所和家庭的安全…

执行SQL响应比较慢,你有哪些排查思路?

如果执行SQL响应比较慢,我觉得可能有以下4个原因: 第1个原因:没有索引或者 导致索引失效。第2个原因:单表数据量数据过多,导致查询瓶颈第3个原因:网络原因或者机器负载过高。第4个原因:热点数据…

基于Canal实现Mysql数据实时同步到Elasticsearch(Docker版)

1、Canal简介 Canal主要用途是对MySQL数据库增量日志进行解析,提供增量数据的订阅和消费,简单说就是可以对MySQL的增量数据进行实时同步,支持同步到MySQL、Elasticsearch、HBase等数据存储中去。 Canal会模拟MySQL主库和从库的交互协议&#…

SpringMVC常用注解用法

Spring MVC是基于Servlet API构建的原始Web框架。 MVC是Model View Controller的缩写即视图模型控制器,是一种思想,而Spring MVC是对该思想的具体实现。关于SpringMVC的学习我们需要掌握用户和程序的连接、获取参数以及返回数据三大部分。而这三大功能的…

2023-5-15-gRpc框架学习

🍿*★,*:.☆( ̄▽ ̄)/$:*.★* 🍿 💥💥💥欢迎来到🤞汤姆🤞的csdn博文💥💥💥 💟💟喜欢的朋友可以关注一下&#xf…

前端魔力赏盲盒小程序 UI原生盲盒微信小程序源码下载

前端魔力赏盲盒小程序 UI原生盲盒微信小程序源码下载 亲测可用 前端是小程序原生源码。 很不错的一款盲盒小程序。 完全没有毛病,非常适合研究学习。

【Linux】匿名管道

目录 匿名管道管道特点父子进程通过匿名管道通信匿名管道通信案例 橙色 匿名管道 管道也叫无名(匿名)管道,是 UNIX 系统 IPC(进程间通信) 的最古老的形式。 统计一个目录中文件的数目命令 ls | wc -l ,为…

会自动化就能拿20K?想多了,你这顶多算是会点皮毛···

现在招个会自动化测试的人是真难呀~ 前一段时间公司计划要招2个自动化测试到岗,同事面试了十几个来应聘的人,发现一个很奇怪的现象,在面试的时候,如果问的是框架API、脚本编写这些问题,基本上所有人都能对答如流&…

湖北省智能科教研究会走进璞华,调研璞公英教学平台个性化教学新模式

2023年5月9日,热烈祝贺湖北省智能科教研究会红5月智能科教走进璞华集团活动圆满成功。会议上,大家畅所欲言,对教育体制改革与教育信息化产品创新,科技成果转化、产教融合、资源互补、学生能力培养等方面展开充分沟通和探讨。 5月9…

解密 Android IPC 机制

在我们使用 Android 手机的时候,有时我们使用的软件会需要消耗比较大的内存,也经常会需要同时打开多个软件。这些时候,我们都会需要使用到多进程技术。作为 Android 开发者,相信我们都知道如何去开启应用的单个多进程,…

【Linux常见指令以及权限理解】权限理解(4)

写在前面 这篇文章,我们来聊一聊Linux下权限相关的知识,我打算从这几个方面展开: 1. 认识Linux下用户的分类 2. 什么叫做权限 3. 没有权限会是什么样子 4. 如何修改权限 5. 其它重要的问题 那么废话不多说,我们现在开始。 …

PDF怎么转换成Word?将PDF转换为Word的三种方法!

在我们需要将PDF文件转换为Word文件时,有几种方法可以选择。通常,我们在文件传输过程中使用的文件格式是PDF,但如果我们需要对文件进行编辑,就需要将其转换为可编辑的Word格式。下面是几种转换方法的介绍,让我们一起来…