中文字幕av专区_日韩电影在线播放_精品国产精品久久一区免费式_av在线免费观看网站

溫馨提示×

溫馨提示×

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

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

SpringBoot集成Redis的過程介紹

發布時間:2021-06-02 09:23:06 來源:億速云 閱讀:210 作者:栢白 欄目:開發技術

本篇文章和大家了解一下SpringBoot集成Redis的過程介紹。有一定的參考價值,有需要的朋友可以參考一下,希望對大家有所幫助。

Redis 介紹: Redis 服務

Redis (REmote Dictionary Server) 是一個由Salvatore Sanfilippo 完成的key-value存儲系統,是跨平臺的非關系型數據庫

Redis 是一個開源的使用ANSI C語言編寫、遵循BSD 協議的、支持網絡、可基于內存、分布式、可選擇持久性的鍵值對存儲數據庫,并提供多語言的API。

Redis 通常被認為是數據結構服務器,其值可以是字符串、哈希、列表、集合以及有序集合。

Redis 優點

異常快,每秒可以執行大約110000次寫(set)操作

每秒可執行大約81000次讀(get)操作

支持豐富的數據結構

操作具有原子性, 所有Redis 操作都是原子操作,這確保了兩個客戶端并發訪問,Redis 服務器能接收更新的值。

多使用工具,緩存,消息隊列(Redis 本地支持發布/訂閱),應用程序中的任何短期數據。

Redis 安裝

下載地址:

https://github.com/MSOpenTech/redis/releases

Redis 支持32位和64 位,下載完成后,解壓后,文件夾下面包含許多子文件,打開cmd 窗口,將其切換到redis 目錄下,輸入命名:

D:\sdk\Redis-x64-5.0.9  redis-server.exe  redis.windows.conf

Redis是什么

Redis是現在最受歡迎的NoSQL數據庫之一,Redis是一個使用ANSI C編寫的開源、包含多種數據結構、支持網絡、基于內存、可選持久性的鍵值對存儲數據庫,其具備如下特性:

  • 基于內存運行,性能高效

  • 支持分布式,理論上可以無限擴展

  • key-value存儲系統

  • 開源的使用ANSI C語言編寫、遵守BSD協議、支持網絡、可基于內存亦可持久化的日志型、Key-Value數據庫,并提供多種語言的API

相比于其他數據庫類型,Redis具備的特點是:

  • C/S通訊模型

  • 單進程單線程模型

  • 豐富的數據類型

  • 操作具有原子性

  • 持久化

  • 高并發讀寫

  • 支持lua腳本

如果想使用redis 啟動更加容易的話,可以使用 將redis 安裝路徑加入到環境變量中,直接點擊 redis-server.exe 即可啟動redis 服務。

SpringBoot 集成Redis 過程

1. 在pom.xml 中配置相關依賴 jar

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

2.在SpringBoot 中配置核心文件

在application.properties 文件下添加配置redis 信息

# 配置redis
spring.redis.host:localhost
spring.redis.password=
spring.redis.port=6379

3. Redis 配置類及其使用

Redis 配置類

// RedisConfig redisconfig 配置
@Configuration
public class RedisConfig {
    /**
     * key redis serializer: {@link StringRedisSerializer} and
     * key redis serializer: {@link Jackson2JsonRedisSerializer}
     **/
    @Bean
    public RedisTemplate<String, Object> redisTemplate(RedisConnectionFactory factory) {
        // 創建對象
        RedisTemplate<String, Object> template = new RedisTemplate<>();
        Jackson2JsonRedisSerializer valueRedisSerializer = new Jackson2JsonRedisSerializer(Object.class);
        //設置Redis的value為json格式,并存儲對象信息的序列化類型
        ObjectMapper objectMapper = new ObjectMapper();
        objectMapper.setVisibility(PropertyAccessor.ALL, JsonAutoDetect.Visibility.ANY);
        objectMapper.enableDefaultTyping(ObjectMapper.DefaultTyping.NON_FINAL);
        valueRedisSerializer.setObjectMapper(objectMapper);

        // 創建一個keyRedisSerializer
        RedisSerializer keyRedisSerializer = new StringRedisSerializer();
        // 設置信息
        template.setKeySerializer(keyRedisSerializer);
        template.setValueSerializer(valueRedisSerializer);
        template.setHashKeySerializer(keyRedisSerializer);
        template.setHashValueSerializer(valueRedisSerializer);
        template.setConnectionFactory(factory);
        template.afterPropertiesSet();
        return template;
    }

    // redisUtils()  方法
    @Bean
    public RedisUtils redisUtils(@Autowired RedisTemplate redisTemplate) {
        return new RedisUtils(redisTemplate);
    }
}

Redis 工具類, 首先redis 的增刪改查等操作,針對多種數據類型的數據

/**
 * redis工具類
 *
 * @author Jone
 */
// RedisUtils
@Slf4j
public class RedisUtils {

    // 初始化變量
    private static Logger logger = LoggerFactory.getLogger(RedisUtils.class);


    private static RedisTemplate redisTemplate;

    public RedisUtils(RedisTemplate redisTemplate) {
        this.redisTemplate = redisTemplate;
    }

    // =============================common============================


    /**
     * 判斷key是否存在
     *
     * @param key 鍵
     * @return true 存在 false不存在
     */
    public Boolean hasKey(String key) {
        try {
            return redisTemplate.hasKey(key);
        } catch (Exception e) {
            logger.error("判斷key是否存在異常: {}", e);
            return false;
        }
    }

    /**
     * 普通緩存獲取
     *
     * @param key 鍵
     * @return 值
     */
    public Object get(String key) {
        return key == null ? null : redisTemplate.opsForValue().get(key);
    }

    /**
     * 刪除
     * @param key
     * @return
     */
    public boolean del(String ... key){
        if(key!=null&&key.length>0){

                redisTemplate.delete(key[0]);
                return true;
            }else{
                redisTemplate.delete(CollectionUtils.arrayToList(key));
                return true;
            }
        }
        return false;
    }

    // SET JIHE
    public Set getKeys(){
       return redisTemplate.keys("*");
    }

    /**
     * 普通緩存放入
     *
     * @param key   鍵
     * @param value 值
     * @return true成功 false失敗
     */
    public Boolean set(String key, Object value) {
        try {
            redisTemplate.opsForValue().set(key, value);
            return true;
        } catch (Exception e) {
            logger.error("set異常: {}", e);
            return false;
        }
    }
}

配置完備之后,自動配置RedisTemplate ,需要操作redis 的類中注入redisTeplate,如下所示:

// 使用RedisTemplate                                                                                
@Autowired
private RedisTemplate<String, String> redisTemplate;

@Autowired 
private RedisTemplate<Object, Object> redisTemplate;

以上就是SpringBoot集成Redis的過程介紹的簡略介紹,當然詳細使用上面的不同還得要大家自己使用過才領會。如果想了解更多,歡迎關注億速云行業資訊頻道哦!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

屯门区| 绵阳市| 荥经县| 肥乡县| 衡南县| 瓦房店市| 商都县| 江门市| 淮北市| 尼勒克县| 沈阳市| 错那县| 藁城市| 铁岭县| 万年县| 临邑县| 海口市| 五华县| 广安市| 岑溪市| 资源县| 应城市| 新余市| 哈尔滨市| 辽宁省| 同江市| 搜索| 萨嘎县| 桃源县| 湖南省| 玉环县| 西宁市| 郴州市| 三原县| 海林市| 富源县| 舞阳县| 称多县| 白城市| 涞源县| 镇江市|