一篇特殊的redis工具类 -- 独此一家

2024-03-16 20:30

本文主要是介绍一篇特殊的redis工具类 -- 独此一家,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

一篇特殊的redis工具类 -- 独此一家、绝无分店

 

一、引言

本篇博客以redis缓存为主。至于什么是redis缓存?还有没有其它的缓存?哪个缓存的性能会更好?这里就不一一做介绍了!(有兴趣的可以自己去百度一下)

在日常的开发中,我们或多或少(必须)的会用到缓存。为了提高系统性能、提升用户体验度,用户体验是多么的重要;这就要求在软件设计时,不但要注重可靠性、安全性、可扩展性以及可维护性等等的一些指标,更要注重用户的体验,用户体验分很多方面,但是有一点非常重要就是对用户操作的响应一定要快;怎样提高用户访问的响应速度,这就是摆在架构设计中必须要解决的问题;说到提高服务的响应速度就不得不说缓存了;

从系统的层面说,CPU的速度远远高于磁盘IO的速度;所以要想提高响应速度,必须减少磁盘IO的操作,但是有很多信息又是存在数据库当中的,每次查询数据库就是一次IO操作;请求响应时间等于网络响应时间和服务器响应时间;网络我们控制不了,服务器响应时间包括CPU计算时间和磁盘IO时间,其中CPU计算时间这个有硬件资源决定的,我们尽量减少算法的复杂度来减少它,磁盘IO时间,这个时间是非常慢的,应该尽量减少;

72617ee4f82b0c3d012786888e26945b4d0.jpg

当客户端调用某个接口获取信息的时候,执行顺序1、2、3、4;由于信息存放在DB中,所以2、3就有一次磁盘IO操作;这个看似非常简单业务逻辑,但是当你做架构设计的时候往往要考虑最坏的场景,或者当成千上万的用户频繁的调用这个接口应该怎么处理?如果按照上图这样的架构处理,这个看似简单业务的接口会使整个系统变慢,这样用户的请求就会长时间得不到响应;这样的问题怎么解决那,这时候就该缓存登场了;

342392472e7bbbc454a6c7653ae6f49fca4.jpg

缓存有很多种、也有很多种缓存策略。这里就不一一做探讨了,毕竟这篇博客是讲关于的工具类!总之一句话,要想提高系统的性能,尽量减少IO的操作,特别是磁盘IO的操作;使用缓存可以有效的避免这种情况;所以在架构设计过程中,涉及到查询数据库的时候,应该考虑一下是不是使用缓存技术来提高系统的性能,并且降低数据库的压力。

 

二、无知的痛(用get / set方式使用redis)

在根据某个需求设计业务的时候,比如说购物车:涉及到添加、查询、修改、删除。不说这四个具体实现时候的细节,这不就简单的对数据库增、删、改、查吗?但是,当成千上万的用户频繁访问的时候,简单的事情在高并发的情况下就会变的不简单!这个时候就需要有个东西来代替数据库,而且还要比数据库更快,来应对可能出现的高并发!所以我们想到了(redis)缓存,作为一个key / value 存在,很多开发者自然的使用set/get 方式来使用 redis  ,实际上这并不是最优化的使用方法。尤其在未启用VM 情况下,redis 全部数据需要放入内存,节约内存尤其重要。 假如一个key-value单元需要最小占用512字节,即使只存一个字节也占了512字节(比如set/get,一个key-value对应一条数据)。这时候就有一个设计模式,可以把key复用,几个key-value作为一个大的value,大的value再作为一个value,set存入一个key中。这样同样512字节就会存放10-100倍的容量。 这就是为了节约内存,建议使用hash类型而不是set/get的方式来使用redis。

 

三、hash类型方式使用redis -- 指定返回类型

在日常开发中,我们会把业务中的所有特性封装成一个对象,再把这个对象存入到redis缓存中。在使用redis的时候,通常会把redis常用的方法封装成一个工具类。然后我们调用工具类中的方法,把存入的对象传到方法中。通常方法会把对象转换成string存入缓存,需要的时候再把string取出来,然后再转换成对象!大多数的情况就是如此,但是在我实际的开发中传入的是个和业务有关的对象,返给我的却是一个object对象(和业务没有半毛钱关系)。我想要让返回的对象和业务有关,还得强转一下!这返回的是单个对象,如果是个list呢?循环强转吗?那如果是map呢?当然肯定都是能转的,但是这样就增加了实际业务中的代码量!在我看来 多一行与业务无关的代码都是罪恶的(纵然它是为了和业务产生关联),我想要的是 我给你存的是啥!返回的就是啥!别整那些没用的......

1.根据key和fieid返回hash中指定存储位置的值,指定返回类型

    /*** 返回hash中指定存储位置的值* @param key* @param fieid* @param obj* @param <T>* @return*/public<T> T hget(String key,String fieid,T obj) {Jedis jedis = null;try {logger.info("hget >> key+fieid:{}",key +"+"+ fieid);jedis = jedisPool.getResource();String hget = jedis.hget(key, fieid);ObjectMapper om = new ObjectMapper();T t =(T) om.readValue(hget, obj.getClass());return t;} catch (Exception e) {logger.error("Jedis hget 异常: " + e.getMessage());return null;} finally {closeRedis(jedis);}}

调用:

//调用hget方法
DemoDTO demoDTO = jedis.hget("key", "fieid", new DemoDTO());

 

2.hvals()方法,获取hash中value的集合,指定返回的集合类型

    /*** 获取hash中value的集合,指定返回的集合类型* @param key* @param obj* @param <T>* @return*/public<T> List<T> hvals(String key,T obj) {Jedis jedis = null;try {logger.info("hvals >> key:{}",key);jedis = jedisPool.getResource();List<String> hvals = jedis.hvals(key);Iterator<String> iterator = hvals.iterator();List<T> returnList = new ArrayList<>();ObjectMapper om = new ObjectMapper();while (iterator.hasNext()) {String next = iterator.next();T t =(T) om.readValue(next, obj.getClass());returnList.add(t);}return returnList;} catch (Exception e) {logger.error("Jedis hvals fail >> e:{}",e.getMessage());return null;} finally {closeRedis(jedis);}}

调用:

//调用hvals方法
List<DemoDTO> demoListDTOS = jedis.hvals("key", new DemoDTO());

 

3.以Map的形式返回hash中的存储和值,指定map中的value类型

    /***  以Map的形式返回hash中的存储和值* @param key* @param obj* @param <T>* @return*/public<T> Map<String,T> hgetAll(String key,T obj) {Jedis jedis = null;try {logger.info("hget >> key+obj:{}",key+"+"+obj);jedis = jedisPool.getResource();Map<String, String> map = jedis.hgetAll(key);Map<String, T> returnMap = new HashMap<>();ObjectMapper om = new ObjectMapper();for (Map.Entry<String, String> e : map.entrySet()) {T t =(T) om.readValue(e.getValue(), obj.getClass());returnMap.put(e.getKey(),t);}return returnMap;} catch (Exception e) {logger.error("Jedis hget fail >> e:{}" + e.getMessage());return null;} finally {closeRedis(jedis);}}

调用:

//调用hgetAll方法
Map<String,DemoDTO> stringDemoDTOMap = jedis.hgetAll("key", new DemoDTO());

 

4.关闭jedis连接,将jedis连接归还redis连接池

    /*** 关闭jedis连接池* @param jedis*/private void closeRedis(Jedis jedis) {if (jedis != null){try{jedis.close();}catch (Exception e){logger.error("Jedis关闭异常" + e.getMessage());}}}

closeRedis 释放资源 防止达到最大连接数出现异常 如 :maxTotal=300

如果每次获取完redis连接,不归还redis连接池的话,当超过redis的最大连接数。然后redis就雪崩了!注意注意!!!

 

四、结尾

其实指定redis返回类型,没什么高大上的!就是用了ObjectMapper类,这个类是Jackson库的主要类。但是,我百度查过网上很多关于redis的连接工具类,发现却没有一个做过这方面的处理!其实这个也不难,在写业务的时候随手就能写出来。我也就是在用redis的时候偶尔蹦出来了这个想法,每次都要 多那么两三行与业务无关的代码让人非常的抓狂!

 

End...

转载于:https://my.oschina.net/qcxdld/blog/1920413

这篇关于一篇特殊的redis工具类 -- 独此一家的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/816630

相关文章

高效录音转文字:2024年四大工具精选!

在快节奏的工作生活中,能够快速将录音转换成文字是一项非常实用的能力。特别是在需要记录会议纪要、讲座内容或者是采访素材的时候,一款优秀的在线录音转文字工具能派上大用场。以下推荐几个好用的录音转文字工具! 365在线转文字 直达链接:https://www.pdf365.cn/ 365在线转文字是一款提供在线录音转文字服务的工具,它以其高效、便捷的特点受到用户的青睐。用户无需下载安装任何软件,只

零基础学习Redis(10) -- zset类型命令使用

zset是有序集合,内部除了存储元素外,还会存储一个score,存储在zset中的元素会按照score的大小升序排列,不同元素的score可以重复,score相同的元素会按照元素的字典序排列。 1. zset常用命令 1.1 zadd  zadd key [NX | XX] [GT | LT]   [CH] [INCR] score member [score member ...]

【Linux 从基础到进阶】Ansible自动化运维工具使用

Ansible自动化运维工具使用 Ansible 是一款开源的自动化运维工具,采用无代理架构(agentless),基于 SSH 连接进行管理,具有简单易用、灵活强大、可扩展性高等特点。它广泛用于服务器管理、应用部署、配置管理等任务。本文将介绍 Ansible 的安装、基本使用方法及一些实际运维场景中的应用,旨在帮助运维人员快速上手并熟练运用 Ansible。 1. Ansible的核心概念

BUUCTF(34)特殊的 BASE64

使用pycharm时,如果想把代码撤销到之前的状态可以用 Ctrl+z 如果不小心撤销多了,可以用 Ctrl+Shift+Z 还原, 别傻傻的重新敲了 BUUCTF在线评测 (buuoj.cn) 查看字符串,想到base64的变表 这里用的c++的标准程序库中的string,头文件是#include<string> 这是base64的加密函数 std::string

超强的截图工具:PixPin

你是否还在为寻找一款功能强大、操作简便的截图工具而烦恼?市面上那么多工具,常常让人无从选择。今天,想给大家安利一款神器——PixPin,一款真正解放双手的截图工具。 想象一下,你只需要按下快捷键就能轻松完成多种截图任务,还能快速编辑、标注甚至保存多种格式的图片。这款工具能满足这些需求吗? PixPin不仅支持全屏、窗口、区域截图等基础功能,它还可以进行延时截图,让你捕捉到每个关键画面。不仅如此

Redis中使用布隆过滤器解决缓存穿透问题

一、缓存穿透(失效)问题 缓存穿透是指查询一个一定不存在的数据,由于缓存中没有命中,会去数据库中查询,而数据库中也没有该数据,并且每次查询都不会命中缓存,从而每次请求都直接打到了数据库上,这会给数据库带来巨大压力。 二、布隆过滤器原理 布隆过滤器(Bloom Filter)是一种空间效率很高的随机数据结构,它利用多个不同的哈希函数将一个元素映射到一个位数组中的多个位置,并将这些位置的值置

PR曲线——一个更敏感的性能评估工具

在不均衡数据集的情况下,精确率-召回率(Precision-Recall, PR)曲线是一种非常有用的工具,因为它提供了比传统的ROC曲线更准确的性能评估。以下是PR曲线在不均衡数据情况下的一些作用: 关注少数类:在不均衡数据集中,少数类的样本数量远少于多数类。PR曲线通过关注少数类(通常是正类)的性能来弥补这一点,因为它直接评估模型在识别正类方面的能力。 精确率与召回率的平衡:精确率(Pr

husky 工具配置代码检查工作流:提交代码至仓库前做代码检查

提示:这篇博客以我前两篇博客作为先修知识,请大家先去看看我前两篇博客 博客指路:前端 ESlint 代码规范及修复代码规范错误-CSDN博客前端 Vue3 项目开发—— ESLint & prettier 配置代码风格-CSDN博客 husky 工具配置代码检查工作流的作用 在工作中,我们经常需要将写好的代码提交至代码仓库 但是由于程序员疏忽而将不规范的代码提交至仓库,显然是不合理的 所

10个好用的AI写作工具【亲测免费】

1. 光速写作 传送入口:http://u3v.cn/6hXWYa AI打工神器,一键生成文章&ppt 2. 讯飞写作 传送入口:http://m6z.cn/5ODiSw 3. 讯飞绘文 传送入口:https://turbodesk.xfyun.cn/?channelid=gj3 4. AI排版助手 传送入口:http://m6z.cn/6ppnPn 5. Kim

分享5款免费录屏的工具,搞定网课不怕错过!

虽然现在学生们不怎么上网课, 但是对于上班族或者是没有办法到学校参加课程的人来说,网课还是很重要的,今天,我就来跟大家分享一下我用过的几款录屏软件=,看看它们在录制网课时的表现如何。 福昕录屏大师 网址:https://www.foxitsoftware.cn/REC/ 这款软件给我的第一印象就是界面简洁,操作起来很直观。它支持全屏录制,也支持区域录制,这对于我这种需要同时录制PPT和老师讲