优化代码的时候,需要增加这么一个逻辑,先从MC中取,取不到从Redis中取。通过Cron来更新MC和Redis中的内容。
简单看了下代码库中有封装好的方法,大致逻辑如下。
public static function set($key, $param, $value, $is_long = true) { $mc = Comm_Mc::init(); $mc->setData($key, $param, $value); $redis = Comm_Redis::init($is_long, true); $redis_key = self::$prefix . $key . '_' . implode('_', $param); $redis->set($redis_key, $value); }
方法没有注释,也没细看之前的调用。突然很多疑问冒出,难道Array能直接存储到MC和Redis中?以往的经验使用MC都是先json_encode()在set。
测试了下MC中直接set array是可以的,get可以正常取出来;Redis中有异常,写入正常,获取异常为’Array’字符串。
分析总结如下:
0、Memcache::set方法value可以不是字符串,非字符串会被serialized
Memcache::set ( string $key , mixed $var [, int $flag [, int $expire ]] ) : bool
1、Redis set value只能是字符串
$redis->set('key', 'value');
2、使用MC和Redis作为Cache最好优先调用json_encode(), 然后写入。MC虽然会自动序列号,但是json_encode()比serialize()更方便更快。
3、必须使用serialize的情况
a、Array存储深度嵌套超过127, json_decode()的时候返回false.
b、反序列号后希望是一个class.
c、PHP低版本不支持json_encode().
4、后来看了以下代码中的使用,都是调方法直接json_encode()的。
5、方法注释很重要。
参考:
Can you store a PHP Array in Memcache?Preferred method to store PHP arrays (json_encode vs serialize)
Storing an array of data using Redis (from Laravel)