溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊(cè)×
其他方式登錄
點(diǎn)擊 登錄注冊(cè) 即表示同意《億速云用戶服務(wù)條款》

Java與SpringBoot對(duì)redis的使用方式是什么

發(fā)布時(shí)間:2022-08-04 09:22:38 來(lái)源:億速云 閱讀:146 作者:iii 欄目:開(kāi)發(fā)技術(shù)

今天小編給大家分享一下Java與SpringBoot對(duì)redis的使用方式是什么的相關(guān)知識(shí)點(diǎn),內(nèi)容詳細(xì),邏輯清晰,相信大部分人都還太了解這方面的知識(shí),所以分享這篇文章給大家參考一下,希望大家閱讀完這篇文章后有所收獲,下面我們一起來(lái)了解一下吧。

1.Java連接redis

redis支持哪些語(yǔ)言可以操作 (去redis官網(wǎng)查詢)

Java與SpringBoot對(duì)redis的使用方式是什么

Java與SpringBoot對(duì)redis的使用方式是什么

1.1 使用Jedis

 (1)添加jedis依賴

<dependency>
            <groupId>junit</groupId>
            <artifactId>junit</artifactId>
            <version>4.12</version>
            <!--只能在測(cè)試類中使用-->
            <scope>test</scope>
        </dependency>
        <dependency>
            <groupId>redis.clients</groupId>
            <artifactId>jedis</artifactId>
            <version>3.6.0</version>
        </dependency>

(2)代碼測(cè)試

public class TestJedis {
    @Test
    public void test01(){
        //連接redis--必須保證你的redis服務(wù)運(yùn)行遠(yuǎn)程連接
        //該對(duì)象把每個(gè)redis命令封裝成對(duì)應(yīng)的方法
        //注意端口號(hào)
        //xshell中的redis要運(yùn)行起來(lái),注意防火墻釋放端口號(hào),注意配置文件的修改
        Jedis jedis=new Jedis("192.168.1.16",6379);
        //對(duì)于字符串操作的命令
        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);

        //對(duì)于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(){
        //創(chuàng)建連接池的配置類
        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();//是否關(guān)閉池子
        }
        long end=System.currentTimeMillis();
        //是為了比較使用池子還是不使用快,結(jié)論是使用池子快
        System.out.println("總耗時(shí):"+(end-start));
    }

1.3 java連接redis集群模式

連接集群時(shí)要保證集群里面沒(méi)有存值, 要是存值需要?jiǎng)h除之前生成的文件(注意刪除干凈)

Java與SpringBoot對(duì)redis的使用方式是什么

還有就是放行對(duì)應(yīng)的端口:6001、6002、6003、6004、6005、6006,因?yàn)橹胺判械膶?shí)在10000端口,注意以上兩點(diǎn),才可以使用idea創(chuàng)建成功。

@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對(duì)redis的使用方式是什么

 2.SpringBoot整合redis

springboot對(duì)redis的操作封裝了兩個(gè)StringRedisTemplate和RedisTemplate類,StringRedisTemplate是RedisTemplate的子類,StringRedisTemplate它只能存儲(chǔ)字符串類型,無(wú)法存儲(chǔ)對(duì)象類型。要想用StringRedisTemplate存儲(chǔ)對(duì)象必須把對(duì)象轉(zhuǎn)為json字符串。

Java與SpringBoot對(duì)redis的使用方式是什么

springboot整合redis時(shí)提供了兩個(gè)模板工具類,StringRedisTemplate和RedisTemplate。

2.1 StringRedisTemplate

(1) 引入相關(guān)的依賴

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

(2)注入StringRedisTemplate該類對(duì)象

 @Autowired
 private StringRedisTemplate redisTemplate;

(3)使用StringRedisTemplate

該類把對(duì)每種數(shù)據(jù)類型的操作,單獨(dú)封了相應(yīng)的內(nèi)部類。

Java與SpringBoot對(duì)redis的使用方式是什么

此處不會(huì)有亂碼,因?yàn)橐呀?jīng)給它序列化方式和反序列化方式換成為String型。

@Autowired
    private StringRedisTemplate stringRedisTemplate;
 @Test
    public void test01(){
        //對(duì)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對(duì)于的所有的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");
        //對(duì)字符串?dāng)?shù)據(jù)類型的操作ValueOperations
        ValueOperations<String, String> forValue = stringRedisTemplate.opsForValue();
        //存儲(chǔ)字符串類型--key value long uint  setex()
        forValue.set("k1","張三",30, TimeUnit.SECONDS);
        //等價(jià)于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

此處會(huì)有亂碼,因?yàn)樗蛄谢绞胶头葱蛄谢绞侥J(rèn)為JDK。

@SpringBootTest
class SbredisApplicationTests02 {
    //當(dāng)你存儲(chǔ)的value類型為對(duì)象類型使用redisTemplate
    //存儲(chǔ)的value類型為字符串。StringRedisTemplate 驗(yàn)證碼
    @Autowired
    private RedisTemplate redisTemplate;
 
    @Test
    public void test01(){
        //必須認(rèn)為指定序列化方式
        redisTemplate.setKeySerializer(new StringRedisSerializer());
        redisTemplate.setValueSerializer(new Jackson2JsonRedisSerializer<Object>(Object.class));
 
        //對(duì)String類型操作類
        ValueOperations forValue = redisTemplate.opsForValue();
        //redis中key和value都變成了亂碼
        //key和value都沒(méi)有指定序列化方式,默認(rèn)采用jdk的序列化方式
        forValue.set("k1","張三");
 
        //value默認(rèn)采用jdk,類必須實(shí)現(xiàn)序列化接口
        forValue.set("k44",new User(1,"haha",12));
    }
}

上面的RedisTemplate需要每次都指定key value以及field的序列化方式,能不能搞一個(gè)配置類,已經(jīng)為RedisTemplate指定好序列化。以后再用就無(wú)需指定。

@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;
    }
}

以上就是“Java與SpringBoot對(duì)redis的使用方式是什么”這篇文章的所有內(nèi)容,感謝各位的閱讀!相信大家閱讀完這篇文章都有很大的收獲,小編每天都會(huì)為大家更新不同的知識(shí),如果還想學(xué)習(xí)更多的知識(shí),請(qǐng)關(guān)注億速云行業(yè)資訊頻道。

向AI問(wèn)一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI