简书文选科普百年工匠

msg框架

2021-02-09  本文已影响0人  漠北兄弟


msg框架

1. 写msg框架的意义

msg(mini super globe 小而全的意思 )。做了多年的码农,一直都是用的别人写好的框架,然后里面写几行代码,功能就完事了,感觉好神奇,但是对其中的实现原理,设计思路一概迷糊。为什么要这么设计?这是怎么实现的?带着各种疑惑,决心自己写一个框架,从底层写起的那种,就当是学习了。

2. msg历程

2019年10份开始写到2020年10月,一年的时间,节假日+疫情不上班期间+晚上。

msg1.0(myeclipse+jar包+mysql)

msg2.0(idea+maven+mysql+redis)

msg3.0(idea+maven+mysql+redis+ rabbitmq+docker)

msg4.0(计划中…..) 可以承载小应用 2021年

msg5.0(计划中…..) 实现微服务 2022年

每一次版本升级都是技术的一次升华,希望5.0版出世的时候可以,用此框架快速的开发一些小系统。

3. 写msg框架的目前用到的技术点

msg框架不同于现在流行的spring boot 框架(万物皆注解),系统还是保留了一些基本的配置信息,所有的交换的数据都是json来实现。

由于之前一直用的WADE框架,在设计msg基本上参考了WADE设计思路。每一个功能都是从底层写起,如果你是初学者,想学习一下,msg还是比较合适的。

3.1 前后端分离

msg 前端用了layer,在选前端时由于消息封闭,没有选vue实现,现在有点后悔,但是主要的设计和功能点后都在后台,所以影响不大。

3.2 接口注册定义

接口定义:所有接口的URL地址只有一个入口,使用servlet,里面通过反射实现访问指定类。

接口名不允许重复。

支持get ,post。

支持报文头、报问都在参数中,用固定格式JSON报文,没有使用Headers

向微服务靠近,目前接口加载配置文件,后期会用redis统一控制注册信息。

{

  "SVC_ID": "msg.homeSVC.GetHotPoint",

  "CALSS_PATH": "busi.home.homeSVC@GetHotPoint",

  "SESSION_FILTER": "false",

  "SVC_NAME": "查询热点",

  "REMARK": "查询热点"

}

3.3 数据交换 Mdt、Mdts、MdtUtil

所有的数据交换都是通过JSON实现,包括配置文件。框架中封装了JSONObject (Mdt)、JSONArray (Mdts)。将一些常用方法做了分装。

Mdt outMdt=new Mdt();

Mdts points=new Mdts();

3.4 日志 MLog

日志通过多线程,线程等待方式实现,全局有效,直接调用,分为三个级别:debug、 info 、 error ,通过配置实现日志级别控制,路径配置,是否打印控制日志等。日志打印通过堆栈信息准确打印出日志时间、位置方便查询。

MLog.debug("GetUserInfo", outMdts.toString());

[2021-02-0400:21:02399][error][createPool][com.msg.database.ConnPool][monitor][270]【default】最大连接数:5可用连接数:

3.5 异常MExc

随时抛异常,异常打印,异常定义等

MExc.msgError("SqlReplaceParam", "SQL 解析失败。SQL中字段值不能包含:= ; , % ' ) 空格等特殊字符");

3.6 连接池

连接池实现是整个框架设计较难的部分,由于系统需要实现多数据源支持,针对此问题还专门请教了,大厂的架构师提供意见。在调试设计了N久之后才搞定多用户,并发,事务回滚等问题。

支持多路由:同一个事物有多个连接多个库。

异常回滚:如果有异常,直接回滚。

每一笔交易完成只有两种情况:回滚或者提交,不存在其他情况。

3.7 单点登录

单点登录用redis实现,用系统生产的随机码控制有效期。目前用两种方式:

一、 session:每登录一次有效期重新计算。

二、 token 长期有效,需要通过app注册。

3.8 接口测试

接口开发完成会后,有指定页面可以测试接口

3.9 请求流水

每次请求都会生成一个唯一id,方便查询日志。

3.10 启动参数

启动参数区分为开发、测试、生产,方便部署

3.11 定时任务暂时用quartz 实现,不打算自己写了

3.12 sql

数据库的增删改查,做了常用方法分装,由于本人写脚本水平还可以,设计时中全部用sql实现,非常不习惯用jpa模式 。不过mybatis 确实好用,当有查询条件有变化时,非常好用,目前没打算继承。

Mdts outMdts=this.dao.query("TB_USER", "SEL_QUERY_USER_INFO", mdt, "msg1");

this.dao.insert("msg_sql",sqlInfos,FinalField.getRoutid());

4. 写msg框架目前实现功能

4.1 主要菜单截图

4.2 接口测试

4.3 菜单管理

4.4 用户管理

4.5 角色管理

4.6 启动日志

5. 对msg框架的畅想

msg 最终目标是向微服务靠近,目前已经具备一些微服务特质,希望能在5.0出世的时候,一鸣惊人,可以快速搭载小系统,小应用,易部署。

如你也对我的项目感兴趣,源码全部公开,如果需要请留言,放心使用。

上一篇下一篇

猜你喜欢

热点阅读