欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  后端开发

memcached - php数组缓存和memcache缓存 一道面试题,帮忙理下思路

程序员文章站 2022-05-23 15:06:11
...
我们的缓存分为两级,第一级只是一个PHP数组,有效范围是Request。而第二级是memcached。这么做的原因是,很多数据在一个Request周期内需要加载多次,这样可以减少memcached的网络请求。另外我们的框架也会尽可能的发送memcached的gets命令来获取数据,从而减少网络请求”, 请使用伪代码实现以上缓存架构

这道题的思路是怎样的,题目也没看懂,麻烦帮忙理下思路.

回复内容:

我们的缓存分为两级,第一级只是一个PHP数组,有效范围是Request。而第二级是memcached。这么做的原因是,很多数据在一个Request周期内需要加载多次,这样可以减少memcached的网络请求。另外我们的框架也会尽可能的发送memcached的gets命令来获取数据,从而减少网络请求”, 请使用伪代码实现以上缓存架构

这道题的思路是怎样的,题目也没看懂,麻烦帮忙理下思路.

// example:
// get_cache('foo');
// get_cache(['foo', 'bar']);
function get_cache($keys) {
    static $cache = [];
    static $memcached;

    $keys = (array)$keys;

    $result = $missing = [];
    foreach ($keys as $key) {
        if (isset($cache[$key])) {
            $result[$key] = $cache[$key];
        } else {
            $missing[] = $key;
        }
    }

    if (!$missing) {
        return $result;
    }

    if (!$memcached) {
        $memcached = new Memcached;
    }

    $mresult = $memcached->getMulti($missing);
    if ($mresult) {
        foreach ($mresult as $key => $value) {
            $result[$key] = $cache[$key] = $value;
        }
    }

    return $result;
}

我表示也没有看懂!

就是说要你写一个PHP缓存的类,通过这个类来统一的访问memcached。
然后这个类需要支持一次返回多个数据。
同时,需要对从memcached拿到的数据存一下数组。方便在本次request里面重复获取缓存的时候直接使用。

稍微难点就在那个对多个数据的查询和缓存上面。

简单的理解是, 已经获取到了,先缓存到memcache里面,如果在一定周期内,需要用到相同的数据,先从memcache里面读取, 这个操作时间比较简短

美图的笔试题。