当前位置: 首页 > news >正文

意外险平台服务网站网站icp备案咋做

意外险平台服务网站,网站icp备案咋做,软件开发文档标准,用jsp做留言板网站记录&#xff1a;449 场景&#xff1a;在Spring Boot微服务使用JedisCluster操作Redis集群的String字符串数据类型。 版本&#xff1a;JDK 1.8,Spring Boot 2.6.3,redis-6.2.5,jedis-3.7.1。 1.微服务中配置Redis信息 1.1在pom.xml添加依赖 pom.xml文件&#xff1a; <…

记录:449

场景:在Spring Boot微服务使用JedisCluster操作Redis集群的String字符串数据类型。

版本:JDK 1.8,Spring Boot 2.6.3,redis-6.2.5,jedis-3.7.1。

1.微服务中配置Redis信息

1.1在pom.xml添加依赖

pom.xml文件:

<dependency><groupId>redis.clients</groupId><artifactId>jedis</artifactId><version>3.7.1</version>
</dependency>

解析:在Spring Boot中默认集成jedis,使用无需加版本号,本例版本3.7.1是Spring Boot 2.6.3对应的版本。

1.2在application.yml中配置Redis集群信息

(1)application.yml配置内容

hub:example:redis:jedis-cluster:password: demo12345678connection-timeout: 60000so-timeout: 1000max-attempts: 100nodes:- 192.168.19.161:27001- 192.168.19.161:27002- 192.168.19.162:27001- 192.168.19.162:27002- 192.168.19.163:27001- 192.168.19.163:27002

(2)解析

在application.yml中配置内容是自定义的,对应自定义配置类JedisClusterProperties。

类全称:com.hub.example.config.JedisClusterProperties。

自定义配置类使用如下注解生效:

@ConfigurationProperties(prefix = "hub.example.redis.jedis-cluster")

1.3加载简要逻辑

Spring Boot微服务在启动时,自动注解机制会读取application.yml的配置信息注入到自定义配置类JedisClusterProperties对象的对应属性。因此,在Spring环境中就能取到Redis集群的配置信息。

Spring从JedisClusterProperties对象中取配置注入到JedisCluster客户端中。因此,JedisCluster客户端就能对Redis集群做增、删、改、查等操作。

2.配置JedisCluster

JedisCluster是jedis框架中封装的操作Redis的客户端。

类全称:redis.clients.jedis.JedisCluster

2.1配置JedisClusterProperties

JedisClusterProperties是自定义配置了,作用是加载application.yml中Redis集群的配置信息。

使用@ConfigurationProperties注解生效,使用注解的prefix指定配置application.yml中前缀。

@Component
@ConfigurationProperties(prefix = "hub.example.redis.jedis-cluster")
public class JedisClusterProperties {private List<String> nodes;private String password;private int connectionTimeout;private int soTimeout;private int maxAttempts;public List<String> getNodes() {return nodes;}public void setNodes(List<String> nodes) {this.nodes = nodes;}public String getPassword() {return password;}public void setPassword(String password) {this.password = password;}public int getConnectionTimeout() {return connectionTimeout;}public void setConnectionTimeout(int connectionTimeout) {this.connectionTimeout = connectionTimeout;}public int getSoTimeout() {return soTimeout;}public void setSoTimeout(int soTimeout) {this.soTimeout = soTimeout;}public int getMaxAttempts() {return maxAttempts;}public void setMaxAttempts(int maxAttempts) {this.maxAttempts = maxAttempts;}
}

2.2配置JedisCluster

@Configuration
public class JedisClusterConfig {@AutowiredJedisClusterProperties jedisClusterProperties;@Bean("jedisCluster")public JedisCluster getJedisCluster(JedisPoolConfig jedisPoolConfigCluster) {List<String> nodesList = jedisClusterProperties.getNodes();Set<HostAndPort> nodesSet = new HashSet<>();for (String ipAndPort : nodesList) {String[] ipAndPortPair = ipAndPort.split(":");nodesSet.add(new HostAndPort(ipAndPortPair[0].trim(), Integer.parseInt(ipAndPortPair[1].trim())));}return new JedisCluster(nodesSet,jedisClusterProperties.getConnectionTimeout(),jedisClusterProperties.getSoTimeout(),jedisClusterProperties.getMaxAttempts(),jedisClusterProperties.getPassword(),jedisPoolConfigCluster);}@Bean("jedisPoolConfigCluster")public JedisPoolConfig jedisPoolConfigCluster() {JedisPoolConfig jedisPoolConfig = new JedisPoolConfig();jedisPoolConfig.setMaxTotal(30);jedisPoolConfig.setMaxIdle(30);jedisPoolConfig.setMinIdle(1);jedisPoolConfig.setNumTestsPerEvictionRun(-1);jedisPoolConfig.setTestOnBorrow(true);jedisPoolConfig.setTestOnReturn(false);jedisPoolConfig.setBlockWhenExhausted(false);return jedisPoolConfig;}
}

2.3解析

配置JedisCluster后,在Spring环境中,使用@Autowired注解注入JedisCluster实例操作Redis集群。

3.使用Jedis操作Redis集群String字符串

3.1简要说明

使用JedisCluster操作Redis集群String字符串,常用操作:增、查、改、删、设置超时等。

3.2操作示例

@RestController
@RequestMapping("/hub/example/operateJedisCluster")
@Slf4j
public class OperateJedisClusterController {@Autowiredprivate JedisCluster jedisCluster;/*** 使用JedisCluster操作Redis集群String字符串类型数据*/@GetMapping("/f02")public Object f02() {log.info("JedisCluster操作Redis集群开始...");// 1.增// 1.1写一条数据jedisCluster.set("J:2023060802:01", "苏州");// 1.2写一条数据,键不存在时,才对键进行设置操作jedisCluster.setnx("J:2023060802:02", "苏州-工业园区");// 1.3写一条数据,并设置超时,600秒jedisCluster.setex("J:2023060802:03", 600L, "苏州-相城");// 2.查String result01 = jedisCluster.get("J:2023060802:01");log.info("查询J:2023060802:01 = " + result01.toString());// 3.改// 3.1修改一条数据jedisCluster.set("J:2023060802:01", "苏州-姑苏");// 3.1修改一条数据,只有键存在才修改SetParams setParams01 = new SetParams();setParams01.ex(5 * 60L);setParams01.xx();jedisCluster.set("J:2023060802:03", "苏州-工业园区-苏州", setParams01);// 4.删long time = 8000;log.info("{}秒后,删除J:2023060802:03.", time / 1000);ThreadUtil.sleep(time);jedisCluster.del("J:2023060802:03");// 5.判断键是否存在Boolean exists01 = jedisCluster.exists("J:2023060802:03");// 6.设置超时// 6.1设置5分钟超时SetParams setParams02 = new SetParams();setParams02.ex(5 * 60L);jedisCluster.set("J:2023060802:04", "苏州-昆山", setParams02);// 6.2设置10分钟超时jedisCluster.expire("J:2023060802:04", 10 * 60L);// 7.查存活时间Long ttl = jedisCluster.ttl("J:2023060802:04");log.info("缓存J:2023060802:04剩余存活时间: {}", ttl);log.info("JedisCluster操作Redis集群结束...");return "执行成功";}
}

3.3测试验证

使用Postman测试。

请求RUL:http://127.0.0.1:18205/hub-205-redis/hub/example/operateJedisCluster/f02

以上,感谢。

2023年6月8日

http://www.yayakq.cn/news/778166/

相关文章:

  • 敲代码做网站多少钱上海 网站建设 500强
  • 如何利用div做网站如何建立一个小程序
  • 棕色网站模板河北怀来县建设局网站
  • 西安分类信息网站开发微信小程序的软件
  • 最好的完全免费开源企业网站如何选择一个优质网站建设公司
  • 亿景网站建设wordpress 菜单 页面跳转
  • 延庆免费网站建设初学者做网站
  • 怎么建设一个网站网站开发制作报价
  • app大全软件网站免费下载wordpress 主题评论
  • 南京做公司网站深圳极速网站建设服务器
  • 摄影网站建设流程广州网站建设索王道下拉
  • 爱做的小说网站大专计算机专业主要学什么
  • 企业网站建设方案百度文库世界工厂网app
  • 网站栏目规划图做网站需要用到ps吗
  • 安阳那里可以制作网站广州优化排名推广
  • 学生为学校做网站建筑网官方网站
  • 郑州网站建设注意事项开发工具下载
  • 怎样注册公司网站建设网页沈阳哪家公司做网站好
  • 大连投诉网站免费网站技术
  • 怎么做视频平台网站吗上海全屋整装哪家好
  • 做视频导航网站有哪些桂林微信网站开发
  • 站酷海洛肥西建设局网站
  • 企业网站建设费未付款怎样挂账1如何做网站推广
  • 网站策划怎么下载网站源码
  • wordpress网站系统自贡订房中心网站建设
  • 淮安官方网站开发区贺州同城购物网站建设
  • 个人主页网站应该怎样做西宁市网站建设
  • 网站建设设计制作外包wordpress标签手册
  • 网站平台建设实训内容合肥网络公司哪个最好
  • 需要登陆的网站如何做爬虫oa系统哪个品牌好