SpringBoot--Redis入门开发

1 篇文章 0 订阅
  • 步骤一:

    导入整合坐标

            <!--springboot 整合redis -->
            <dependency>
                <groupId>org.springframework.boot</groupId>
                <artifactId>spring-boot-starter-data-redis</artifactId>
            </dependency>
            
            <!--引入data-redis的依赖包:jackson-->
            <dependency>
                <groupId>com.fasterxml.jackson.core</groupId>
                <artifactId>jackson-databind</artifactId>
                <version>2.9.8</version>
            </dependency>

  • 步骤二: RedisTemplate 模板类

    手动装配这个类:RedisConfig

    @Configuration
    @EnableCaching
    public class RedisConfig {
    ​
        //1.注入工厂对象
        @Resource
        private RedisConnectionFactory redisConnectionFactory;
    ​
        //2.注入模板类对象
        @Bean
        public RedisTemplate get(){
            RedisTemplate redisTemplate = new RedisTemplate();
            redisTemplate.setKeySerializer(new StringRedisSerializer());//将传入的key : 序列化
            redisTemplate.setValueSerializer(new GenericJackson2JsonRedisSerializer());//将传入的value : 序列化
            redisTemplate.setConnectionFactory(redisConnectionFactory);//通过工厂获取连接对象,模板类建立了与redis连接
            return  redisTemplate;
        }
    }
    ​

  • 步骤三:使用RedisTemplate 模板类操作redis数据库

    ​
    @RunWith(SpringRunner.class)
    @SpringBootTest(classes = RedisApplication.class)
    public class Demo {
    ​
        @Autowired
        @Qualifier("redisTemplate")
        RedisTemplate  redisTemplate;
    ​
        @Test
        public void testX1(){
            //获取操作redis五种数据类型的对象
            ValueOperations string_oper = redisTemplate.opsForValue();
            ListOperations list_per = redisTemplate.opsForList();
            HashOperations hash_per= redisTemplate.opsForHash();
            SetOperations set_per= redisTemplate.opsForSet();
            ZSetOperations zSet_oper= redisTemplate.opsForZSet();
        }
        @Test
        public void testX(){
            //获取操作redis五种数据类型的对象
            ValueOperations string_oper = redisTemplate.opsForValue();
           string_oper.set("ssss","AAA");
        }
    ​
    }

  • 步骤四: 启用redis缓存,在配置类RedisConfig加上注解: @EnableCaching //开启缓存

    • @Cacheable: 使用redis保存数据

    • @CachePut: 在做更新(添加/修改)方法后,更新redis缓存数据

    • @CacheEvict 应用到删除数据的方法上,调用方法时会从缓存中删除对应 key 的数据

      相同的属性:属性里面可以使用spel表达式

      value = "user",:redis缓存的名称

      key = "ss", 缓存的key

      unless = "条件表达式“: 当不满足条件时,使用redis保存数据,反之不保存

      condition="条件表达式": 当满足条件时,使用redis保存数据,反之保存

    @Service
    public class CategoryServiceImpl implements CategoryService {
        @Cacheable(value = "list33",key="#root.methodName",unless = "3>10")
        public List<String> findAll() {
            List<String> list = new ArrayList<String>();
            list.add("phone");
            list.add("computer");
            list.add("clothes");
            return list;
        }
    }
    ​

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: 好的,以下是一个简单的Spring Boot与Redis集成的项目。 1. 首先,我们需要在pom.xml文件添加以下依赖: ``` <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-data-redis</artifactId> </dependency> ``` 这将添加Spring Data Redis的依赖。 2. 接下来,我们需要在application.properties文件添加Redis的配置信息: ``` spring.redis.host=localhost spring.redis.port=6379 ``` 这里我们使用本地的Redis服务,端口为6379。 3. 然后,我们创建一个RedisConfig类,用于配置Redis连接池和RedisTemplate: ``` @Configuration public class RedisConfig { @Bean JedisConnectionFactory jedisConnectionFactory() { return new JedisConnectionFactory(); } @Bean public RedisTemplate<String, Object> redisTemplate() { RedisTemplate<String, Object> redisTemplate = new RedisTemplate<>(); redisTemplate.setConnectionFactory(jedisConnectionFactory()); redisTemplate.setKeySerializer(new StringRedisSerializer()); redisTemplate.setValueSerializer(new GenericJackson2JsonRedisSerializer()); return redisTemplate; } } ``` 这里我们使用Jedis作为Redis客户端,配置了连接工厂和RedisTemplate,将key和value都序列化为字符串。 4. 接下来,我们创建一个Controller类,用于添加和获取数据: ``` @RestController public class RedisController { @Autowired private RedisTemplate<String, Object> redisTemplate; @PostMapping("/add") public void add(@RequestParam String key, @RequestParam String value) { redisTemplate.opsForValue().set(key, value); } @GetMapping("/get") public Object get(@RequestParam String key) { return redisTemplate.opsForValue().get(key); } } ``` 这里我们使用了@Autowired注解将RedisTemplate注入到Controller,实现了添加和获取数据的接口。 5. 最后,我们启动Spring Boot应用,并访问http://localhost:8080/add?key=test&value=hello,添加数据。然后访问http://localhost:8080/get?key=test,获取数据,成功获取到刚才添加的内容。 这就是一个简单的Spring Boot与Redis集成的项目。 ### 回答2: Spring Boot是一个用于简化Spring应用程序开发的框架,它提供了快速搭建基于Spring的应用程序的能力。而Redis是一个开源的内存数据存储,它广泛用于缓存、消息队列、实时分析等场景。 在一个简单的Spring Boot Redis项目,我们首先需要引入Spring Boot和Redis的依赖。可以在项目的pom.xml文件添加相应的依赖项。然后,我们需要配置Redis连接,在application.properties(或application.yml)文件配置Redis的连接信息,如Redis的主机、端口、密码等。 接下来,我们可以创建一个简单的控制器,用于处理业务逻辑。在该控制器,我们可以通过注入RedisTemplate对象来操作Redis。通过RedisTemplate,我们可以执行常见的Redis操作,如设置值、获取值、删除值等等。 例如,我们可以创建一个UserController类,用于处理用户的注册和登录逻辑。在这个控制器,我们可以使用Redis来存储用户的相关信息,比如用户名、密码等。在用户注册时,我们将用户信息存储到Redis,并设置一个过期时间,以实现自动清除用户信息的功能。而在用户登录时,我们可以通过从Redis获取用户信息来验证用户的身份。 除了基本的CRUD操作,Spring Boot还提供了一些高级功能,如分布式缓存、分布式锁等。这些功能可以帮助我们更好地利用Redis来提升系统的性能和可靠性。例如,我们可以使用Redis作为缓存来提高数据的访问速度,同时利用Redis的分布式锁来保证数据的一致性。 总之,Spring Boot Redis简单项目可以帮助我们快速上手使用Redis,并且在开发过程提供了很多便利的特性。通过使用Spring Boot和Redis,我们可以轻松地构建出高效、可靠的应用程序。 ### 回答3: Spring Boot Redis是一个用于搭建分布式缓存系统的框架,能够帮助开发者快速搭建基于Redis的应用程序。下面是一个简单的Spring Boot Redis项目介绍。 首先,我们需要在pom.xml文件添加Spring Boot和Redis的依赖。 ```xml <dependencies> <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-data-redis</artifactId> </dependency> </dependencies> ``` 接下来,我们需要在application.properties或application.yml文件配置Redis的连接信息。 ```properties spring.redis.host=127.0.0.1 spring.redis.port=6379 ``` 然后,我们可以创建一个简单的实体类,并在类上添加注解来定义实体在Redis的存储方式。 ```java @RedisHash("user") public class User { @Id private Long id; private String name; private int age; //省略getter和setter方法 } ``` 接着,我们可以创建一个Repository接口来操作Redis的数据。 ```java public interface UserRepository extends CrudRepository<User, Long> { User findByName(String name); List<User> findByAgeGreaterThan(int age); } ``` 最后,我们可以在Controller使用Repository来操作Redis的数据。 ```java @RestController public class UserController { @Autowired private UserRepository userRepository; @GetMapping("/users/{name}") public User getUserByName(@PathVariable String name) { return userRepository.findByName(name); } @GetMapping("/users/age/{age}") public List<User> getUsersByAge(@PathVariable int age) { return userRepository.findByAgeGreaterThan(age); } } ``` 通过以上步骤,我们就可以创建一个简单的Spring Boot Redis项目。在该项目,我们可以使用Repository接口来对Redis的数据进行操作,比如查询用户信息、根据条件筛选用户等。这个项目可以作为学习和了解Spring Boot Redis入门案例,建议初学者可以动手试一试。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值