了解了一下cache

时间:2023-02-03 09:54:47

由于我的服务器处理请求时需要从数据获取一些信息,而有些请求相当频繁,而数据或的访问时间相对来说是比较长的。因此我想对这些信息进行cache操作。

使用cache进行优化有instruction-cache和data-cache两种,对于I-Cache,我想基本上不了解,大概只有开发计算机硬件架构和研究操作系统内核的人才应该关心吧。我只想稍微了解一下D-Cache。

网上开源的Cache项目有memcache,squid等,大多是用于web server,而且主要问题估计和我一样对数据库的一些内容进行cache,或许还有网页页面吧。

下面是来自memcached的wiki网页的部分sample代码:

1)使用cache前的样子
function get_foo (int userid) {
result = db_select("SELECT * FROM users WHERE userid = ?", userid);
return result;
}
2)使用cache后的样子
function get_foo (int userid) {
result = memcached_fetch("userrow:" + userid);
if (!result) {
result = db_select("SELECT * FROM users WHERE userid = ?", userid);
memcached_add("userrow:" + userid, result);
}
return result;
}
需要注意的问题是在更新数据库的时候,Cache也需要更新,否则可能导致数据库和cache中的内容不一致,从来导致bug。

这两个都比较庞大,我用不着这么先进的武器。我想要一个轻量型的进程内的cache系统。
找到一个叫libcache的库:http://resnet.uoregon.edu/~gurney_j/jmpc/libcache.html