抽象工厂模式(Redis 集群升级)

目录

定义

[Redis 集群升级](#Redis 集群升级)

[模拟单机服务 RedisUtils](#模拟单机服务 RedisUtils)

[模拟集群 EGM](#模拟集群 EGM)

[模拟集群 IIR](#模拟集群 IIR)

定义使⽤接⼝

实现调⽤代码

代码实现

定义适配接⼝

实现集群使⽤服务

EGMCacheAdapter

IIRCacheAdapter

定义抽象⼯程代理类和实现

JDKProxy

JDKInvocationHandler

测试验证


定义

抽象⼯⼚模式与⼯⼚⽅法模式虽然主要意图都是为了解决,接⼝选择问题。但在实现上,抽象⼯⼚是⼀个中⼼⼯⼚,创建其他⼯⼚的模式。

Redis 集群升级

随着这次的升级,可以预⻅的问题会有;

  1. 很多服务⽤到了Redis需要⼀起升级到集群。

  2. 需要兼容集群A和集群B,便于后续的灾备。

  3. 两套集群提供的接⼝和⽅法各有差异,需要做适配。

  4. 不能影响到⽬前正常运⾏的系统。

模拟单机服务 RedisUtils

模拟集群 EGM

模拟集群 IIR

定义使⽤接⼝

复制代码
public interface CacheService {
    String get(final String key);
    void set(String key, String value);
    void set(String key, String value, long timeout, TimeUnit timeUnit);
    void del(String key);
}

实现调⽤代码

复制代码
public class CacheServiceImpl implements CacheService {
    private RedisUtils redisUtils = new RedisUtils();
    
    public String get(String key) {
        return redisUtils.get(key);
    }
    
    public void set(String key, String value) {
        redisUtils.set(key, value);
    }
    
    public void set(String key, String value, long timeout, TimeUnit timeUnit) {
        redisUtils.set(key, value, timeout, timeUnit);
    }
    
    public void del(String key) {
        redisUtils.del(key);
    }
}

代码实现

定义适配接⼝

复制代码
public interface ICacheAdapter {
    String get(String key);
    void set(String key, String value);
    void set(String key, String value, long timeout, TimeUnit timeUnit);
    void del(String key);
}

实现集群使⽤服务

EGMCacheAdapter

复制代码
public class EGMCacheAdapter implements ICacheAdapter {
    private EGM egm = new EGM();
    
    public String get(String key) {
        return egm.gain(key);
    }
    
    public void set(String key, String value) {
        egm.set(key, value);
    }
    
    public void set(String key, String value, long timeout, TimeUnit timeUnit) {
        egm.setEx(key, value, timeout, timeUnit);
    }
    
    public void del(String key) {
        egm.delete(key);
    }
}

IIRCacheAdapter

复制代码
public class IIRCacheAdapter implements ICacheAdapter {
    private IIR iir = new IIR();
    
    public String get(String key) {
        return iir.get(key);
    }
    
    public void set(String key, String value) {
        iir.set(key, value);
    }
    
    public void set(String key, String value, long timeout, TimeUnit timeUnit) {
        iir.setExpire(key, value, timeout, timeUnit);
    }
    
    public void del(String key) {
        iir.del(key);
    }
}

定义抽象⼯程代理类和实现

JDKProxy

复制代码
public static <T> T getProxy(Class<T> interfaceClass, ICacheAdapter cacheAdapter) throws Exception {
    InvocationHandler handler = new JDKInvocationHandler(cacheAdapter);
    ClassLoader classLoader = Thread.currentThread().getContextClassLoader();
    Class<?>[] classes = interfaceClass.getInterfaces();
    return (T) Proxy.newProxyInstance(classLoader, new Class[]{classes[0]}, handler);
}

JDKInvocationHandler

复制代码
public class JDKInvocationHandler implements InvocationHandler {
    private ICacheAdapter cacheAdapter;
    
    public JDKInvocationHandler(ICacheAdapter cacheAdapter) {
        this.cacheAdapter = cacheAdapter;
    }
    
    public Object invoke(Object proxy, Method method, Object[] args) throws Throwable {
        return ICacheAdapter.class.getMethod(method.getName(), ClassLoaderUtils.getClazzByArgs(args)).invoke(cacheAdapter, args);
    }
    
}

测试验证

复制代码
@Test
public void test_CacheService() throws Exception {
    CacheService proxy_EGM = JDKProxy.getProxy(CacheServiceImpl.class, new EGMCacheAdapter());
    proxy_EGM.set("user_name_01","⼩亮哥");
    String val01 = proxy_EGM.get("user_name_01");
    System.out.println(val01);

    CacheService proxy_IIR = JDKProxy.getProxy(CacheServiceImpl.class, new IIRCacheAdapter());
    proxy_IIR.set("user_name_01","⼩亮哥");
    String val02 = proxy_IIR.get("user_name_01");
    System.out.println(val02);
}
相关推荐
imHanweihu1 分钟前
基于POI-TL实现动态Word模板数据填充(含图表):从需求到落地的完整开发实践
java·onlyoffice·poi-tl
月夕·花晨5 分钟前
Gateway -网关
java·服务器·分布式·后端·spring cloud·微服务·gateway
失散135 分钟前
分布式专题——6 Redis缓存设计与性能优化
java·redis·分布式·缓存·架构
杏花春雨江南5 分钟前
Spring Cloud Gateway 作为一个独立的服务进行部署吗
java·开发语言
GSDjisidi6 分钟前
东京本社招聘 | 财务负责人 & 多个日本IT岗位(Java/C++/Python/AWS 等),IT营业同步招募
java·开发语言·aws
叫我阿柒啊17 分钟前
Java全栈开发面试实战:从基础到微服务的完整技术栈解析
java·spring boot·微服务·前端框架·vue·jwt·全栈开发
前行的小黑炭19 分钟前
Android:在项目当中可能会遇到的ANR,应该如何解决?
android·java·kotlin
索迪迈科技1 小时前
Flink Task线程处理模型:Mailbox
java·大数据·开发语言·数据结构·算法·flink
float_六七5 小时前
IntelliJ IDEA双击Ctrl的妙用
java·ide·intellij-idea