Redis实践(4.3)SpringBoot 读模式的负载均衡

前文中使用SpringBoot Data Redis项目集成了Redis的主从架构接入,本篇主要来测试一下整合后从项目中使用自定义的工具类操作redis相关的API,实现操作Redis读模式的负载均衡。前篇示例中分别提供了注解@Resource注入的形式获取RedisTemplate类型,但是获取到固定的是某台服务器的连接模板对象,在使用过程中一旦定义则每次请求均来自一个模块,理论上可以通过模块功能代码的形式来实现压力复杂。另外一种则是本文使用的工具类来实现读取数据的负载均衡(前文中所述写模式只有一台服务器所以不存在负载均衡),详见下文。 1.RedisUtils packagecn.chendd.redis.utils; import...; /** *RedisUtils工具类 * *@authorchendd *@date2023/5/1922:00 */ publicfinal...

文章分类:经验分享 技术知识

Redis

Redis实践(4.2)SpringBoot 测试主从连接池

前文中使用SpringBoot Data Redis项目集成了Redis的主从架构接入,本篇主要来测试一下整合后从项目中配置的Redis连接池是否生效的实现,虽然配置了有连接池参数,仅仅只是参数配置而已,事实上它确实是生效了吗?所以本文将使用代码来验证验证使用RedisTemplate的连接池工作机制,详见下文。 1.application.yml lettuce: pool: enabled:true max-active:8#最大连接数据库连接数,设-1为没有限制 max-idle:8#最大等待连接中的数量,设0为没有限制 max-wait:10s#最大建立连接等待时间。如果超过此时间将接到异常。设为-1表示无限制。 min-idle:0#最小等待连接中的数量,设0为没有限制 time-between-eviction-runs:10s#空闲连接回收时间 【说明】 (1)此...

文章分类:经验分享 技术知识

Redis

Redis实践(4.1)SpringBoot 测试主从RedisTemplate

前文中使用SpringBoot Data Redis项目集成了Redis的主从架构接入,本篇主要来测试一下整合后从项目中获取的RedisTemplate上下文信息以及操作redis相关的API,所以本文使用两种方式来获取RedisTemplate实例,分别是使用Spring注解和Spring Bean组件获取的工具类的形式,通过不同的RedisTemplate实例拿到不同的ConnectionFactory来验证各个实例操作的都是对应的Redis环境,详见下文。 1.注解代码 通过注解的形式注入6个容器对象,分别是2个写Redis和4个读Redis,同时包含了RedisTemplate和StringRedisTemplate,参考如下代码: package cn.chendd.redis; import ... /** * 使用@Resource注入的方式来测试redis的6个实现类,关...

文章分类:经验分享 技术知识

Redis

Redis实践(4)SpringBoot Data Redis 主从架构集成

1.基本介绍 前篇文章搭建了一个Redis的主从高可用架构,无论怎么玩也都是基于Redis客户端进行的,实际需要使用相关的Spring技术整合才是灵魂需要,所以基于这个一主二从的Redis环境来使用SpringBoot Data Redis来整合实践,本篇文章将搭建项目环境,配置相关参数。从Spring官网查看了SpringBoot Data Redis子项目的介绍信息,选择了2.7.12的稳定版本,比2.X再新的2.7.13-SNAPSHOT为快照版本,限制Spring Framework 5.3.27 且 JDK8,3.X的稳定版本限制的条件Spring Framework 6.0.9 且 JDK17,参考如下图所示 (2.7.12限制条件) (3.0.6限制条件) 2.Maven坐标 <properties> <project.build.sourceEncoding>UTF-8<...

文章分类:经验分享 技术知识

Redis
封面图片

Redis实践(3)主从复制高可用架构

1.基本介绍 Redis单击环境版仅适合学习和测试应用,因为一台服务器将承载应用的全部请求,压力较大且容量有限,所以生产环境应当考虑更高级别的可用策略,主从复制是Redis高可用中最简单的实现方式。实现Redis高可用的模式主要有三种: 主从模式、哨兵模式、集群模式。本文将基于当前最新版本Redis7.0.11来搭建的主从模式,并验证相关配置的正确性。 主从模式顾名思义是一台为主机Master,一台为从机Slave,甚至可以是多台为从机,这种结构将多台服务器的Redis服务连接为一个整体。Redis master slave 使用异步方式将数据从 master 传输到 slave。从节点会确认接收到主节点发送的数据,主节点将包含多个从节点。Redis 支持级联复制类型,因此我们的从服务器连接到另一个从服务器,为主从节点启用持久性选项是非常好的做法。基本上,主从是一种用于将数据库从一台服务器...

文章分类:经验分享 技术知识

Redis

Redis实践(2)客户端介绍

前面一篇实践了Redis的安装,也算是有了一个基础的Redis环境,本篇文章介绍一下相关的Redis的客户端,笔者并未对各个的客户端亲自实践,但总归是收集了一些官方介绍的资料进行了解和汇总,本文所述的客户端是指以客户端软件的形式访问Redis服务器,并非是具体的某个编程语言的接入框架,且看下文细细道来,以下各个客户端的排名不分先后。 1.客户端介绍 1.1 RedisInsight Redis-cli是Redis官方命令行工具,可用于执行Redis命令,并在终端中提供直观的Redis终端命令的操作体验。 Redis官方提供的客户端RedisInsight 是将图形用户界面与 Redis CLI 相结合,让您可以使用任何 Redis 部署。您可以直观地浏览数据并与之交互、利用诊断工具、通过示例学习等等。最重要的是,RedisInsight 是免费的。 RedisInsight 是一个强大的工...

文章分类:经验分享 技术知识

Redis

Redis实践(1)简单介绍与安装

1.背景介绍 早在19和20年全面学习SpringBoot相关技术知识时也曾经有学习到Redis,主要是看了几家的视频教程,但是未曾有具体的实践,后来再学习到Docker和Spring Session框架的Redis存储时,又稍微的实践了一丢丢,所有的实践也就仅此而已,蜻蜓点水的程度,谈不上有掌握,更谈不上深度掌握,所以我把Redis这块的技术暂时搁浅了,直到前几个月掌握到SpringCloud Alibaba系列技能后,又想起来Redis这块的技术,对于专业的技术开发者,怎么能容忍自己不去掌握了,所以一个月以来花了许许多多的周末和晚上的闲暇时光,进行了学习实践。 本次相关实践是站在自己的水平面上进行的实践,实践范围也主要围绕个人感兴趣的知识范围内的实现,只占整合Redis相关技术圈非常非常小的一部分,核心围绕Redis的主从复制、集群架构、桌面客户端、SpringBoot Data Re...

文章分类:经验分享 技术知识

Redis

Java解析xml大文件

基本介绍 曾经使用Java解析xml文件的实现方式和优缺点还是经典的面试题目,要是没有经历过或者并不认可的说明还是很年前的。日常工作中常见的配置文件类型有:xml、yml、properties、ini、json等格式,一些常用简单的配置可能首选将不再是xml,但xml格式也终将不会被抛弃,毕竟有许多适合的应用场景与其它格式无法具备的优点。 关于xml格式文件的解析,记忆中常用的有dom、jdom、jom4j、sax和JDK6中增加的Jaxb组件,对于xml大文件的解析除了它们自身实现的差异外,也主要取决于对各个API的把控,这几年来对于xml文件的解析一直使用的是Jaxb,话说还真的是我觉得最便捷好易用的,只不过在去年遇到了一个50M的以上大小的xml文件,在文件稍大的情况下,首先联想到的便是肯定不能一次性读取文件,再去使用xml解析,也就是说上述的所有组件均不能直接使用,也在同事超大佬的...

文章分类:经验分享 技术知识

使用Allatori实现代码混淆加密

每个软件开发人员迟早都会意识到,他不仅必须支持他制作的产品并不断更新它,试图以所有可能的方式改进它,而且还要同时保护它。在我们这个信息技术和快速变化的市场时代,这些规则是在软件开发业务中取得成功的唯一途径。每个软件开发人员迟早都会意识到,他不仅必须支持他制作的产品并不断更新它,试图以所有可能的方式改进它,而且还要同时保护它。在我们这个信息技术和快速变化的市场时代,这些规则是在软件开发业务中取得成功的唯一途径。混淆器Allatori充分利用了人类大脑在代码保护领域的发明,可供许多软件开发人员使用,他们的目的是保护他们的秘密和专有技术——这实际上意味着保护他们的未来。它的官方网站地址为“https://allatori.com/”,前面这段也是从其官网上翻译来摘选的,看到更新日志时才知道JDK的版本也到了17的版本了,当前最新版本为Allatori-8.2,可免费用于教育和非商业项目。 代码混...

文章分类:经验分享 技术知识

获取文件内容的编码格式

对于字符文件的读取若要读取到预期的文本内容则需要传递对应的文件编码,若出现读取文件的编码与文件实际编码不匹配时则会出现乱码,本文则是提供几种获取文件编码的实现方式。本文所述的文件编码格式是狭义的个人认为的UTF-8和GB2312(GBK)的中文编码,其它的非中文编码则不在考虑的范围内。 所以,本文以简单的示例出发,提供两个文件分别是GB2312.txt和UTF8.txt,在代码中分别获取到这两个文件的实际编码即可,目前掌握了共3种方式,详细参考如下: Jdk内置Charset 这种方式没有具体的实践,听旁边的同时随口一说,主要是使用Charset中的编码进行编码,是canEncode是否可以按指定的编码进行编码啥的,同时也有见到那种将文件内容读取到,而后再转换为String类型,使用new String(文件内容.getBytes(编码) , 编码)后的文本再与原始文件内容进行对比,若对比...

文章分类:经验分享 技术知识

本站信息

 运营时间: 天

 用户数量: 人

 文章数量: 篇

 评论数量: 条

 点赞个数: 个

 最后更新:

标签云