T. *_*nes 6 php parallel-processing bash
我想从bash脚本启动~10个php进程.当其中一个完成时,我希望bash脚本启动另一个php进程,并且无限期地继续,总是运行~10个php进程.
最简单的方法是什么?
每次启动的php文件都是相同的,但php进程将知道从数据库中提取新值,因此每次都处理新数据.我需要启动的文件和它的所有类都已经用php编写了.
Kyl*_*off 10
似乎非常适合上司.以下配置将确保始终运行10个进程,并处理日志轮换,这也很方便.所有输出(包括stderr)都将写入/var/log/worker.log.使用"autorestart = true",supervisord将在退出时立即替换子进程.
[program:worker]
command=php /path/to/worker.php
process_name=%(program_name)s_%(process_num)d
stdout_logfile=/var/log/%(program_name)s.log
redirect_stderr=true
stdout_capture_maxbytes=512MB
stdout_logfile_backups=3
numprocs=10
numprocs_start=0
autostart=true
autorestart=true
Run Code Online (Sandbox Code Playgroud)
一旦你有了supervisor配置(通常是/etc/supervisord/conf.d),就可以使用supervisorctl作为启动和停止进程组的便捷方式.
$ supervisorctl start worker
...
$ supervisorctl stop worker
...
$ supervisorctl status
worker:worker_0 RUNNING pid 8985, uptime 0:09:24
worker:worker_1 RUNNING pid 10157, uptime 0:08:52
...
worker:worker_9 RUNNING pid 12459, uptime 0:08:31
Run Code Online (Sandbox Code Playgroud)
| 归档时间: |
|
| 查看次数: |
1748 次 |
| 最近记录: |