写在前面
在一些场景中,我们会频繁的去查询数据库中的信息在页面中展示,并且数据库中的这些信息又不会经常变更,那么我们就可以就可以在redis中存储一份这样的数据,毕竟redis是内存型数据库,它的查询效率比较高。但是我们又不能一直使用redis中的数据,因为数据库中的数据有可能会更新,如果不给redis中的数据做更新,那么我们的信息就没有时效性了。
所以,我们给redis设置一个有效期,过了有效期就销毁数据,然后程序在redis中查询不到数据就会从数据库中去查询,同时在redis中再爆粗一份相同的数据,下次再来查询的时候,就会又从redis中查询了,直到redis中的数据过期,如此循环下去。
api.route("/areas")
def get_area_info():
'''获取城区信息'''
# 先尝试从redis 中获取缓存数据
try:
areas_json = redis_store.get("area_info")
except Exception as e:
current_app.logger.error(e)
areas_json = None
if areas_json is None:
# 查询数据库 获取城区信息
try:
areas_list = Area.query.all()
except Exception as e:
current_app.logger.error(e)
return jsonify(erro=RET.DBERR, errmsg="查询城区信息异常")
# 遍历列表,处理每一个对象,转换一下对象的属性名
areas = []
for area in areas_list:
areas.append(area.to_dict())
# 将数据转换为json redis 只能存储字符串
areas_json = json.dumps(areas)
# 将数据在redis中保存一份
try:
redis_store.setex("area_info", constants.AREA_INFO_REDIS_EXPIRES, areas_json)
except Exception as e:
current_app.logger.error(e)
else:
# 在日志中记录,表示redis中有缓存,直接使用的是缓存数据
current_app.logger.info("hit redis cache area info")
# return jsonify(errno=RET.OK, errmsg="查询城区信息成功", data={"areas": areas})
# 在这里从redis中查询的数据已经是json格式的了,可以直接返回
return '{"errno":0,"errmsg":"查询城区信息成功","data":{"areas":%s}}' % areas_json, 200, \
{"Content-Type": "application/json"}