日期:2014-05-17  浏览次数:20504 次

解决php snoopy远程获取数据的稳定性问题

?

使用php?snoopy在获取远程数据的时候,经常遇到远程站点不稳定或者是网络因素影响,造成读取数据失败或者返回时间过长的问题,本篇文章着重介绍一下大致的解决思路。

前段时间利用沈阳交通违章查询网的接口,做了一个简单的违章查询系统,并且在数据远程获取之前进行了缓存,开始设置的缓存时间为3天(因为沈阳交通违章查询网的数据每周更新一次)。这样运行了将尽3个月的时间,通过长时间的观察,发现交警队的数据源并不稳定,一周7天大约有2天网站是处于无法访问的状况,在缓存失效的情况下,经常会造成等待时间过长(大约30s),最后返回为空查询结果的问题。

?

这个问题非常影响用户体验,我也考虑了很长时间,解决思路如下:

1.对接口请求情况进行判断;

2.设置合理的超时时间。(根据远程站点响应速度,大约2-5s肯定会返回数据)

3.将最后一次成功查询结果写入数据表,接口失效的时候调用最后一次成功查询记录。

?

综合以上几点方法,基本可以解决这个问题。运行流程如下:

1.用户输入信息并提交查询请求

2.服务器端检测该查询资料是否缓存并有效,如果存在并有效则直接返回(最剩资源,不用去远程获取)

3.如果缓存不存在或者失效,则调用远程获取方法

4.远程获取方法使用php?snoopy进行获取远端数据,这里需要设置超时时间以及判断返回状态和是否超时。

$snoopy = new Snoopy;
$snoopy->read_timeout=4;  //读取超时时间

?

if ($snoopy->status>0&& $snoopy->status== '200' && !$snoopy->timed_out) {
    //这里是读取成功的处理逻辑
}else{
    //这里是远程接口出问题的时候的处理逻辑
}

?首先说明一下,$snoopy->status是远程返回的状态码,成功返回的应该是200,其他情况下返回的都应该是错误的,并且有效的请求状态应该是大于0的,$snoopy->timed_out在未超时的情况下值为false,如果读取请求超时的话,返回值应该为true。

5.如果接口请求不超时,直接进行最新的数据处理,并删除该资料有关的最后一次查询结果,并将最新的查询结果写入数据库。

/**
     * 写