[Shell] swoole_timer_tick 与 crontab 实现定时任务和监控

手动完成 "任务" 和 "监控" 主要有下面三步:

 

1. mission_cron.php(定时自动任务脚本):

复制代码
<?php
/*** 自动任务 定时器 (5s 执行).** swoole_timer_tick 解决秒级定时;* 如需调整,注意配置路径 和 mission_cron_monitor.** Daemon Run:*  ./mission_cron_monitor** Foreground Run:*  php mission_cron.php** Stop:*  kill -9 PID** @farwish.com*/swoole_timer_tick(5000, function() {// 查询结果// 事务性更新// 记录日志// 输出结果
}
复制代码

 

2. mission_cron_monitor (由 crontab 运行,监控上述脚本):

复制代码
#/bin/bash
# 监控定时器,断掉重启.
#
# crontab used in /var/spoor/cron/
# ( crontab -e )
#
# @farwish.comphpbin=/usr/local/php7/bin/php
curdir=`dirname $0` 
script=${curdir}/mission_cron.php
process=`ps aux | grep -v grep | grep ${script}`if test -z "$process"; thennohup ${phpbin} ${script} > /dev/null 2>&1 &
fi
复制代码

这里 curdir 没有使用 `pwd`,原因在于 pwd 获取的是当前所在工作目录,非执行的脚本所在目录,你可以通过 man 获得详细解释。

  pwd - print name of current/working directory

  dirname - strip last component from file name

 

nohup的作用在于不受终端挂断影响,配合 & 后台运行,完美实现了 daemon.

 

3. 设置用户级 cron 脚本.

# 用户级运行cron.
# 分 时 日 月 周 命令
# @farwish.com# 每分钟执行
*/1 * * * * /home/www/project/mission_cron_monitor

 

完成以上三步,主要工作就完了,可以运行查看效果了;

重申:mission_cron.php 任务不一定要包在 swoole_timer_tick 回调函数内,仅在执行 秒/毫秒 定时需要。

 

脚本虽然简单,但是有一些问题需要当心,如下:

 

1. 排错:任务有没有执行通过看日志 /var/log/cron 是否有执行记录,

     有执行的话就是脚本问题,语法错误或者其它。注意,脚本中一律使用绝对路径。

 

2. 级别:系统级任务   /ect/crontab

     用户级任务   直接用 crontab -e 编辑(存放位置 /var/spoor/cron/weichen)

     程序级任务   swoole_timer_tick(1000, function() {});

 

3. 选项:crontab -e 

     crontab -l   # 当前用户拥有的 cron

     crontab -r   # 删除当前用户的 cron

     crontab -ri  # 删除前先询问

  更多 crontab -h

转载于:https://www.cnblogs.com/wanglijun/p/8707599.html

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

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

相关文章

关于项目调研

一、柠檬时代app 1、作品内容&#xff1a; 该作品主要为每一所高校的大学生量身定制的手机生活助手&#xff0c;由您自主运营的校园手机客户端。开放的自定义平台&#xff0c;汇聚本校周边所有生活服务、外卖商家、娱乐休闲、新鲜事儿、知名社团、周边商铺、校园达人等栏目。 …

html 标签

html概述 超文本标记语言&#xff08;英语&#xff1a;HyperText Markup Language&#xff0c;简称&#xff1a;HTML&#xff09;是一种用于创建网页的标准标记语言。HTML是一种基础技术&#xff0c;常与CSS、JavaScript一起被众多网站用于设计令人赏心悦目的网页、网页应用程序…

es6 --- forEach的实现

forEach的第一个参数 接收回调函数 let a [a, b, c]; a.forEach((v, k ,s)>{console.log(v, k ,s);console.log(this); })v: valuek: keys: 代表数组a本身this指向当前函数执行所在的作用域,即window forEach的第二个参数. forEach第1个参数用于接收回调函数,第2个参数…

java Calendar

1.1 Calendar类概念 Calendar是日历类&#xff0c;在Date后出现&#xff0c;替换掉了许多Date的方法。该类将所有可能用到的时间信息封装为静态成员变量&#xff0c;方便获取。 Calendar为抽象类&#xff0c;由于语言敏感性&#xff0c;Calendar类在创建对象时并非直接创建&…

结对项目之需求分析与原型设计

结对项目之需求分析与原型设计 031402317 李佳恺 031402511 黄家俊 这是我们两个人第一次合作&#xff0c;虽然结对是栋哥帮我们分配的&#xff0c;并且一开始我们就认识&#xff0c;但是也很开心有这个机会能一起合作完成任务。 初步分工我负责随笔&#xff0c;家俊负责原型设…

javaEE项目部署方式

1、手动部署 2、自动化部署 “自动化”的具体体现&#xff1a;向版本库提交新的代码后&#xff0c;应运服务器上自动部署 转载于:https://www.cnblogs.com/zyc-blogs/p/9674606.html

vue --- 2.0数据的响应式的一种实现

初识: 实际上是通过Object.defineProperty()方法来实现的talk is cheap, show your code let obj {}; Object.defineProperty(obj, name, {get(){return document.querySelector(#name).innerHTML;},set(newVal){document.querySelector(#name).innerHTML val;} })// 注1: …

心得开始之路

本人是大四实习狗&#xff0c;现在最大的问题是什么&#xff1f; 一&#xff1a;实力不够 二&#xff1a;人又懒 开始以为就做做运维&#xff0c;学学服务器就可以了&#xff0c;但是现在才发现&#xff0c;嗯&#xff0c;不会开发的运维什么都不算。 现在开始学习Python自动运…

结对编程作业——毕设导师智能匹配

结对编程作业——毕设导师智能匹配 031402317 李佳恺031402511 黄家俊 问题描述及要求 输入30个老师&#xff08;包含带学生数的要求的上限&#xff0c;单个数值&#xff0c;在[0,8]内&#xff09;&#xff0c;100个学生&#xff08;包含绩点信息&#xff09;&#xff0c;每…

内置函数二

内置函数: 1.lambda 匿名函数 lambda 参数:返回值 例    resultlambda x,y:xy sresult(x3,y4) print(s) 2.sorted 排序 sorted(iterable, keyfunc, reverseTurn/False) 例    lst [1, 8, 18, 19, 97, 12, 3] lst.sort() lst自带的排序功能  l2 sorted(lst) 排序…

vue --- 2.0响应式补充

补充: 数组的响应式 // 对数组的方法进行重写 // 1. 不能影响本来的方法 // 2. 调用的时候可以找到它 let odlArrayPrototype Array.prototype; let proto Object.create(odlArrayPrototype); // 继承 [push,shift,unshift].forEach(method >{proto[method] function(){…

OptaPlanner - 把example运行起来(运行并浅析Cloud balancing)

经过上面篇长篇大论的理论之后&#xff0c;在开始讲解Optaplanner相关基本概念及用法之前&#xff0c;我们先把他们提供的示例运行起来&#xff0c;好先让大家看看它是如何工作的。OptaPlanner的优点不仅仅是提供详细丰富的文档 &#xff0c;还为各种应用场景提供丰富的示例&am…

es6 --- 使用proxy对数据进行劫持

说明: 数据劫持,简单的说就是在对数据进行操作(增删改查)时,触发的函数下面想通过使用以下的形式来使用: let proxy reactive({ name:lz }); proxy.name; // 获取 proxy.name 栗子; // 设置 delete proxy.name; // 删除解决方案: proxy函数的2个参数第一个参数: 接收一…

Java8-如何构建一个Stream

Stream的创建方式有很多种&#xff0c;除了最常见的集合创建&#xff0c;还有其他几种方式。 List转Stream List继承自Collection接口&#xff0c;而Collection提供了stream()方法。 List<Integer> list Lists.newArrayList(1, 2, 3); Stream<Integer> stream li…

软件产品案例分析

软件产品案例分析 第一部分&#xff1a; 评测&#xff1a; 上手体验&#xff1a; 说实话&#xff0c;在老师布置这个作业之前我确实不知道有K米这个APP&#xff0c;我想这是很少去KTV的原因吧。。。不过在接到这个作业后&#xff0c;我就去百度了普及了一下这个app的相关知识。…

java/android 做题中整理的碎片小贴士(12)

1、edittext中设置最长字数&#xff0c;可在xml中加入android:maxLength"10"&#xff0c;可在java代码中加入editText.setFilters(new InputFilter[]{new InputFilter.LengthFilter(20)}); 2、edittext监听软键盘delete按键&#xff1a; Et.setOnKeyListener(new Vi…

POJ2777(线段树裸题)

题目&#xff1a;http://poj.org/problem?id2777 别忘了各地的return&#xff1b; 有可能输入的L<R&#xff0c;手动swap&#xff1b; 似乎是多组输入&#xff1f; pushup和pushdown的位置。 &#xff08;原来pushup只有一行&#xff09; 要开四倍数组。是这种写法的原因吧…

vue --- 2.0 编译的实现

初识 假设html中有如下dom: <div id"app"><!-- 插值绑定 --><p>{{name}}</p><!-- 指令解析 --><p l-text"name"></p><p>{{age}}</p><p>{{doubleAge}}</p><!-- 双向绑定实现 -->…

个人作业收官——软件工程实践总结

一、回望与展望 1.1 对比现在和开学初博客开篇的课程目标和期待 当初的目标&#xff1a; 提升团队合作的能力能够学习到开发的一系列流程&#xff0c;以及如何写高质量的代码加强自己的编码能力&#xff0c;以及编码习惯熟悉不同平台的开发过程 如今&#xff1a; 基本的目标都…