统计平台-脚本系列1

2018-01-24  本文已影响0人  柳风儿

发货统计(多进程,前后30天每天的日期)

最近正在做的统计平台是关于整个中型电商网站的各项数据统计与展示,目前用到的技术是ELK,以后会慢慢把整个平台架构都写进来,今天先写一个模块-发货统计。

$statistical_dates = array();
for($i=1;$i<15;$i++){
    $statistical_dates[$i] = date("Y-m-d",strtotime('-'.$i.'day'));
    //此处调用真正跑的脚本。。
}
//因为需要计算当天之前15天的每一天的日期,所以用了strtotime,突然想起来,客服预约的日期展示,从今天开始30天内可以预约的日期,也可以用相同的函数处理:
$week_array=array("日","一","二","三","四","五","六");
$days=array();
for($i=0;$i<30;$i++){
    $days[$i]['time']=date("m-d",strtotime('+'.$i.'day'));
    if ($i==0) {
        $days[$i]['week']= '今';
    }else{
        $days[$i]['week']= $week_array[date("w",strtotime('+'.$i.'day'))];
    }
    $num = 1; //此处获取一下当天可以预约的数量。。
    if (empty($num)) {
        $num = 2;
    }
    $days[$i]['num']=$num;
}

也可以采用PHP多进程来处理,同时跑很多天的数据,可以节省很多时间:
以下是官方文档的代码:

<?php

$pid = pcntl_fork();
//父进程和子进程都会执行下面代码
if ($pid == -1) {
    //错误处理:创建子进程失败时返回-1.
     die('could not fork');
} else if ($pid) {
     //父进程会得到子进程号,所以这里是父进程执行的逻辑
     pcntl_wait($status); //等待子进程中断,防止子进程成为僵尸进程。
} else {
     //子进程得到的$pid为0, 所以这里是子进程执行的逻辑。
}

?>

拿来加在代码里以后发现还是启动了一个脚本,并没有同时启动很多个脚本,后来才发现

else if那段父进程里,暂时不要wait,把父进程放到一个数组里,到循环完成以后,再释放,就可以同时启动多个脚本来恢复一段时间内每一天的数据了

<?php
$pids = array();
//循环要循环的数据
foreach ($codes_info as $code_info) {
    $pid = pcntl_fork();
    //父进程和子进程都会执行下面代码
    if($pid == -1) {
        //错误处理:创建子进程失败时返回-1.
        die('error','could not fork');
    }elseif($pid) {
        //父进程会得到子进程号,所以这里是父进程执行的逻辑 父进程挂起
        $pids[] = $pid;
    }else{
        pcntl_exec('/usr/bin/php',array('cron.php','方法','参数';//这里调用要执行的每一天的脚本
    }
}
foreach ($pids as $npid) {
    if($npid) {
        pcntl_waitpid($npid, $status);
    }
}
?>
上一篇 下一篇

猜你喜欢

热点阅读