我们有一个需要在缓存中更新每日数据的应用程序。因此,如果我们清除数据,有没有任何简单的方法可以在不访问所有页面和组合的情况下重建缓存。有什么方法可以使之自动化吗?

最佳答案

我用django模型为“sql lite”中的临时缓存数据创建了一个decorator类:
这种方法对你有帮助吗?
装饰工:

class MWT(object):
    """Memoize With Timeout CACHE as a decorator"""
    _caches = {}
    _timeouts = {}

    def __init__(self, timeout=2):
        self.timeout = timeout

    def collect(self):
        """Clear cache of results which have timed out"""
        for func in self._caches:
            cache = {}
            for key in self._caches[func]:
                if (time.time() - self._caches[func][key][1]) < self._timeouts[func]:
                    cache[key] = self._caches[func][key]
            self._caches[func] = cache

    def __call__(self, f):
        self.cache = self._caches[f] = {}
        self._timeouts[f] = self.timeout

        def func(*args, **kwargs):
            kw = kwargs.items()
            kw.sort()
            key = (args, tuple(kw))
            try:
                v = self.cache[key]
                if (time.time() - v[1]) > self.timeout:
                    raise KeyError
            except KeyError:
                v = self.cache[key] = f(*args, **kwargs), time.time()
            return v[0]

        func.func_name = f.func_name

        return func

我的模型:
class MySimpleModel(models.Model):
    name = models.CharField(max_length=100)

    def __unicode__(self):
        return "{} - {}".format(self.name, self.id)

    def __set__(self):
        return self.name

然后我使用这个方法(defined decorator)来读取django模型:
class SQLData(object):
    def __init__(self, name):
        self._name = name

    def name(self):
        return self._name


@MWT(timeout=10)  # You can set any value to timeout (time of clearing cache).
def sql_reader():
    return list(MySimpleModel.objects.all())  # Using list method as faster to read sql.

class GetData(object):
    def __init__(self):
        pass

    @classmethod
    def get_data(cls):
        result = []

        for data in sql_reader():
            data = SQLData(data.name)
            result.append(data)

        return result

10-07 12:24
查看更多