最近公司老大抱怨,产品某部分内容访问速度奇慢无比,由于是之前接手的别人的代码,不太清楚业务的具体逻辑,不过,经过查看,内容为无需实时更新的内容,so 直接上缓存。
什么是缓存?
对于后端来说,要做的基本就是接收请求,返回数据,而在返回数据的过程中,我们要对数据库进行查询操作,找到正确的 请求内容,如果要查找的数据量比较大,每次请求的耗时将会是一个非常可怕的事情。这个时候,我们就需要对某些无需实 时更新的内容进行缓存处理,把要返回的内容存放在缓存中,收到数据请求后直接把缓存中的数据返回,如果缓存不存在, 则查询数据库,并且把内容添加进缓存中,以便下次请求。
缓存中应该放置什么内容?
缓存的存在,虽然给我们的访问速度带来了提升,但缓存并不是适用于任何场合,个人理解,对于一些无需实时更新,并且 数据量较大或者查询速度教慢的,可以使用缓存操作。
Django的缓存机制。
在django中,存在多种缓存机制,例如:利用本地内存进行缓存,利用文件系统进行缓存、利用数据库进行缓存等缓存芳 式。
利用数据库进行缓存。
由于Redis这种Key/value的存储方式,使得它很适合做缓存数据库,而django也对Redis有着非常好的支持,所以这里我选 择了使用Redis。
首先,安装Redis数据库。操作非常简单,使用命令进行安装 #sudo apt-get install redis-server(win下可以选择下载相应的 安装包)。
然后,就是缓存的主角,django-redis (http://django-redis-chs.readthedocs.io/zh_CN/latest/#id2) 具体内容可在官方文档 查看。
Django的配置相关:
如果你是第一次使用Redis,并且是第一次使用django-redis 那么,上面的配置就是你要添加进setting里的内容。
配置完成后,我们就要对想要进行缓存的数据代码进行缓存处理了。
这是一个get请求函数,在请求里,我们首先定义一个key,这个也是我们存储在redis数据库中的key的名字(可以根据需要 随意设置)。然后就是获取key 使用cache.get 尝试获取key 如果key存在,则返回key里面的,无需重复查询数据库。
如果key不存在。
在key不存在的情况下,我们可以执行对数据库的查询操作,然后把查询的内容通过cache.set保存进redis。
参数为(之前声明的key的名字,数据,过期时间)
过期时间是一个比较重要的参数,它指定了你缓存进redis数据库中的数据的生存时间,可以视需求而定。
如果key存在。
直接返回value中的数据,结束。
运行程序后,我们可以通过redis-cil查看我们的数据是否缓存成功。
如果数据存在,则输入keys * 会出现你声明的key的名字。
此外,我们还可以通过ttl [key name] 来查看我们的缓存的生存时间等,具体可参考redis使用教程。
普通的redis缓存其实是一个相对来说简单的事情,通过一个简单的缓存,访问速度确实块了许多,可能对于缓存来说,可以做的还有更多,不过,更多的东西,要等以后变得更加强大了以后再去做了。