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

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

相关推荐
zhangkaixuan45628 分钟前
Apache Paimon 写入流程
java·大数据·apache·paimon
Java爱好狂.41 分钟前
分布式ID|从源码角度深度解析美团Leaf双Buffer优化方案
java·数据库·分布式·分布式id·es·java面试·java程序员
Elastic 中国社区官方博客1 小时前
通过混合搜索重排序提升多语言嵌入模型的相关性
大数据·数据库·人工智能·elasticsearch·搜索引擎·ai·全文检索
胡桃夹夹子1 小时前
存档111111111
java·开发语言
不会编程的小寒1 小时前
C++ 中string的用法
java·开发语言
乐悠小码1 小时前
Java设计模式精讲---02抽象工厂模式
java·设计模式·抽象工厂模式
数据的世界011 小时前
技术变革:为何C#与.NET是未来的开发方向
java·c#·.net
向上的车轮1 小时前
Actix Web适合什么类型的Web应用?可以部署 Java 或 .NET 的应用程序?
java·前端·rust·.net
脸大是真的好~1 小时前
黑马JAVAWeb-03 SpringBootWeb-分层解耦-三层架构-@SpringBootApplication注解-IOC控制反转-DI依赖注入
java
倔强的石头1062 小时前
KingbaseES:从兼容到超越,详解超越MySQL的权限隔离与安全增强
数据库·mysql·安全·金仓数据库