Redis-Session无状态会话技术
生活随笔
收集整理的這篇文章主要介紹了
Redis-Session无状态会话技术
小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,幫大家做個(gè)參考.
1 有狀態(tài)Session
2 無狀態(tài)Session
3 Redis-Session
3.1 使用Redis-session的好處
- 用戶認(rèn)證信息存儲(chǔ)到redis緩存中,形成無狀態(tài)會(huì)話
- 便于擴(kuò)展,當(dāng)單體應(yīng)用擴(kuò)展為集群會(huì)相當(dāng)方便
- 便于權(quán)限驗(yàn)證
3.2 Redis安裝
- 將Redis安裝包上傳到服務(wù)器
- 解壓安裝包
- 安裝GCC
- 進(jìn)入redis安裝目錄,執(zhí)行編譯
- 安裝
3.3 前臺(tái)啟動(dòng)
cd /usr/local/redis/bin/ ./redis-server3.4 后他啟動(dòng)
- 將解壓目錄的redis.conf復(fù)制到安裝目錄
- 修改配置文件 redis.conf
- 后臺(tái)啟動(dòng)
- 本地登錄測(cè)試
- 客戶端登錄
- 默認(rèn)存儲(chǔ)在db0
4 Spring Boot 集成 Redis
4.1 依賴
<!-- 引入 redis 依賴 --><dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-data-redis</artifactId></dependency><dependency><groupId>redis.clients</groupId><artifactId>jedis</artifactId><version>2.9.0</version></dependency><dependency><groupId>org.springframework.data</groupId><artifactId>spring-data-redis</artifactId><version>1.8.7.RELEASE</version></dependency>4.2 基本配置
############################################################ # # REDIS 配置 # ############################################################ # Redis數(shù)據(jù)庫索引(默認(rèn)為0) spring.redis.database=1 # Redis服務(wù)器地址 spring.redis.host=121.36.70.255 # Redis服務(wù)器連接端口 spring.redis.port=6379 # Redis服務(wù)器連接密碼(默認(rèn)為空) spring.redis.password=imooc # 連接池最大連接數(shù)(使用負(fù)值表示沒有限制) spring.redis.pool.max-active=1000 # 連接池最大阻塞等待時(shí)間(使用負(fù)值表示沒有限制) spring.redis.pool.max-wait=-1 # 連接池中的最大空閑連接 spring.redis.pool.max-idle=10 # 連接池中的最小空閑連接 spring.redis.pool.min-idle=2 # 連接超時(shí)時(shí)間(毫秒) spring.redis.timeout=04.3 工具類
package com.imooc.utils;import java.util.Map; import java.util.Set; import java.util.concurrent.TimeUnit;import org.springframework.beans.factory.annotation.Autowired; import org.springframework.data.redis.core.StringRedisTemplate; import org.springframework.stereotype.Component;/*** @Description: 使用redisTemplate的操作實(shí)現(xiàn)類 */ @Component public class RedisOperator {// @Autowired // private RedisTemplate<String, Object> redisTemplate;@Autowiredprivate StringRedisTemplate redisTemplate;// Key(鍵),簡(jiǎn)單的key-value操作/*** 實(shí)現(xiàn)命令:TTL key,以秒為單位,返回給定 key的剩余生存時(shí)間(TTL, time to live)。* * @param key* @return*/public long ttl(String key) {return redisTemplate.getExpire(key);}/*** 實(shí)現(xiàn)命令:expire 設(shè)置過期時(shí)間,單位秒* * @param key* @return*/public void expire(String key, long timeout) {redisTemplate.expire(key, timeout, TimeUnit.SECONDS);}/*** 實(shí)現(xiàn)命令:INCR key,增加key一次* * @param key* @return*/public long incr(String key, long delta) {return redisTemplate.opsForValue().increment(key, delta);}/*** 實(shí)現(xiàn)命令:KEYS pattern,查找所有符合給定模式 pattern的 key*/public Set<String> keys(String pattern) {return redisTemplate.keys(pattern);}/*** 實(shí)現(xiàn)命令:DEL key,刪除一個(gè)key* * @param key*/public void del(String key) {redisTemplate.delete(key);}// String(字符串)/*** 實(shí)現(xiàn)命令:SET key value,設(shè)置一個(gè)key-value(將字符串值 value關(guān)聯(lián)到 key)* * @param key* @param value*/public void set(String key, String value) {redisTemplate.opsForValue().set(key, value);}/*** 實(shí)現(xiàn)命令:SET key value EX seconds,設(shè)置key-value和超時(shí)時(shí)間(秒)* * @param key* @param value* @param timeout* (以秒為單位)*/public void set(String key, String value, long timeout) {redisTemplate.opsForValue().set(key, value, timeout, TimeUnit.SECONDS);}/*** 實(shí)現(xiàn)命令:GET key,返回 key所關(guān)聯(lián)的字符串值。* * @param key* @return value*/public String get(String key) {return (String)redisTemplate.opsForValue().get(key);}// Hash(哈希表)/*** 實(shí)現(xiàn)命令:HSET key field value,將哈希表 key中的域 field的值設(shè)為 value* * @param key* @param field* @param value*/public void hset(String key, String field, Object value) {redisTemplate.opsForHash().put(key, field, value);}/*** 實(shí)現(xiàn)命令:HGET key field,返回哈希表 key中給定域 field的值* * @param key* @param field* @return*/public String hget(String key, String field) {return (String) redisTemplate.opsForHash().get(key, field);}/*** 實(shí)現(xiàn)命令:HDEL key field [field ...],刪除哈希表 key 中的一個(gè)或多個(gè)指定域,不存在的域?qū)⒈缓雎浴? * @param key* @param fields*/public void hdel(String key, Object... fields) {redisTemplate.opsForHash().delete(key, fields);}/*** 實(shí)現(xiàn)命令:HGETALL key,返回哈希表 key中,所有的域和值。* * @param key* @return*/public Map<Object, Object> hgetall(String key) {return redisTemplate.opsForHash().entries(key);}// List(列表)/*** 實(shí)現(xiàn)命令:LPUSH key value,將一個(gè)值 value插入到列表 key的表頭* * @param key* @param value* @return 執(zhí)行 LPUSH命令后,列表的長(zhǎng)度。*/public long lpush(String key, String value) {return redisTemplate.opsForList().leftPush(key, value);}/*** 實(shí)現(xiàn)命令:LPOP key,移除并返回列表 key的頭元素。* * @param key* @return 列表key的頭元素。*/public String lpop(String key) {return (String)redisTemplate.opsForList().leftPop(key);}/*** 實(shí)現(xiàn)命令:RPUSH key value,將一個(gè)值 value插入到列表 key的表尾(最右邊)。* * @param key* @param value* @return 執(zhí)行 LPUSH命令后,列表的長(zhǎng)度。*/public long rpush(String key, String value) {return redisTemplate.opsForList().rightPush(key, value);}}總結(jié)
以上是生活随笔為你收集整理的Redis-Session无状态会话技术的全部?jī)?nèi)容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 【Java基础】递归输出目录下所有文件路
- 下一篇: Spring Boot项目(Maven\