- 1 redis
- 1.1 特點
- 1.2 支援的資料型別
- 1.3 應用場景
- 2 安裝redis
- 2.1 docker
- 3 視覺化軟體
- 3.1 Redis Desktop Manager(RDM)
- 3.2 QuickRedis (推薦)
- 4 SpringBoot整合
- 4.1 引入redis
- 4.2. 操作redis
- 4.2.1 直接操作
- 4.3 分散式會話場景(Resis-Session)
1 redis
redis是一個用C語言開發的,基於記憶體結構進行鍵值對資料儲存、高效能、非關係型NoSQL資料庫
官網: https://redis.io/
1.1 特點
- 基於記憶體儲存,資料讀寫效率很高
- 本身支援持久化
- 雖然基於key-value儲存,但是支援多種資料型別
- 支援叢集、支援主從模式
1.2 支援的資料型別
Redis是以鍵值對形式,進行資料儲存,同時value也支援多種資料型別
- String 字串
- hash 對映
- list 列表
- set 集合
- zset 有序集合
1.3 應用場景
-
分散式會話
在分散式系統中,可以使用redis實現session
(共享快取) -
快取
提高訪問資料、降低資料庫壓力 -
分散式鎖
基於redis的操作特徵,可以實現分散式鎖功能 -
點贊、排行榜、計數器
對資料實時讀寫要求比較高,但對資料庫一致性要求不是很高的功能場景 -
訊息中介軟體
實現應用之間的通訊
2 安裝redis
官網上有根據windows、linux、mac 等環境安裝redis,這裡主要介紹docker安裝方式,操作更加方便好用
2.1 docker
-
安裝docker
- Windows安裝:https://www.runoob.com/docker/windows-docker-install.html
- Centos安裝:https://www.runoob.com/docker/centos-docker-install.html
- Mac安裝:https://www.runoob.com/docker/macos-docker-install.html
-
檢視docker版本
網址:https://hub.docker.com/_/redis?tab=tags
-
拉取映象
docker pull redis
-
建立容器
docker run -itd --name redis_1 -p 6379:6379 redis
-
進入容器
docker exec -it redis_1 /bin/bash
3 視覺化軟體
3.1 Redis Desktop Manager(RDM)
-
Github
https://github.com/RedisInsight/RedisDesktopManager
-
安裝文件
https://docs.resp.app/en/latest/install/
3.2 QuickRedis (推薦)
是一款國產開源的 免費 Redis 視覺化管理工具,支援直連、哨兵、叢集模式,支援億萬數量級的 key,支援 Windows 、 Mac OS X 和 Linux 下執行。
-
官網: https://quick123.net/
-
下載地址:
https://gitee.com/quick123official/quick_redis_blog/releases/
https://github.com/quick123official/quick_redis_blog/releases/
4 SpringBoot整合
4.1 引入redis
開啟pom.xml
檔案
<!-- https://mvnrepository.com/artifact/org.springframework.boot/spring-boot-starter-data-redis -->
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-data-redis</artifactId>
<version>2.7.15</version>
</dependency>
4.2. 操作redis
4.2.1 直接操作
-
定義
stringRedisTemplate
@Autowired private StringRedisTemplate stringRedisTemplate;
-
寫入
// 過期時間,單位:分 public final static int Redis_Key_Login_Expire_Time = 30 ; public final static Straing key = 'key_1'; public final static Straing content = '這是儲存內容'; stringRedisTemplate.boundValueOps(key).set(content, Constant.Redis_Key_Login_Expire_Time, TimeUnit.MINUTES);
-
讀取
public final static Straing key = 'key_1'; String content = stringRedisTemplate.boundValueOps(key).get();
4.3 分散式會話場景(Resis-Session)
引入 spring-session 和 redis 的整合,使得自動將 session 儲存到 redis 中
PS: 直接配置就好,不需要改動程式碼
-
引入依賴包
根據你的SpringBoot版本(我的v2.7.15)選擇依賴,儘量保持一致
<!-- https://mvnrepository.com/artifact/org.springframework.session/spring-session-data-redis --> <dependency> <groupId>org.springframework.session</groupId> <artifactId>spring-session-data-redis</artifactId> <version>2.7.4</version> </dependency>
-
修改
application.yml
配置- spring-session 儲存配置
- tore-type:
- none : 預設值,表示儲存在單臺伺服器上
- Redis : 表示儲存在redis上
spring: # redis 配置 redis: host: localhost port: 6379 password: 123456 database: 2 # Redis共有16個資料(0-15) session: timeout: 86400 # session失效時間,單位秒,1天 store-type: redis # 指定儲存方式
-
呼叫
public User doLogin(String userAccount, String userPassword, HttpServletRequest request) { // ... // 儲存session String key = "userLoginState"; String value = "這是儲存內容" request.getSession().setAttribute(key,value); return null; }
-
儲存成效果
本文由部落格一文多發平臺 OpenWrite 釋出!