shell脚本作为保证PHP脚本不挂掉的守护进程实例分享


Posted in PHP onJuly 15, 2013

前几天开始跑一份数据名单,名单需要提供用户名、是否有手机号、是否有邮箱,用户名单我轻易的获取到了,但是,用户名单有2000w之多,并且去检测用户是否有手机号、是否有邮箱必须得通过一个对外开放的安全接口一个一个用户去请求,然后分析返回值才能知道。

下面是我处理的方案:
1、将2000w名单保存到临时数据表
2、用PHP程序每次从该表获取500个用户,检测完后生成SQL update原纪录
3、为了防止PHP程序突然断掉,用shell脚本每隔1分钟检测,PHP挂掉了则重启
我使用shell脚本作为守护进程的原因是,手机与邮箱的检测接口速度慢,不可能在1~2天将2000w用户检测完。

方案详细:
1、临时保存用户名单表users,表结构如下:

CREATE TABLE `users` ( 
  `account` varchar(50) COMMENT '用户名', 
  `has_phone` tinyint(3) unsigned NOT NULL default '0' COMMENT '是否有手机号', 
  `has_email` tinyint(3) unsigned NOT NULL default '0' COMMENT '是否有邮箱', 
  `flag` tinyint(3) unsigned  NOT NULL default '0' COMMENT '标志位', 
  PRIMARY KEY  (`account`), 
  KEY `flag` (`flag`) 
 ) ENGINE=InnoDB  DEFAULT CHARSET=utf8 COMMENT='名单表';

我先将2000多w用户名导入到这个临时表,has_phone与has_email这二个字段默认都是0(没有),标志位flag说明该用户是否已经检测完。
下面是一部分表数据:
9873aaa,0,0,0
adddwwwd876222,0,0,0
testalexlee,0,0,0
codejia.net,0,0,0
haohdouywaa21,0,0,0
 
2、PHP脚本check_users.php
将 用户名单导入到表之后,再写一个简单的PHP脚本,思路是这样的:每次循环从表取flag=0的500个用户,然后请求接口判断用户是否有手机号、邮箱, 生成一条SQL,保存到一个SQLS数组里,等500个用户全部检测完了之后,循环SQLS数组,更新表里这500个名单,并将flag标志位设置为1, 表示已经检测完,下次就不获取了。
由于PHP脚本代码较长,这里分享下简单的代码说明:
<?php 
class Users{ 
    private $data; 
    private $sqls; 
    private $nums;         //判断是否有500用户 
    private $total_nums;   //当前已经检测完的用户数量     //每次取500个用户 
    private function getUsers(){...} 
    //检测这500个用户并生成SQL 
    private function checkUserInfo(){...} 
    //更新这500个用户 
    private function updateUserInfo(){...} 
    //运行 
    public function run(){ 
        $flag = true; 
        while($flag){ 
             if($this->nums != 500){ $flag = false; } 
             if($this->total_nums == 10000){  
                exit(0); //跑完1w个用户就退出,由守护进程启动 
             } 
             $this->getUsers(); 
             $this->checkUserInfo(); 
             $this->updateUserInfo(); 
             sleep(1); //跑完500用户休息1秒,保护用户检测接口      
         } 
    } 
} 
$user = new Users(); 
$user->run(); 
?>

上面是简洁版的PHP脚本,大概意思到了,刚开始的版本是没有$total_nums这个变量,是因为刚开始跑这个脚本的时候,发现只跑完了4w多条脚本就挂球了,后来一看,是因为连接数据库没连上,脚本一直挂在那里。加上这个变量也无法解决这个问题,只是在每次跑完1w个用户之后,PHP脚本退出,再由下面的shell脚本重新启动。

3、shell脚本作为守护进程
我把这个shell脚本加到了crontab里边,每隔1分钟执行一次,这个shell脚本很简单,检测check_users.php是否存在进程id,如果存在,则说明PHP脚本还在运行,shell脚本不做任何操作;如果不存在,则说明PHP脚本已经exit(0)跑完了1w用户退出了,那么shell脚本启动该脚本,进入下一个1w用户名单的检测。
上面我有讲到,如果PHP脚本在连接数据库的时候,无法连接上的时候,PHP会一直挂球在那里,无法退出了。我在shell脚本里加了一个时间检测,当PHP脚本进程存在的时候,计算已经存在了多长时间,如果超过了我预想的时间,则将PHP脚本kill掉,再重启。

开头的举例数据,结果类似如下:
testalexlee,1,0,1
codejia.net,0,0,1
haohdouywaa21,1,1,1
9873aaa,0,1,1
adddwwwd876222,1,0,1

说在最后:以上用户名单数据只是举个栗子,不要太认真,2000w数据,我估计要跑一段时间了,因为检测接口比较慢,接口在接到请求后还要连表,查表,再返回。其实,最好的方法还是直接从接口请求的表拉一份名单出来,再用shell命令处理下很快就有结果了,可是在公司就是这样,有些东西不开放的,你懂的~~~

PHP 相关文章推荐
php 动态多文件上传
Jan 18 PHP
PHP高自定义性安全验证码代码
Nov 27 PHP
深入php self与$this的详解
Jun 08 PHP
php Calender(日历)代码分享
Jan 03 PHP
PHP错误Warning: Cannot modify header information - headers already sent by解决方法
Sep 27 PHP
php防止站外远程提交表单的方法
Oct 20 PHP
php简单图像创建入门实例
Jun 10 PHP
php输出含有“#”字符串的方法
Jan 18 PHP
php实现和c#一致的DES加密解密实例
Jul 24 PHP
PHP实现防盗链的方法分析
Jul 25 PHP
PHP使用PhpSpreadsheet操作Excel实例详解
Mar 26 PHP
PHP引擎php.ini参数优化深入讲解
Mar 24 PHP
PHP 伪静态技术原理以及突破原理实现介绍
Jul 12 #PHP
php的$_FILES的临时储存文件与回收机制实测过程
Jul 12 #PHP
php图像处理函数大全(推荐收藏)
Jul 11 #PHP
PHP 获取远程文件大小的3种解决方法
Jul 11 #PHP
深入Nginx + PHP 缓存详解
Jul 11 #PHP
基于PHP中的常用函数回顾
Jul 11 #PHP
PHP 获取文件权限函数介绍
Jul 11 #PHP
You might like
使用 php4 加速 web 传输
2006/10/09 PHP
PHP新手上路(三)
2006/10/09 PHP
简单的php+mysql聊天室实现方法(附源码)
2016/01/05 PHP
php5.6.x到php7.0.x特性小结
2019/08/17 PHP
Code:findPosX 和 findPosY
2006/12/20 Javascript
Js 冒泡事件阻止实现代码
2013/01/27 Javascript
javascript对中文按照拼音排序代码
2014/08/20 Javascript
javascript自定义右键弹出菜单实现方法
2015/05/25 Javascript
基于JQuery的$.ajax方法进行异步请求导致页面闪烁的解决办法
2016/05/10 Javascript
js实现表格筛选功能
2017/01/18 Javascript
原生js实现日期计算器功能
2017/02/17 Javascript
jQuery插件zTree实现的基本树与节点获取操作示例
2017/03/08 Javascript
详解webpack 如何集成第三方js库
2017/06/29 Javascript
详解vue-cli脚手架build目录中的dev-server.js配置文件
2017/11/24 Javascript
微信小程序页面生命周期详解
2018/01/31 Javascript
在Vue中用canvas实现二维码和图片合成海报的方法
2019/06/10 Javascript
微信小程序实现导航栏和内容上下联动功能代码
2020/06/29 Javascript
微信小程序实现点击页面出现文字
2020/09/21 Javascript
基于vue实现微博三方登录流程解析
2020/11/04 Javascript
JavaScript使用setTimeout实现倒计时效果
2021/02/19 Javascript
基于python实现在excel中读取与生成随机数写入excel中
2018/01/04 Python
一文秒懂python读写csv xml json文件各种骚操作
2019/07/04 Python
python3访问字典里的值实例方法
2020/11/18 Python
浅谈CSS3动画的回调处理
2016/07/21 HTML / CSS
EVE LOM英国官网:全世界最好的洁面膏
2017/10/30 全球购物
威尔逊皮革:Wilsons Leather
2018/12/07 全球购物
护理专业毕业生自荐信范文
2014/01/05 职场文书
挂职自我鉴定
2014/02/26 职场文书
2014年幼儿园国庆主题活动方案
2014/09/16 职场文书
三严三实民主生活会发言稿
2014/10/13 职场文书
初婚初育证明范本
2015/06/18 职场文书
大学生村官入党自传
2015/06/26 职场文书
2016年秋季开学典礼新闻稿
2015/11/25 职场文书
三八红旗手先进事迹材料(2016推荐版)
2016/02/25 职场文书
个人售房合同协议书
2016/03/21 职场文书
新手必备Python开发环境搭建教程
2021/05/28 Python