我刚刚也了解了Redis和Redisson。基本上,我试图使用Redis在我的应用程序中存储用于授权的AcessTokens / RefreshTokens。所以我想用到期时间存储令牌。我使用Spring Data Redis来存储令牌,但是没有Api使Map中的每个条目都失效。我碰到了这篇文章Spring Data Redis Expire Key,因此查找了Redisson。我尝试了一个简单的maven java项目来测试到期时间。这是pom.xml:
<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
<modelVersion>4.0.0</modelVersion>
<groupId>com.bridgelabz</groupId>
<artifactId>redissonApp</artifactId>
<version>0.0.1-SNAPSHOT</version>
<packaging>jar</packaging>
<name>redissonApp</name>
<url>http://maven.apache.org</url>
<properties>
<project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
</properties>
<dependencies>
<dependency>
<groupId>junit</groupId>
<artifactId>junit</artifactId>
<version>3.8.1</version>
<scope>test</scope>
</dependency>
<dependency>
<groupId>org.redisson</groupId>
<artifactId>redisson</artifactId>
<version>3.3.0</version>
</dependency>
</dependencies>
</project>
Run Code Online (Sandbox Code Playgroud)
以下是令牌类
package com.bridgelabz.redissonApp;
public class Token {
private String accessToken;
private int id;
public Token() { }
public Token(String accessToken, int id) {
this.accessToken = accessToken;
this.id = id;
}
public String getAccessToken() {
return accessToken;
}
public void setAccessToken(String accessToken) {
this.accessToken = accessToken;
}
public int getId() {
return id;
}
public void setId(int id) {
this.id = id;
}
@Override
public String toString() {
return "Token [accessToken=" + accessToken + ", id=" + id + "]";
}
}
Run Code Online (Sandbox Code Playgroud)
这是我的演示应用程序:
package com.bridgelabz.redissonApp;
import java.util.concurrent.TimeUnit;
import org.redisson.Redisson;
import org.redisson.api.LocalCachedMapOptions;
import org.redisson.api.RMapCache;
import org.redisson.api.RedissonClient;
import org.redisson.api.LocalCachedMapOptions.EvictionPolicy;
import org.redisson.config.Config;
public class App {
public static void main(String[] args) {
Config config = new Config();
config.useSingleServer().setAddress("127.0.0.1:6379");
// LocalCachedMapOptions localCachedMapOptions =
// LocalCachedMapOptions.defaults()
// .evictionPolicy(EvictionPolicy.LFU);
RedissonClient redisson = Redisson.create(config);
try {
RMapCache<Integer, Token> map = redisson.getMapCache("TestMap");
Token myToken = new Token("abc", 1);
map.put(1, myToken, 10, TimeUnit.SECONDS);
System.out.println("Stored value with key 1 is: " + map.get(1));
}
finally {
redisson.shutdown();
}
}
}
Run Code Online (Sandbox Code Playgroud)
运行App.java之后,我得到的输出是:
SLF4J: Failed to load class "org.slf4j.impl.StaticLoggerBinder".
SLF4J: Defaulting to no-operation (NOP) logger implementation
SLF4J: See http://www.slf4j.org/codes.html#StaticLoggerBinder for further details.
Stored value with key 1 is: Token [accessToken=abc, id=1]
Run Code Online (Sandbox Code Playgroud)
只需注释一下放置代码并在10秒后运行应用程序,便可以得到部分期望的结果:
LF4J: Failed to load class "org.slf4j.impl.StaticLoggerBinder".
SLF4J: Defaulting to no-operation (NOP) logger implementation
SLF4J: See http://www.slf4j.org/codes.html#StaticLoggerBinder for further details.
Stored value with key 1 is: null
Run Code Online (Sandbox Code Playgroud)
但是当我运行redis-cli时,我仍然在输出中获取值:
127.0.0.1:6379> hget TestMap 1
"\x00\x00\x00\x00\x00\x00\x00\x00H\x00\x00\x00\x00\x00\x00\x00{\"@class\":\"com.bridgelabz.redissonApp.Token\",\"accessToken\":\"abc\",\"id\":1}"
Run Code Online (Sandbox Code Playgroud)
为什么还不能从Redis中删除密钥?仅供参考:所有内容都在我的本地计算机上进行了测试,仅包括redis。
Redis不支持为散列开箱即用的单个元素逐出。因此,Redisson建立了自己的解决方案并将其命名MapCache
。
因此,有了MapCache
,您现在有两个级别的到期控制:Redis提供的密钥级别和Redisson提供的字段级别。
在您的测试代码中:
RMapCache<Integer, Token> map = redisson.getMapCache("TestMap");
Token myToken = new Token("abc", 1);
map.put(1, myToken, 10, TimeUnit.SECONDS);
Run Code Online (Sandbox Code Playgroud)
您已1
在哈希字段上设置了到期时间TestMap
。这意味着哈希没有针对它设置有效期,而是针对它具有的字段之一设置了有效期。因此,当您使用进行查找时redis-cli
,哈希仍然存在。当Redisson到期过程开始时,它最终将消失。
归档时间: |
|
查看次数: |
1263 次 |
最近记录: |