美文网首页
设计模式实战-模板方法

设计模式实战-模板方法

作者: 梨花菜 | 来源:发表于2021-12-31 15:00 被阅读0次

    需求背景

    在大数据测试过程中,需要用到多种数据源,经常需要切换多个工具和网站;

    并且数据源的配置比较分散,缺乏统一的数据源配置管理入口。因为需要一个统一的查询数据和管理配置的功能

    需求分析

    数据查询

    • 执行查询时,需要知道数据源id和执行的Query(命令或者SQL)
    • 记录每次查询,方便后续溯源;同时也要设置每种数据源慢查询阈值,发送告警信息

    数据源配置管理

    • 敏感信息需要加密(rsa不对称加密,不能使用哈希,因为后端还要解密得到明文)
    • 每个项目数据隔离
    • 权限控制(管理员才能CRUD配置)

    设计分析

    数据查询

    • 执行查询时,不管什么数据源,大致上都会经过几个特定的步骤,读取配置,创建连接,校验query合法性,执行query,关闭连接, 序列化query result, 写query log,发通知

    设计流程图

    image-20211231111811826

    设计实现

    根据设计分析得知,不管什么类型的数据查询,都会遵循固定的步骤;差别只是根据数据源来分别实现具体的步骤。

    因此模板方法符合这种情况

    抽象父类

    父类UML

    datasource_service抽象类

    父类定义

    • 在模板方法中,在抽象父类定义一个公有方法,并且在里面按顺序调用对应的私有方法

    具体就是定义execute方法,依次调用_validate _init_conn _execute __write_execute_log _is_slow_query这些私有方法

    image-20211231142420981

    具体子类(MySQL)

    子类UML

    mysql_services_impl

    子类MySQL定义和实现

    image-20211231143244476

    具体子类(Redis)

    子类UML

    redis_services_impl

    子类Redis定义和实现

    image-20211231145151285

    View调用Service

    • 根据数据源类型,实例化对应的service对象
    • 调用service对象的execute方法
    image-20211231143555232

    总结

    • 模板方法核心思想:定义好骨架,子类实现具体细节;

    • 通过使用模板方法,在需要扩展时,只需要实现另外的子类即可,不需要对原来的代码改动

    • 注意点:父类中不需要被子类重写的方法,应该使用双下划线__

    相关文章

      网友评论

          本文标题:设计模式实战-模板方法

          本文链接:https://www.haomeiwen.com/subject/tywgqrtx.html