我的编程空间,编程开发者的网络收藏夹
学习永远不晚

php如何使用多进程

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

php如何使用多进程

这篇文章给大家分享的是有关php如何使用多进程的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。

  1. 代码:

    <?php
    
    class process{
    public $num = 10;  #  进程数
    public $timeout = 4;  #  延迟时间
    public $pipedir = "pipe/";  #  管道目录
    public $logdir = "log/";  #  日志目录
    public $errlog = "err.log";  #  错误日志
    public $successlog = "success.log";  #  成功日志
    
    public function __construct(){
        $pipedir = $this->pipedir;
        $logdir = $this->logdir;
        if(!is_dir($pipedir)){
            if(!mkdir($pipedir)){
                $this->write_log(1,"创建管道目录{$pipedir}失败");
            }
        }
        if(!is_dir($logdir)){
            if(!mkdir($logdir)){
                $this->write_log(1,"创建日志目录{$logdir}失败");
            }
        }
        if (!function_exists('pcntl_fork')) {
            $this->write_log(1,'未安装pcntl扩展');
            exit;
        }
    }
    
    private function write_log($type,$msg){
        $logdir = $this->logdir;
        $errlog = $this->errlog;
        $successlog = $this->successlog;
        $prelog = date('Y-m-d H:i:s').":";
        if($type == 1){
            $logname = $logdir.$errlog;
        }else{
            $logname = $logdir.$successlog;
        }
        file_put_contents($logname,$prelog.$msg.PHP_EOL,FILE_APPEND);
    }
    
    public function run($name){
        $num = $this->num;
        $timeout = $this->timeout;
        $pipedir = $this->pipedir;
        $pipefile = $pipedir.posix_getpid();
        if (!posix_mkfifo($pipefile, 0666)) {
            $this->write_log(1,"创建管道文件{$pipefile}失败");
            exit;
        }
        #  处理任务
        for ($i = 0; $i < $num; ++$i ) {
            $cpid = pcntl_fork();  #  创建子进程
            if ($cpid == 0) {
                #  子进程过程
                call_user_func($name,$i);
                $pw = fopen($pipefile, 'w');
                fwrite($pw, $i."\n");  #  当前任务处理完比,在管道中写入数据
                fclose($pw);
                exit(0);  #  执行完后退出
            }
        }
        #  父进程
        $pr = fopen($pipefile, 'r');
        stream_set_blocking($pr, FALSE);  #  将管道设置为非堵塞,用于适应超时机制
        $pdata = '';  #  存放管道中的数据
        $sline = 0;  #  成功执行的进程数量
        $stime = time();
        while ($sline < $num && (time() - $stime) < $timeout) {
            $tline = fread($pr, 1024);
            if (empty($tline)) {
                continue;   
            }
            #  用于分析多少任务处理完毕,通过'\n'标识
            foreach(str_split($tline) as $v) {
                if ("\n" == $v) {
                    ++$sline;
                }
            }
            $pdata .= $tline;
        }
        $this->write_log(2,"总共{$sline}个任务执行成功");
        fclose($pr);
        unlink($pipefile);  #  删除管道,已经没有作用了
        #  等待子进程执行完毕,避免僵尸进程
        $n = 0;
        while ($n < $num) {
            $status = -1;
            $cpid = pcntl_wait($status, WNOHANG);
            if ($cpid > 0) {
                $this->write_log(2,"进程{$cpid}执行结束");
                ++$n;
            }
        }
        #  验证结果,主要查看结果中是否每个任务都完成了
        $arr = array();
        foreach(explode("\n", $pdata) as $i) {
            if (is_numeric(trim($i))) {
                array_push($arr, $i);  
            }
        }
        $arr = array_unique($arr);
        if ( count($arr) == $num) {  
            $this->write_log(2,var_export($arr,true));
        } else {
            $this->write_log(1,"执行成功数量:".count($arr));
            $this->write_log(1,"执行成功的线程:".var_export($arr,true));
        }
    }
    }
  2. 测试:

    $process = new process();
    $process->num = 5;  #  修改进程数为5
    $process->run('todo');
    
    function todo($pid){
    $num = 19;  #  总任务数
    $anum = ceil($num/5);  #  平均每个进程处理任务数
    $lnum = $num - $anum*(5-1);  #  最后一个进程处理任务数
    $minnum = $anum*$pid;  #  当前进程处理的最小值
    $maxnum;  #  当前进程处理的最大值
    if($pid<(5-1)){
        $maxnum = $minnum + $anum;
    }else{
        $maxnum = $num;
    }
    for($i=$minnum;$i<$maxnum;$i++){
        echo "进程号:{$pid};输出:{$i}".PHP_EOL;
    }
    }
  3. 输出:

    进程号:1;输出:4
    进程号:1;输出:5
    进程号:1;输出:6
    进程号:1;输出:7
    进程号:2;输出:8
    进程号:2;输出:9
    进程号:2;输出:10
    进程号:2;输出:11
    进程号:3;输出:12
    进程号:3;输出:13
    进程号:3;输出:14
    进程号:3;输出:15
    进程号:4;输出:16
    进程号:4;输出:17
    进程号:4;输出:18
    进程号:0;输出:0
    进程号:0;输出:1
    进程号:0;输出:2
    进程号:0;输出:3

感谢各位的阅读!关于“php如何使用多进程”这篇文章就分享到这里了,希望以上内容可以对大家有一定的帮助,让大家可以学到更多知识,如果觉得文章不错,可以把它分享出去让更多的人看到吧!

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

php如何使用多进程

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

如何解析PHP多进程编程

这篇文章主要介绍了如何解析PHP多进程编程,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。PHP多进程编程使用多进程的优点: 1. 使用多进程, 子进程结束以后, 内核会
2023-06-14

php如何启动多个进程

要启动多个进程,可以使用PHP的多进程库如pcntl或posix。使用pcntl库启动多个进程的一种方法如下:1. 创建一个主进程,负责创建和管理其他子进程。2. 使用`pcntl_fork()`函数在主进程中创建子进程。可以使用循环来创建
2023-08-25

Python使用multiprocessing如何实现多进程

本文探讨了使用Pythonmultiprocessing模块实现多进程的方法,提供了一个示例来说明如何创建并启动进程。它还介绍了进程间通信机制,例如队列、管道和共享内存。多进程的优点包括并发性、隔离和可扩展性,但缺点包括开销、复杂性和调试困难。文中还提供了最佳实践,例如限制进程数量、使用进程池、仔细考虑IPC和使用异常处理。
Python使用multiprocessing如何实现多进程
2024-04-02

Linux如何使用gdb调试多进程

这篇文章主要介绍了Linux如何使用gdb调试多进程的相关知识,内容详细易懂,操作简单快捷,具有一定借鉴价值,相信大家阅读完这篇Linux如何使用gdb调试多进程文章都会有所收获,下面我们一起来看看吧。一.gdb常用目录表操作描述l命令相当
2023-06-28

如何使用 PHP 进行异步编程?

php中的异步编程使用事件循环和回调,以实现并发任务执行。它可以通过libev扩展来实现,该扩展提供了一个事件循环,用于监听事件并执行相应的回调。异步网络编程示例展示了使用libev进行异步网络连接的服务器创建,而定时器编程示例则展示了创建
如何使用 PHP 进行异步编程?
2024-04-19

如何使用 C++ 函数实现多进程编程?

c++++ 中的多进程编程涉及使用 头文件创建和管理并行运行的进程。创建进程需要使用 std::thread 构造函数,并向其传递一个要运行的函数。参数可以通过构造函数作为附加参数传递。一个实战案例演示了使用多进程计算大数字的分解。使用
如何使用 C++ 函数实现多进程编程?
2024-04-26

php如何实现多进程和关闭进程的方法

本篇内容介绍了“php如何实现多进程和关闭进程的方法”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!php实现关闭进程的方法:首先创建一个PH
2023-06-07

PHP Git 实战:如何使用 Git 进行多人开发?

PHP Git 实战:多人协作开发的必备工具简介Git 是一款分布式版本控制系统,它允许开发人员协同工作,跟踪代码更改并轻松管理不同的项目版本。对于进行多人开发的 PHP 项目来说,Git 至关重要。本文将指导您逐步使用 Git 来管理您
PHP Git 实战:如何使用 Git 进行多人开发?
2024-05-13

php如何解决进程太多的问题

小编给大家分享一下php如何解决进程太多的问题,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!php进程太多的解决办法:1、通过“ps -ef | wc -l”命
2023-06-25

php进程多导致cpu高如何解决

要解决PHP进程多导致CPU高的问题,可以采取以下几种方法:1. 优化代码:检查代码中是否存在死循环、重复执行的问题,尽量避免无意义的重复计算或查询,优化数据库操作等。2. 使用缓存技术:可以使用缓存技术来减轻对数据库或其他资源的访问压力,
2023-09-26

如何使用Shell构建多进程的CommandlineFu爬虫

小编给大家分享一下如何使用Shell构建多进程的CommandlineFu爬虫,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!CommandlineFu 是一个记录
2023-06-16

编程热搜

  • Python 学习之路 - Python
    一、安装Python34Windows在Python官网(https://www.python.org/downloads/)下载安装包并安装。Python的默认安装路径是:C:\Python34配置环境变量:【右键计算机】--》【属性】-
    Python 学习之路 - Python
  • chatgpt的中文全称是什么
    chatgpt的中文全称是生成型预训练变换模型。ChatGPT是什么ChatGPT是美国人工智能研究实验室OpenAI开发的一种全新聊天机器人模型,它能够通过学习和理解人类的语言来进行对话,还能根据聊天的上下文进行互动,并协助人类完成一系列
    chatgpt的中文全称是什么
  • C/C++中extern函数使用详解
  • C/C++可变参数的使用
    可变参数的使用方法远远不止以下几种,不过在C,C++中使用可变参数时要小心,在使用printf()等函数时传入的参数个数一定不能比前面的格式化字符串中的’%’符号个数少,否则会产生访问越界,运气不好的话还会导致程序崩溃
    C/C++可变参数的使用
  • css样式文件该放在哪里
  • php中数组下标必须是连续的吗
  • Python 3 教程
    Python 3 教程 Python 的 3.0 版本,常被称为 Python 3000,或简称 Py3k。相对于 Python 的早期版本,这是一个较大的升级。为了不带入过多的累赘,Python 3.0 在设计的时候没有考虑向下兼容。 Python
    Python 3 教程
  • Python pip包管理
    一、前言    在Python中, 安装第三方模块是通过 setuptools 这个工具完成的。 Python有两个封装了 setuptools的包管理工具: easy_install  和  pip , 目前官方推荐使用 pip。    
    Python pip包管理
  • ubuntu如何重新编译内核
  • 改善Java代码之慎用java动态编译

目录