电商系统,Redis做缓存时===>通用缓存key的封装

Redis做缓存时,可能会设置很多key,来标识我们需要存取的数据,如何能够保证key的唯一呢?

我们可用考虑给key加一个前缀,例如:用户相关的缓存都以用户为前缀,公司所有的缓存都以公司为前缀......。我们在key前拼接上前缀,作为redis中真正读写的key,这样是不是就能使得key唯一且易区分呢?

这里,我们采用模板模式来封装key。

接口<---抽象类<---实现类

接口就是定义一些契约,抽象类来做一些共同的操作,实现类依照特定的要求来完成具体功能,这种设计也是非常常用的。

我们以电商为例来进行说明:

电商中有很多模块,用户模块、商品模块、订单模块......

如何保证每个模块的前缀不一样呢?

小技巧:通过类名,我们将类名作为前缀,这样就可以保证key的唯一性了。

第一步,接口:

public interface KeyPrefix {
    //有效期
    public int expireSeconds();
	
    //前缀
    public String getPrefix();
}

第二步,抽象类:

public abstract class BasePrefix implements KeyPrefix{

    private int expireSeconds;
    private String prefix;

    public BasePrefix(String prefix) {
	//0-永不过期
	this(0, prefix);
    }
	
    public BasePrefix(int expireSeconds, String prefix) {
	super();
	this.expireSeconds = expireSeconds;
	this.prefix = prefix;
    }

    @Override
    public int expireSeconds() {
	return expireSeconds;
    }

    @Override
    public String getPrefix() {
	String className = getClass().getSimpleName();
	return className + ":" + prefix;
    }

}

第三步,实现类:

public class UserKey extends BasePrefix{
    
    private UserKey(String prefix) {
        super(prefix);
    }

    //同一模块内,可自定义变量来区分
    public static UserKey getById = new UserKey("id");
    public static UserKey getByName = new UserKey("name");

}
public class GoodsKey extends BasePrefix{
    private GoodsKey(int expireSeconds, String prefix) {
        super(expireSeconds, prefix);
    }

    public static GoodsKey getGoodsList = new GoodsKey(60, "gl");
    public static GoodsKey getGoodsDetail = new GoodsKey(60, "gd");
}

......

只是一种思路,仅供参考,不喜勿喷。

 

 

  • 1
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值