【Redis,Java】Redis的两种序列化方式—nosql数据库

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结果中,带来额外的内存消耗。

第二种方式就是进行手动序列化和反序列化

相关推荐
一眼万年0410 分钟前
Redis Cluster模式
redis·微服务
guojl15 分钟前
Java多任务编排技术
java
丶意冷23 分钟前
mybatisPlus分页方言设置错误问题 mybatisPlus对于Oceanbase的Oracle租户分页识别错误
java·数据库·oracle·oceanbase
要开心吖ZSH1 小时前
《Spring 中上下文传递的那些事儿》Part 4:分布式链路追踪 —— Sleuth + Zipkin 实践
java·分布式·spring
桦说编程1 小时前
深入解析CompletableFuture源码实现
java·性能优化·源码
蓝澈11212 小时前
迪杰斯特拉算法之解决单源最短路径问题
java·数据结构
deriva2 小时前
.netcore+ef+redis+rabbitmq+dotcap先同步后异步再同步的方法,亲测有效
redis·rabbitmq·.netcore
Kali_072 小时前
使用 Mathematical_Expression 从零开始实现数学题目的作答小游戏【可复制代码】
java·人工智能·免费
rzl022 小时前
java web5(黑马)
java·开发语言·前端
时序数据说2 小时前
为什么时序数据库IoTDB选择Java作为开发语言
java·大数据·开发语言·数据库·物联网·时序数据库·iotdb