redis学习篇(一)通过redis进行缓存优化
1. 概念: redis是一款高性能的NOSQL系列的非关系型数据库
-
1.1.什么是NOSQL
NoSQL(NoSQL = Not Only SQL),意即“不仅仅是SQL”,是一项全新的数据库理念,泛指非关系型的数据库。
随着互联网web2.0网站的兴起,传统的关系数据库在应付web2.0网站,特别是超大规模和高并发的SNS类型的web2.0纯动态网站已经显得力不从心,暴露了很多难以克服的问题,而非关系型的数据库则由于其本身的特点得到了非常迅速的发展。NoSQL数据库的产生就是为了解决大规模数据集合多重数据种类带来的挑战,尤其是大数据应用难题。-
1.1.1. NOSQL和关系型数据库比较
优点:
1)成本:nosql数据库简单易部署,基本都是开源软件,不需要像使用oracle那样花费大量成本购买使用,相比关系型数据库价格便宜。
2)查询速度:nosql数据库将数据存储于缓存之中,关系型数据库将数据存储在硬盘中,自然查询速度远不及nosql数据库。
3)存储数据的格式:nosql的存储格式是key,value形式、文档形式、图片形式等等,所以可以存储基础类型以及对象或者是集合等各种格式,而数据库则只支持基础类型。
4)扩展性:关系型数据库有类似join这样的多表查询机制的限制导致扩展很艰难。缺点:
1)维护的工具和资料有限,因为nosql是属于新的技术,不能和关系型数据库10几年的技术同日而语。
2)不提供对sql的支持,如果不支持sql这样的工业标准,将产生一定用户的学习和使用成本。
3)不提供关系型数据库对事务的处理。 -
1.1.2. 非关系型数据库的优势:
1)性能NOSQL是基于键值对的,可以想象成表中的主键和值的对应关系,而且不需要经过SQL层的解析,所以性能非常高。
2)可扩展性同样也是因为基于键值对,数据之间没有耦合性,所以非常容易水平扩展。 -
1.1.3. 关系型数据库的优势:
1)复杂查询可以用SQL语句方便的在一个表以及多个表之间做非常复杂的数据查询。
2)事务支持使得对于安全性能很高的数据访问要求得以实现。对于这两类数据库,对方的优势就是自己的弱势,反之亦然。 -
1.1.4. 总结
关系型数据库与NoSQL数据库并非对立而是互补的关系,即通常情况下使用关系型数据库,在适合使用NoSQL的时候使用NoSQL数据库,
让NoSQL数据库对关系型数据库的不足进行弥补。
一般会将数据存储在关系型数据库中,在nosql数据库中备份存储关系型数据库的数据
-
2 为什么通过redis进行缓存优化?
- 因为如果在大数据高并发的情况下,对关系型数据库进行查询。需要多次进行IO操作,耗时长,影响用户体验。
- 而nosql这类非关系数据库很好的解决了耗时问题,它的数据保存在内存中,进行数据处理的事件大大降低
3. redis优化的小案例
1.前端发送ajax请求到servlet
<%@ page contentType="text/html;charset=UTF-8" language="java" %>
<html>
<head>
<title>$Title$</title>
<script src="${pageContext.request.contextPath}/js/jquery-1.8.3.js"></script>
<script>
$(function () {
//发送ajax请求收到数据并进行解析
$.get("proviceservlet",{},function (data) {
//data为数组的字符串
var provice = $("#provice");
$(data).each(function () {
var option = "<option id="+this.id+">"+this.location+"</option>"
provice.append(option);
});
});
});
</script>
</head>
<body>
<select id="provice">
<option id="aaa">请选择省份</option>
</select>
</body>
</html>
2.serlvet调用业务层代码进行查询
@WebServlet("/proviceservlet")
public class proviceservlet extends HttpServlet {
private proviceservice service = new proviceservice();
protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
response.setContentType("Application/json;charset=utf-8");
String provice = service.findprovice();
System.out.println("provice = " + provice);
response.getWriter().write(provice);
}
}
3.业务层逻辑:
如果redis中有需要的数据,直接从redis中取出
否则查询数据库,存入redis中
public class proviceservice {
private provicedao dao = new provicedao();
//先到redis中进行查找是否已经保存
//如果没有保存,就到数据库中查询,保存到redis中
public String findprovice() {
Jedis jedis = JedisUtils.getJedis();
String provice = jedis.get("provice");
System.out.println("provice = " + provice);
if ((provice == null) || (provice.trim().length() == 0)) {
//redis中没有
ObjectMapper mapper = new ObjectMapper();
try {
System.out.println("redis中没有,在数据中查找");
List<dao.provice> findprovice = dao.findprovice();
String json = mapper.writeValueAsString(findprovice);
jedis.set("provice", json);
return json;
} catch (JsonProcessingException e) {
e.printStackTrace();
}
}
System.out.println("redis中有,直接在redis中查找");
return jedis.get("provice");
}
}
4.dao层查询数据库
public class provicedao {
public List<provice> findprovice() {
JdbcTemplate template = new JdbcTemplate(DButils.getDataSource());
String sql = "select * from provice";
List<provice> proviceList = template.query(sql,new BeanPropertyRowMapper<provice>(provice.class));
return proviceList;
}
}