说明:
- 这里命令启动时候,获取进程的pid,然后fork子进程,可以将这个pid传递给子进程。
- 子进程每隔10s进行一个探活,获取父进程的id与传入的pid是否一致,这里普及一个知识点,如果父进程异常退出,这个子进程未退出就会被init进程(pid=1)接管,那么这就是一个孤儿进程。
- 同时子进程每次探活的时候就会更改redis的锁的过期时间,如果探活时间间隔是10s,那么我们的过期时间设置就是14s,多冗余一点时间。
代码实现
代码实现总是那么苍白无力哈,这里就写一个laravel的扩展来做,好处就是不影响我们主体的任何代码就完成了,我们的laravel可以随意升级。
github地址:github.com/zzh78727258…
composer地址:packagist.org/packages/ze…
总结
整体实现没有使用判断进程是否存在的ps grep等命令,因为我们docker环境不一定支持这些命令,只是用简单的pid与parent_id做对比。
laravel的在命令开始于结束都进行钩子方式,我们在Listener下面进行监听即可
public function subscribe($events) { $events->listen( [ CommandStarting::class, // 命令开始的时候 ], __CLASS__ . '@handle' ); }
整体代码是基于laravel扩展化的,不会影响laravel的升级操作。
好了,以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作具有一定的参考学习价值,谢谢大家对黑区网络的支持。