get($ckey"/> get($ckey">
> 백엔드 개발 > PHP 튜토리얼 > PHP缓存应用的一个陷阱

PHP缓存应用的一个陷阱

WBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWB
풀어 주다: 2016-06-13 10:35:15
원래의
883명이 탐색했습니다.

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中获取的,如果这么写会出现什么问题呢?假如:

$result = $taomanyiApiService->getCoinSetting();
로그인 후 복사


$result获取的数据为空,因为$result数据是从HTTP请求过来的,数据不正常也是比较常见的事情。在这种状况下,HTTP请求失败,那么接口数据就请求不到,接下来的流程是设置缓存

$cache->set($ckey, json_encode($result), 3600);
로그인 후 복사


我们会发现,因为一次接口HTTP请求的失败,我们不小心将空数据缓存了起来,缓存时间为3600秒。这样就会出现页面上,例如分类出现了数据的空白,影响了整个业务流程

我们做以下的优化:

if ($result) $cache->set($ckey, json_encode($result), 3600); 
로그인 후 복사


 

관련 라벨:
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿