> 백엔드 개발 > PHP 튜토리얼 > PHP缓存使用的一个陷阱_PHP教程

PHP缓存使用的一个陷阱_PHP教程

WBOY
풀어 주다: 2016-07-13 17:53:02
원래의
843명이 탐색했습니다.

先看一段代码:
[php]
/**
 * 获取设置信息
 */ 
public function getCoinSetting() { 
    $cache  = Common::getTair(); 
    $ckey   = Common::hashKey("Hello"); 
    $ret    = $cache->get($ckey); 
    if ($ret) return json_decode($ret, true); 
    $taomanyiApiService = $this->_getTmiApiService(); 
    $result = $taomanyiApiService->getCoinSetting(); 
    $cache->set($ckey, json_encode($result), 3600); 
    return $result; 

这是一个使用Tair内存缓存的实例,这段代码中,设置了缓存,缓存时间为3600秒。数据是从Api中获取的,如果这么写会出现什么问题呢?假如:
[php] 
$result = $taomanyiApiService->getCoinSetting(); 

$result获取的数据为空,因为$result数据是从HTTP请求过来的,数据不正常也是比较常见的事情。在这种状况下,HTTP请求失败,那么接口数据就请求不到,接下来的流程是设置缓存
[php ]
$cache->set($ckey, json_encode($result), 3600); 

我们会发现,因为一次接口HTTP请求的失败,我们不小心将空数据缓存了起来,缓存时间为3600秒。这样就会出现页面上,例如分类出现了数据的空白,影响了整个业务流程
我们做以下的优化:
[php] 
if ($result) $cache->set($ckey, json_encode($result), 3600);  


作者:initphp

www.bkjia.comtruehttp://www.bkjia.com/PHPjc/478077.htmlTechArticle先看一段代码: [php] /** * 获取设置信息 */ public function getCoinSetting() { $cache = Common::getTair(); $ckey = Common::hashKey(Hello); $ret = $cache-get($ckey); if...
원천:php.cn
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿