springboot整合redis-sentinel哨兵模式集群(一)

引入依赖

        <!-- redis --><dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-data-redis</artifactId></dependency><dependency><groupId>redis.clients</groupId><artifactId>jedis</artifactId></dependency>

application.properties 添加Redis配置

redis.cluster="192.168.74.142:7000,192.168.74.142:7001,192.168.74.142:7002,192.168.74.130:7003,192.168.74.130:7004,192.168.74.130:7005"#集群地址
redis.masterName="xxx"
redis.password="***"
@Configuration
public class RedisSentinelConfig {@Value("${redis.cluster}")private String nodesStr;@Value("${redis.masterName}")private String masterName;@Value("${redis.password}")private String masterName;private static final String COLON = ",";private static final String COMMA=":";// 配置RedisSentinelConfig@Beanpublic RedisSentinelConfiguration redisSentinelConfiguration(){RedisSentinelConfiguration configuration = new RedisSentinelConfiguration();String[] host = nodesStr.split(COLON);for (String redisHost : host) {String[] item = redisHost.split(COMMA);String ip = item[0];String port = item[1];configuration.addSentinel(new RedisNode(ip, Integer.parseInt(port)));}configuration.setMaster(masterName);return configuration;}// 配置redis连接池JedisSentinelPoolConfig@Beanpublic JedisPoolConfig jedisSentinelPoolConfiggg() {JedisPoolConfig jedisPoolConfig = new JedisPoolConfig();//最大连接数,默认为8个,当连接池中的连接数达到最大连接数时,新的连接请求将会被阻塞,直到有连接被释放回连接池中jedisPoolConfig.setMaxTotal(3);//最大空闲连接数,默认为8个,当连接池中的空闲连接数超过最大空闲连接数时,多余的连接将会被关闭jedisPoolConfig.setMaxIdle(1);//JedisConnectionFactory jedisConnectionFactory = new JedisConnectionFactory();//jedisConnectionFactory.setjedisPoolConfig.setMinIdle(0);//当连接池中的连接耗尽且blockWhenExhausted为true时,等待获取连接的最大时间(单位为毫秒),默认值为-1,表示永不超时jedisPoolConfig.setMaxWaitMillis(2 * 1000L);//当连接池中的连接耗尽时,是否阻塞等待,默认值为true。如果设置为false,则当连接池中的连接耗尽时,会直接抛出异常jedisPoolConfig.setBlockWhenExhausted(true);//设置的逐出策略类名,默认DefaultEvictionPolicy(当连接超过最大空闲时间,或连接数据超过最大空闲连接数)jedisPoolConfig.setEvictionPolicyClassName("org.apache.commons.pool2.impl.DefaultEvictionPolicy");//是否启用Pool的JMX管理功能,默认为truejedisPoolConfig.setJmxEnabled(true);//在borrow一个jedis实例时,是否提前进行validate操作,如果为true,则得到的jedis实例均是可用的;//在从连接池中获取连接时,是否进行连接有效性检查,默认值为false。如果设置为true,则在获取连接时会调用validateObject方法进行连接有效性检查jedisPoolConfig.setTestOnBorrow(true);return jedisPoolConfig;}//配置redis连接工厂jedisConnectionFactry@Beanpublic JedisConnectionFactory jedisConnectionFactry(@Autowired RedisSentinelConfiguration configuration, @Autowired JedisPoolConfig jedisPoolConfig){JedisConnectionFactory jedisConnectionFactory = new JedisConnectionFactory(configuration, jedisPoolConfig);jedisConnectionFactory.setPassword(password);return jedisConnectionFactory;}//RedisTemplate配置类@Bean@Autowiredpublic StringRedisTemplate redisTemplate(RedisConnectionFactory jedisConnectionFactory) {// StringRedisSerializer和GenericJackson2JsonRedisSerializer是Spring Data Redis中常用的两种序列化方法// StringRedisSerializer是RedisTemplate默认的key和value的序列化方式,它将对象序列化为字符串存储在Redis中。它适用于存储简单的字符串类型数据,如字符串、数字等。// GenericJackson2JsonRedisSerializer是RedisTemplate默认的value的序列化方式,它使用Jackson库将对象序列化为JSON格式存储在Redis中。它适用于存储复杂的对象类型数据,如Java对象、集合、Map等// 如果存储的是简单的字符串类型数据,可以使用StringRedisSerializer。如果存储的是复杂的对象类型数据,可以使用GenericJackson2JsonRedisSerializer。也可以根据自己的需求自定义序列化方式StringRedisTemplate redisTemplate = new StringRedisTemplate();redisTemplate.setConnectionFactory(jedisConnectionFactory);// key采用String的序列化方式redisTemplate.setKeySerializer(new StringRedisSerializer());// valuevalue采用GenericJackson2JsonRedisSerializer序列化方式redisTemplate.setValueSerializer(new GenericJackson2JsonRedisSerializer());redisTemplate.afterPropertiesSet();return redisTemplate;}

参考博客: https://blog.csdn.net/weixin_42338444/article/details/102682584?spm=1001.2014.3001.5506

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/76992.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Python 图片处理

Step1 提取PDF中的图片&#xff0c;并另存 Step2 去除灰色纸张背景 import PyPDF2 from PIL import ImageEnhance,Image,ImageFilter import cv2 import numpy as np from skimage.filters import unsharp_mask from skimage.filters import gaussian from skimage.restora…

Linux设备驱动——自动创建设备节点udev机制的实现过程

创建设备文件的机制有以下下列几种&#xff1a; mknod命令&#xff1a;手动创建设备节点的命令devfs:可以用于创建设备节点&#xff0c;创建设备节点的逻辑在内核空间&#xff08;内核2.4版本之前使用&#xff09;udev:自动创建设备节点的机制&#xff0c;创建设备节点的逻辑在…

Ubuntu20 安装 带cuda的opencv遇到的问题

问题1&#xff1a; CUDA 12.2 fp16 dnn 编译错误 错误 C2666: operator !: 具有类似的转换重载函数 解决&#xff1a; CUDA 12.2 fp16 dnn compilation error Issue #23893 opencv/opencv GitHub Solution: I "solved" this by using static_cast. You want …

python机器人编程——用python实现一个写字机器人

目录 一、前言二、整体框架2.1 系统构成2.2 硬件介绍2.2.1主要组成部分2.2.2机械结构2.2.3驱动及控制主板PS电机驱动原理简介: 2.2.4其余部分 2.3 机器人python程序框架2.3.1通信服务模块2.3.2消息处理模块2.3.3轨迹解析模块2.3.4机械臂逆解模块2.3.5写字板模块 三、机械臂的建…

0门槛限制!快来领取你的专属元宇宙虚拟展厅!

数字化时代中&#xff0c;元宇宙虚拟展厅仿佛成为了一种新的潮流&#xff0c;虚拟展厅的出现为我们呈现出了一个超越现实的全新世界。元宇宙虚拟展厅以其多样性、互动性、沉浸式展示为特点&#xff0c;同产品进行交互&#xff0c;创造出逼真的虚拟环境&#xff0c;为广大用户打…

【Linux学习笔记】消息队列

方法一&#xff1a; 消息队列的接口 #include "fcntl.h" #include "sys/stat.h" #include "mqueue.h"// 创建消息队列实例。name: 消息队列名称。成功返回0&#xff0c;失败返回-1&#xff0c;错误码存于error中 mqd_t mq_open(const char *na…

八股——const 关键字

1.const作用 作用&#xff1a;const用于保护指针指向数据不被修改 测试代码1 显示数组的函数不小心修改了指针指向的值&#xff0c;这时候没有加const关键字&#xff0c;编译器不会报错 #include <stdio.h> void showar(int ar[]);int main(void) {int ar[4]{2,3,4,5…

Springboot后端跨域处理

跨域 当一台服务器资源从另一台服务器&#xff08;不同的域名或者端口&#xff09;请求一个资源或者接口&#xff0c;就会发起一个跨域HTTP请求。 同源&#xff1a;协议、域名、端口都相同 只要一个不同&#xff0c;就是跨域。 例子 请求方响应方是否跨域原因http://www.ba…

element-ui switch开关组件二次封装,添加loading效果,点击时调用接口后改变状态

先看效果&#xff1a; element-ui中的switch开关无loading属性&#xff08;在element-plus时加入了&#xff09;&#xff0c;而且点击时开关状态就会切换&#xff0c;这使得在需要调用接口后再改变开关状态变得比较麻烦。 思路&#xff1a;switch开关外包一层div&#xff0c;给…

LeetCode518. 零钱兑换 II 以及 动态规划相关的排列组合问题

文章目录 一、题目二、题解方法一&#xff1a;完全背包问题的变体&#xff08;版本1&#xff09;方法二&#xff1a;完全背包问题变体&#xff08;版本2&#xff09; 三、拓展&#xff1a;先遍历物品后遍历背包vs先遍历背包后遍历物品先遍历物品后遍历背包&#xff08;组合问题…

NAT实验:构建复杂网络拓扑,实现互联网访问与FTP发布

文章目录 一、实验背景与目的二、实验拓扑三、实验需求四、实验解法1.配置链路上各个接口的IP地址。2.在私网中配置单臂路由3.在R1和R3上配置默认路由指向公网。4.私网A通过NAPT使vlan 20和vlan 10能够使用R1的公网访问互联网。5.私网B通过在R3上配置EASY IP访问互联网。6.私网…

Docker部署EMQX

1、简介 EMQ X (Erlang/Enterprise/Elastic MQTT Broker) 是基于 Erlang/OTP 平台开发的开源物联网 MQTT 消息服务器。 Erlang/OTP是出色的软实时 (Soft-Realtime)、低延时 (Low-Latency)、分布式 (Distributed)的语言平台。 MQTT 是轻量的 (Lightweight)、发布订阅模式 (Pu…

labelme2voc 标签重叠/覆盖问题

使用labelme自带的 labelme2voc.py转换voc数据集时可能标签重叠

Maven Helper mvn项目冲突如何解决

一般用这款插件来查看maven的依赖树。 一、安装&#xff1a; File-->setting--->Plugins--->在搜索框中填写Maven Helper然后搜索&#xff0c;单击Install按钮进行安装&#xff0c;装完重启IDE。 二、使用 当Maven Helper 插件安装成功后&#xff0c;打开项目中的p…

AMD R7 7840HS 核显 780M 性能怎么样

目录 1. 基本数据 2.性能对比 2.1对比一 2.2 对比二 3.综合 1. 基本数据 2.性能对比 2.1对比一 锐龙77840h相当于i几 答&#xff1a;类似于I7-12700H R7 7840H介于13500-13700之间。 R7 7840H是AMD锐龙旗下高性能的一款处理器&#xff0c;主要应用在主流的游戏本中。各…

GFS 分布式文件系统

1&#xff0e;GlusterFS简介 GlusterFS 是一个开源的分布式文件系统。 由存储服务器、客户端以及NFS/Samba 存储网关&#xff08;可选&#xff0c;根据需要选择使用&#xff09;组成。 没有元数据服务器组件&#xff0c;这有助于提升整个系统的性能、可靠性和稳定性。 MFS 传统…

GO语言篇之发布开源软件包

GO语言篇之发布开源软件包 文章目录 GO语言篇之发布开源软件包新建仓库拉取到本地初始化项目编写代码提交代码发布引用软件包 我们写GO语言程序的时候难免会引用第三方的软件包&#xff0c;那么你知道别人是怎么发布自己的软件包吗&#xff0c;别急&#xff0c;这篇博客教你怎么…

数据分享|R语言分析上海空气质量指数数据:kmean聚类、层次聚类、时间序列分析:arima模型、指数平滑法...

全文链接&#xff1a;http://tecdat.cn/?p30131 最近我们被客户要求撰写关于上海空气质量指数的研究报告。本文向大家介绍R语言对上海PM2.5等空气质量数据&#xff08;查看文末了解数据免费获取方式&#xff09;间的相关分析和预测分析&#xff0c;主要内容包括其使用实例&…

【持续更新】Linux下常用的命令脚本

mysql 备份数据库 mysqldump -u用户名 -p密码 --databases 数据库名称 > 备份文件.sql备份全部数据库 #!/bin/bash# MySQL用户名和密码 MYSQL_USER"root" MYSQL_PASSWORD"XMhmyh2019."# 备份保存路径 BACKUP_DIR"/usr/mysqlbackup"# 获取数…

Vue通过ref修改 <el-input-number> 增减按钮的样式

Vue 为一个 <el-input-number> 设置了ref为‘inputNumberRef’, 通过这个ref获取<el-input-number>组件中的增、减按钮所在的<i>标签&#xff0c;并将它们的class分别改为el-icon-plus 和 el-icon-minus。 可以通过以下代码实现&#xff1a; <template&g…