redis和mysql的区别:
redis是属于nosql的数据库,而mysql是属于sql数据库,redis是属于nosql数据库。mysql是存储在磁盘中的,redis是存储在内存中的,所以redis的读取书读快。这里所说的redis代表nosql,而mysql代表sql。
redis的数据库是以键值对为基础存储在内存中的,而mysql为代表的关系型数据库是以表为基础存储在磁盘中的。下面这张图总结了两者之间的区别:
redis和java的互通:
1.Jedis客户端
1、 引入依赖
2、建立连接
3、使用
4、释放资源
缺点:jedis本身是线程不安全的,频繁的创建和销毁连接会有性能损耗。 —利用连接池代替jedis直连。
连接池设置
使用
连接池的释放,仍然与Jedis直连一样。函数内部,它会有判断是否是连接池,如果是就归还连接。
SpringDataRedis.
– 对letture和Jedis的整合。
–提供了redistemplate类统一api来操作redis
–支持基于jdk、json、字符串、spring对象的数据序列化及反序列化。
1.引入依赖
2.引入redis的配置信息,springboot的application.properties文件
3.注入RedisTemplate,拿到连接池中的redisTemplate
private StringRedisTemplate redisTemplate;
如果要用这个方法使用redis一定注意redis的序列化,不然就会导致redis数据库内部的存储不对,因为在java这边,默认会将所要存储对象专程object类存储—将java对象转成字节,传到redis中,可能导致存储在redis中会乱码。
方式一
序列化方式
上述这种方式为了在反序列化知道对象的类型,json序列化器会将类的class类型也存储在json结果中,带来额外的内存消耗。
第二种方式就是进行手动序列化和反序列化