重构实战落地--水平切割和跨层访问哪个好
来源:互联网 发布:processon类似软件 编辑:程序博客网 时间:2024/04/30 13:26
系统要重构了,水平切分大体明确.
本来期望水平拆分成不同的jar和api,实现微服务之前的部署.
但是实际操作起来
1. 会导致要不停的拆分子模块,
2. 每个子模块都会有外部边界.
都需要配置 dubbo 的consumer ,但是又会最终在一个jvm上运行,技术边界导致不可能完全子模块化. 需要将所有的dubbo配置和mybatis配置放在一起. 然后各个子模块,按需封装wrapper.
所以说最终说来,还是需要一个 类依赖检查工具.
对于要重构的老服务,
1. 已经有大量的跨层调用,
2. 还有就是大量的获取多余的属性, (直接调用 DAO的getBean,调用集成层的getOrder)
3. 还有就是大量未经收缩形参调用. 这种如何落地. updateState(driverId,normalState)
4. 其他:
4.1 流程杂糅. 比如 N个帐户转账,司机流水,司机状态变更.
都放在accountTransfer 里,但只有司机分润和逆分润会转账.
4.2 大段代码代码
落地: 每周进行codeReview. 找到可以重构的点.进行TODO 书写.
或者通过牛逼的依赖检查工具,检查出老的代码,自动添加TODO到代码中.但是这种工具风险太大,也容易错误.
随着收缩形参之后会有大量的service,通过进一步的分类细化到不同的类中.
对业务的需求理解产出.
1. 流程图. 主流程缩放框架. 整理出对应的外部模块
2.
0 0
- 重构实战落地--水平切割和跨层访问哪个好
- mysql垂直和水平切割
- 重构--先垂直水平切分后的落地之泛化思维
- mysql 分库分表(水平切割和垂直切割)
- exFAT和NTFS哪个好
- EXFAT和NTFS哪个好
- discuz和phpwind哪个好
- TIMESTAMP和DATETIME哪个好
- 实战 .Net 数据访问层
- 实战.NET数据访问层
- 基于.NET平台的分层架构实战(七-外一篇)——对数据访问层第一种实现(Access+SQL)的重构
- 基于.NET平台的分层架构实战(七-外一篇)——对数据访问层第一种实现(Access+SQL)的重构
- 是时候重构数据访问层的代码了
- APP开发实战54-业务逻辑层设计(Presenter)和数据访问层设计(Model)
- 数据的水平切割
- Silverlight实战示例3(兼集合属性的妙用)--数据库访问层和数据访问层
- Silverlight实战示例3(兼集合属性的妙用)--数据库访问层和数据访问层
- Apache访问日志切割和自定义格式
- EcmaScript6学习之二
- XModem协议
- 王爽汇编语言课程设计2
- JVM调优总结(4):分代垃圾回收
- NYOJ 118 修路方案
- 重构实战落地--水平切割和跨层访问哪个好
- javaの内部类
- tomcat配置解决中文乱码
- 模拟c++容器vector写的动态数组
- Masonry介绍与使用实践和各种使用心得,持续更新~
- ECMAScript6学习之三
- 右键属性数据表的显示
- php操作memcache的使用【转】
- getChildAt()