Java与SpringBoot对redis的使用方式

作者:青柠果 时间:2021-06-11 19:23:39 

1.Java连接redis

redis支持哪些语言可以操作 (去redis官网查询)

Java与SpringBoot对redis的使用方式

Java与SpringBoot对redis的使用方式

1.1 使用Jedis

 (1)添加jedis依赖

<dependency>
           <groupId>junit</groupId>
           <artifactId>junit</artifactId>
           <version>4.12</version>
           <!--只能在测试类中使用-->
           <scope>test</scope>
       </dependency>
       <dependency>
           <groupId>redis.clients</groupId>
           <artifactId>jedis</artifactId>
           <version>3.6.0</version>
       </dependency>

(2)代码测试

public class TestJedis {
   @Test
   public void test01(){
       //连接redis--必须保证你的redis服务运行远程连接
       //该对象把每个redis命令封装成对应的方法
       //注意端口号
       //xshell中的redis要运行起来,注意防火墙释放端口号,注意配置文件的修改
       Jedis jedis=new Jedis("192.168.1.16",6379);
       //对于字符串操作的命令
       String set = jedis.set("k1", "v1");
       System.out.println(set);
       String set1 = jedis.set("k2", "v2");
       System.out.println(set1);
       String set2 = jedis.set("k3", "v3");
       System.out.println(set2);

//对于hash的操作
       jedis.hset("k4","name","小花");
       Long hset = jedis.hset("k4", "age", "18");
       System.out.println(hset);

Map<String ,String> map=new HashMap<>();
       map.put("name","小明");
       map.put("age","20");
       Long k = jedis.hset("k5", map);
       System.out.println(k);
       jedis.close();
   }
}

1.2 使用连接池连接redis

@Test
   public void test02(){
       //创建连接池的配置类
       JedisPoolConfig jedisPoolConfig=new JedisPoolConfig();
       jedisPoolConfig.setMaxIdle(20);
       jedisPoolConfig.setMinIdle(5);
       jedisPoolConfig.setMaxWait(Duration.ofMillis(3000));
       JedisPool jedisPool=new JedisPool(jedisPoolConfig,"192.168.1.16",6379);
       long start = System.currentTimeMillis();

for (int i = 0; i < 1000; i++) {
           //从jedis连接池获取资源
           Jedis jedis=jedisPool.getResource();
           String ping = jedis.ping();
           jedis.close();//是否关闭池子
       }
       long end=System.currentTimeMillis();
       //是为了比较使用池子还是不使用快,结论是使用池子快
       System.out.println("总耗时:"+(end-start));
   }

1.3 java连接redis集群模式

连接集群时要保证集群里面没有存值, 要是存值需要删除之前生成的文件(注意删除干净)

Java与SpringBoot对redis的使用方式

还有就是放行对应的端口:6001、6002、6003、6004、6005、6006,因为之前放行的实在10000端口,注意以上两点,才可以使用idea创建成功。

@Test
   public void test03(){
     Set<HostAndPort> nodes=new HashSet<>();
     nodes.add(new HostAndPort("192.168.227.175",6001));
     nodes.add(new HostAndPort("192.168.227.175",6002));
     nodes.add(new HostAndPort("192.168.227.175",6003));
     nodes.add(new HostAndPort("192.168.227.175",6004));
     nodes.add(new HostAndPort("192.168.227.175",6005));
     nodes.add(new HostAndPort("192.168.227.175",6006));
       JedisCluster jedisCluster=new JedisCluster(nodes);
     jedisCluster.set("k6", "小老虎和小兔子");
       jedisCluster.close();
   }

Java与SpringBoot对redis的使用方式

 2.SpringBoot整合redis

springboot对redis的操作封装了两个StringRedisTemplate和RedisTemplate类,StringRedisTemplate是RedisTemplate的子类,StringRedisTemplate它只能存储字符串类型,无法存储对象类型。要想用StringRedisTemplate存储对象必须把对象转为json字符串。

Java与SpringBoot对redis的使用方式

springboot整合redis时提供了两个模板工具类,StringRedisTemplate和RedisTemplate。

2.1 StringRedisTemplate

(1) 引入相关的依赖

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

(2)注入StringRedisTemplate该类对象

@Autowired
private StringRedisTemplate redisTemplate;

(3)使用StringRedisTemplate

该类把对每种数据类型的操作,单独封了相应的内部类。

Java与SpringBoot对redis的使用方式

此处不会有乱码,因为已经给它序列化方式和反序列化方式换成为String型。

@Autowired
   private StringRedisTemplate stringRedisTemplate;
@Test
   public void test01(){
       //对hash类型的操作
       HashOperations<String, Object, Object> forHash = stringRedisTemplate.opsForHash();
       forHash.put("k1","name","张三");
       forHash.put("k1","age","15");
       Map<String,String> map=new HashMap<>();
       map.put("name","李四");
       map.put("age","25");
       forHash.putAll("k36",map);

Object o = forHash.get("k1", "name");
       System.out.println(o);

Set<Object> k1 = forHash.keys("k1");
       System.out.println(k1);

List<Object> k11 = forHash.values("k1");
       System.out.println(k11);

//获取k1对于的所有的field和value
       Map<Object, Object> k12 = forHash.entries("k1");
       System.out.println(k12);
   }
   @Test
   void contextLoads() {
       //删除指定的key
      // stringRedisTemplate.delete("k");
       //查看所有的key
       //stringRedisTemplate.keys("k");
       //是否存在指定的key
       //stringRedisTemplate.hasKey("k");
       //对字符串数据类型的操作ValueOperations
       ValueOperations<String, String> forValue = stringRedisTemplate.opsForValue();
       //存储字符串类型--key value long uint  setex()
       forValue.set("k1","张三",30, TimeUnit.SECONDS);
       //等价于setnx 存入成功返回true ,失败返回false
       Boolean absent = forValue.setIfAbsent("k11", "李四", 30, TimeUnit.SECONDS);
       System.out.println(absent);
       //append拼接
       Integer append = forValue.append("k11", "真好看");
       String k11 = forValue.get("k11");
       System.out.println(k11);

}

2.2 RedisTemplate

此处会有乱码,因为它序列化方式和反序列化方式默认为JDK。

@SpringBootTest
class SbredisApplicationTests02 {
   //当你存储的value类型为对象类型使用redisTemplate
   //存储的value类型为字符串。StringRedisTemplate 验证码
   @Autowired
   private RedisTemplate redisTemplate;

@Test
   public void test01(){
       //必须认为指定序列化方式
       redisTemplate.setKeySerializer(new StringRedisSerializer());
       redisTemplate.setValueSerializer(new Jackson2JsonRedisSerializer<Object>(Object.class));

//对String类型操作类
       ValueOperations forValue = redisTemplate.opsForValue();
       //redis中key和value都变成了乱码
       //key和value都没有指定序列化方式,默认采用jdk的序列化方式
       forValue.set("k1","张三");

//value默认采用jdk,类必须实现序列化接口
       forValue.set("k44",new User(1,"haha",12));
   }
}

上面的RedisTemplate需要每次都指定key value以及field的序列化方式,能不能搞一个配置类,已经为RedisTemplate指定好序列化。以后再用就无需指定。

@Configuration
public class RedisConfig {
   @Bean
   public RedisTemplate<String, Object> redisTemplate(RedisConnectionFactory factory) {
       RedisTemplate<String, Object> template = new RedisTemplate<>();
       RedisSerializer<String> redisSerializer = new StringRedisSerializer();
       Jackson2JsonRedisSerializer jackson2JsonRedisSerializer = new Jackson2JsonRedisSerializer(Object.class);
       ObjectMapper om = new ObjectMapper();
       om.setVisibility(PropertyAccessor.ALL, JsonAutoDetect.Visibility.ANY);
       om.enableDefaultTyping(ObjectMapper.DefaultTyping.NON_FINAL);
       jackson2JsonRedisSerializer.setObjectMapper(om);
       template.setConnectionFactory(factory);
       //key序列化方式
       template.setKeySerializer(redisSerializer);
       //value序列化
       template.setValueSerializer(jackson2JsonRedisSerializer);
       //value hashmap序列化  filed value
       template.setHashValueSerializer(jackson2JsonRedisSerializer);
       template.setHashKeySerializer(redisSerializer);
       return template;
   }
}

来源:https://blog.csdn.net/qq_50896786/article/details/126111148

标签:Java,redis,使用
0
投稿

猜你喜欢

  • Spring boot如何快速的配置多个Redis数据源

    2023-05-12 18:27:32
  • 深入剖析Java中String类的concat方法

    2023-06-02 07:07:13
  • Java常用的八种排序算法及代码实现+图解

    2022-04-09 13:30:06
  • Android zygote启动流程详解

    2023-09-13 07:44:12
  • C++版本基于ros将文件夹中的图像转换为bag包

    2021-11-13 07:15:59
  • SpringCloud Feign 服务调用的实现

    2023-09-18 11:07:35
  • C#微信公众号开发之接收事件推送与消息排重的方法

    2022-01-31 08:44:46
  • 解决Android MediaRecorder录制视频过短问题

    2023-04-24 01:47:56
  • Java数据结构之ArrayList从顺序表到实现

    2022-06-14 00:53:25
  • 运行java的class文件方法详解

    2021-07-29 03:53:48
  • mybatis 报错显示sql中有两个limit的解决

    2022-04-30 02:50:49
  • Android实现界面跳转功能

    2022-05-07 21:51:32
  • Android WorkManager浅谈

    2023-03-24 11:26:46
  • Java编程复用类代码详解

    2021-09-13 10:06:34
  • MyEclipse2018中安装Mybatis generator插件的实现步骤

    2022-02-17 03:47:37
  • C# MVC 微信支付教程系列之公众号支付代码

    2022-11-29 09:14:29
  • 关于Eureka的概念作用以及用法详解

    2023-08-23 15:17:29
  • Java Shutdown Hook场景使用及源码分析

    2023-05-19 06:01:30
  • maven的pom.xml中profiles的作用详解

    2022-07-03 20:40:54
  • SpringMVC拦截器创建配置及执行顺序

    2023-06-06 20:41:16
  • asp之家 软件编程 m.aspxhome.com