Java操作Redis的方式有哪些

本篇內容介紹了“Java操作redis的方式有哪些”的有關知識,在實際案例的操作過程中,不少人都會遇到這樣的困境,接下來就讓小編帶領大家學習一下如何處理這些情況吧!希望大家仔細閱讀,能夠學有所成!

成都創新互聯公司-專業網站定制、快速模板網站建設、高性價比霞浦網站開發、企業建站全套包干低至880元,成熟完善的模板庫,直接使用。一站式霞浦網站制作公司更省心,省錢,快速模板網站建設找我們,業務覆蓋霞浦地區。費用合理售后完善,10多年實體公司更值得信賴。

Jedis操作Redis

創建idea工程

建立一個Maven項目,導入Jedis依賴即可:

<!-- 導入Jedis依賴 -->
        <dependency>
            <groupId>redis.clients</groupId>
            <artifactId>jedis</artifactId>
            <version>3.2.0</version>
        </dependency>

導入依賴之后創建JedisDemo測試類

package com.vleus.jedis;

import redis.clients.jedis.Jedis;

/**
 * @author vleus
 * @date 2021年07月03日 23:52
 */
public class JedisDemo1 {

    public static void main(String[] args) {

        //創建Jedis對象
        Jedis jedis = new Jedis("192.168.37.139",6379);
		//測試Jedis客戶端是否能夠連接上Redis
        System.out.println(jedis.ping());
    }
}

輸出PONG表示連接成功~
Java操作Redis的方式有哪些

注意:

第一次測試時如果連接不上虛擬機的Redis,報連接不上的異常有兩個問題需要解決:

  • 首先,kill掉Redis的進程,然后修改Reids的啟動使用的配置文件

    • 注釋掉bind的配置;

    • 同時將protected-mode的值改為no
      Java操作Redis的方式有哪些

  • 第二步,關掉Linux的防火墻(這里僅是在做學習時使用,生產環境別這么干)

systemctl stop firewalld
systemctl disable firewalld

反正我是這么解決的。

Jedis操作Redis

1、創建idea springboot項目,引入依賴

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

        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-test</artifactId>
            <scope>test</scope>
        </dependency>

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

        <!-- spring2.x繼承redis需要commons-pool -->
        <dependency>
            <groupId>org.apache.commons</groupId>
            <artifactId>commons-pool2</artifactId>
            <version>2.6.2</version>
        </dependency>
		<dependency>
            <groupId>com.fasterxml.jackson.core</groupId>
            <artifactId>jackson-databind</artifactId>
            <version>2.8.3</version>
        </dependency>

    </dependencies>

2、創建RedisConfig配置類

@EnableCaching
@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序列化
        template.setHashValueSerializer(jackson2JsonRedisSerializer);
        return template;
    }

    @Bean
    public CacheManager cacheManager(RedisConnectionFactory factory) {
        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);
        // 配置序列化(解決亂碼的問題),過期時間600秒
        RedisCacheConfiguration config = RedisCacheConfiguration.defaultCacheConfig()
                .entryTtl(Duration.ofSeconds(600))
                .serializeKeysWith(RedisSerializationContext.SerializationPair.fromSerializer(redisSerializer))
                .serializeValuesWith(RedisSerializationContext.SerializationPair.fromSerializer(jackson2JsonRedisSerializer))
                .disableCachingNullValues();
        RedisCacheManager cacheManager = RedisCacheManager.builder(factory)
                .cacheDefaults(config)
                .build();
        return cacheManager;
    }

}

簡單的Controller測試

/**
 * @author vleus
 * @date 2021年07月04日 13:06
 */
@RestController
@RequestMapping(value = "/redisTest")
public class RedisTestController {

    @Resource
    private RedisTemplate redisTemplate;

    @GetMapping
    public String testRedis() {
        //設置值到redis
        redisTemplate.opsForValue().set("name","jack");
        //從redis中獲取值
        String name = (String) redisTemplate.opsForValue().get("name");
        return name;
    }
}

“Java操作Redis的方式有哪些”的內容就介紹到這里了,感謝大家的閱讀。如果想了解更多行業相關的知識可以關注創新互聯網站,小編將為大家輸出更多高質量的實用文章!

網站名稱:Java操作Redis的方式有哪些
當前URL:http://m.kartarina.com/article16/jedigg.html

成都網站建設公司_創新互聯,為您提供面包屑導航電子商務、網站策劃、ChatGPT、外貿建站網站制作

廣告

聲明:本網站發布的內容(圖片、視頻和文字)以用戶投稿、用戶轉載內容為主,如果涉及侵權請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網站立場,如需處理請聯系客服。電話:028-86922220;郵箱:631063699@qq.com。內容未經允許不得轉載,或轉載時需注明來源: 創新互聯

h5響應式網站建設
主站蜘蛛池模板: 人妻少妇看A偷人无码电影| 无码中文在线二区免费| 无码任你躁久久久久久| 国产成人年无码AV片在线观看| 97久久精品无码一区二区天美| 亚洲AV无码乱码精品国产| 亚洲gv猛男gv无码男同短文| 国产精品无码翘臀在线观看| 亚洲大尺度无码无码专区| 成人免费无码大片a毛片软件| 无码专区—VA亚洲V天堂| 一本大道无码人妻精品专区| 精品高潮呻吟99av无码视频| 亚洲一级特黄大片无码毛片| 亚洲天堂2017无码中文| 中文字幕乱码无码人妻系列蜜桃| 精品无码成人网站久久久久久| 亚洲国产超清无码专区| 亚洲AV无码成人精品区蜜桃| 国产AV无码专区亚洲AV手机麻豆| 熟妇人妻无码xxx视频| 亚洲AV无码乱码在线观看代蜜桃| 国产精品免费无遮挡无码永久视频| 伊人蕉久中文字幕无码专区 | 亚洲午夜无码AV毛片久久| 亚洲最大av资源站无码av网址| 国产AV一区二区三区无码野战 | 亚洲国产精品成人精品无码区在线| 人妻精品无码一区二区三区| 精品国产V无码大片在线看| 69久久精品无码一区二区| 日韩精品无码熟人妻视频| 无码人妻精品一区二区| 无码AV波多野结衣久久| 久久午夜无码鲁丝片直播午夜精品| 亚洲精品无码mv在线观看网站 | 亚洲AV综合色区无码一区爱AV| 中文字幕人妻无码一夲道| 亚洲欧洲精品无码AV| 国产50部艳色禁片无码| 人妻aⅴ无码一区二区三区|