Spring Boot2.0之 整合Redis事务详解编程语言
2023-06-13 09:20:46 时间
Redis 事务可以一次执行多个命令, 并且带有以下两个重要的保证:
事务是一个单独的隔离操作:事务中的所有命令都会序列化、按顺序地执行。事务在执行的过程中,不会被其他客户端发送来的命令请求所打断。
事务是一个原子操作:事务中的命令要么全部被执行,要么全部都不执行。
一个事务从开始到执行会经历以下三个阶段:
开始事务。
命令入队。
执行事务。
事务的开启很简单的:
可以使用AOP封装下~
跟之前使用MySQL数据库没啥子区别的
看下目录
pom:
project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd" modelVersion 4.0.0 /modelVersion groupId redis /groupId artifactId com.toov5.redis /artifactId version 0.0.1-SNAPSHOT /version parent groupId org.springframework.boot /groupId artifactId spring-boot-starter-parent /artifactId version 2.0.0.RELEASE /version /parent dependencies !-- SpringBoot web 核心组件 -- dependency groupId org.springframework.boot /groupId artifactId spring-boot-starter-web /artifactId /dependency dependency groupId org.springframework.boot /groupId artifactId spring-boot-starter-data-redis /artifactId /dependency /dependencies
groupId org.apache.maven.plugins /groupId artifactId maven-compiler-plugin /artifactId configuration source 1.8 /source target 1.8 /target /configuration /plugin plugin groupId org.springframework.boot /groupId artifactId spring-boot-maven-plugin /artifactId configuration maimClass com.itmayiedu.controller.IndexController /maimClass /configuration executions execution goals goal repackage /goal /goals /execution /executions /plugin /plugins /build
import org.springframework.beans.factory.annotation.Autowired; import org.springframework.data.redis.core.StringRedisTemplate; import org.springframework.stereotype.Component; @Component public class RedisService { @Autowired private StringRedisTemplate stringRedisTemplate; //这样该方法支持多种数据类型 public void set(String key , Object object, Long time){ //开启事务权限 stringRedisTemplate.setEnableTransactionSupport(true); try { //开启事务 stringRedisTemplate.multi(); String argString =(String)object; //强转下 stringRedisTemplate.opsForValue().set(key, argString); //成功就提交 stringRedisTemplate.exec(); } catch (Exception e) { //失败了就回滚 stringRedisTemplate.discard(); if (object instanceof String ) { //判断下是String类型不 String argString =(String)object; //强转下 //存放String类型的 stringRedisTemplate.opsForValue().set(key, argString); //如果存放Set类型 if (object instanceof Set) { Set String valueSet =(Set String )object; for(String string:valueSet){ stringRedisTemplate.opsForSet().add(key, string); //此处点击下源码看下 第二个参数可以放好多 //设置有效期 if (time != null) { stringRedisTemplate.expire(key, time, TimeUnit.SECONDS); //做个封装 public void setString(String key, Object object){ String argString =(String)object; //强转下 //存放String类型的 stringRedisTemplate.opsForValue().set(key, argString); public void setSet(String key, Object object){ Set String valueSet =(Set String )object; for(String string:valueSet){ stringRedisTemplate.opsForSet().add(key, string); //此处点击下源码看下 第二个参数可以放好多 public String getString(String key){ return stringRedisTemplate.opsForValue().get(key);
import org.springframework.beans.factory.annotation.Autowired; import org.springframework.web.bind.annotation.RequestMapping; import org.springframework.web.bind.annotation.RestController; import com.toov5.service.RedisService; @RestController public class IndexController { @Autowired private RedisService redisService; @RequestMapping("/setString") public String setString(String key, String value){ redisService.set(key, value, 5000l); //超时时间5000s l表示long型 return "成功"; @RequestMapping("get") public String get(String key){ return redisService.getString(key); }
import org.springframework.boot.SpringApplication; import org.springframework.boot.autoconfigure.SpringBootApplication; @SpringBootApplication(scanBasePackages={"com.toov5.*"}) public class app { public static void main(String[] args) { SpringApplication.run(app.class, args); }
yml: 注意一定要是Master啊 Slave不支持写哦
spring: redis: database: 0 host: 192.168.91.3 port: 6379 password: 123 jedis: pool: max-active: 8 max-wait: -1 max-idle: 8 min-idle: 0 timeout: 10000
运行结果:
Redis
原创文章,作者:ItWorker,如若转载,请注明出处:https://blog.ytso.com/16146.html
cgojavamysqlxml相关文章
- Redis(八):spring data redis 理解详解大数据
- Redis准确无误的事务处理与管道技术(redis事务管道)
- Redis数据失效机制研究(redis失效原理)
- Java实现Redis事务管理(redis事务java)
- Redis管理:快速列出所有key(redis列出key)
- Redis集群下的事务操作(redis 集群 事务)
- Redis事务如何理解和运用(怎么理解redis 事务)
- 火速开启Redis事务(用redis要开事物吗)
- Redis提供分布式事务解决方案(用redis做分布式事务)
- 让Redis支持注解事务回滚(注解事务和redis回滚)
- 一分钟了解Redis事务实现数据安全保障(一分钟看懂redis事务)
- XCache与Redis一次性能提升的神奇组合(xcache redis)
- 春天里的Redis开启缓存大门的钥匙(spring_redis)
- Redis让单机也支持事务(单机支持事务 redis)
- 使用Redis解决分布式事务问题(分布式事务用redis)
- 分布式事务探索Redis尝试(分布式事务 redis)
- Redis高效实现频繁读取(redis 高效频繁读取)
- Redis的弹指之间,防护崩溃的坚实保障(redis防崩溃)
- Redis中插入对象的实战技巧(redis里面插入对象)
- 支持Redis实现部分事务功能(redis部分事物)
- Redis自动化清空缓存,提升系统运行效率(redis 自动清空缓存)
- 使用Redis脚本实现事务处理(redis 脚本 事务)