58招才猫重构总结

58招才猫重构总结

招财猫系统因为历史原因很是庞大冗余,业务流程特别复杂,最近参加了58招才猫的重构,总结重构的以下几点:

  • 兼容旧的代码
  • 业务层抽离
  • 边际值判定
  • 日志处理
  • 对外接口要用户友好
  • 异常处理
  • 测试用例
  • 代码规范
  • 接口文档

1.兼容旧的代码

因为以前的代码正在良好的运行,因此新的代码在实现重构的情况下,测试通过项目上线后为了防止异常情况紧急切回旧接口

解决方案

实现一个selector,维护一个url集合,通过判断url是否在集合内来选择走新的controller还是旧的controller

Created with Raphaël 2.1.2 开始 前端请求 url是否存在 新接口 结束 旧接口 yes no
处理结果

实现了一个自由控制新旧接口切换的开关

2.业务层抽离

原来招才猫中没有业务层,项目太过臃肿庞大。

解决方案

根据情况将业务内容分为代理和微服务两个部分,代理部分实现外部的服务调用,微服务部分根据业务划分出不同的微服务

处理结果

实现了业务层的分离,使主服务只是简单的跳板作用,同时业务的划分有利于程序员对业务的理解和职责划分,增强项目的可协作性,减少新人的学习业务成本。

3.边际值判定

很多接口只能满足特定的情况,未考虑传入异常数据或者脏数据的情况

解决方案

在接口前直接对参数进行检查,throwCheckException并返回异常情况和参数同时记录到日志中,以便于将来进行日志数据分析。

处理结果

异常数据进入接口会抛出检查时异常

4.日志记录

原来的日志记录不规范,怎么记录的都有,有的只是catch了异常并打印,而且使用的都是同步日志

解决方案

统一日志处理规范,每个请求生成一个traceID用在整个程序运行流程,全部使用异步日志处理,出现异常时记录数据的输入,类名方法名和异常的内容。

处理结果

日志记录的规范完整,能快速定位错误,记录速度提升最少30%。

5.对外接口要用户友好

有的接口用户使用的比较痛苦,不能直接返回用户想要的结果;只根据数据库返回结果。还有的接口在方法内调用同一个微服务多次

解决方案

在原有的接口下增加用户友好的接口,优化微服务的调用逻辑

处理结果

增加用户对底层接口的调用,减少程序员造轮子的冲动;同时减少程序的响应时间。

6.异常处理

原来的异常处理大多是将异常打印到日志

解决方案

统一的异常类定义并对异常进行分类和主动捕捉,记录异常的类名、方法名、输入参数和异常的具体信息到日志

处理结果

通过化被动为主动的异常处理使异常更加可控,同时能快速定位异常并便于异常处理。

7.测试用例

在写完自己的接口后还是要写点用例测一下

处理结果

增强代码的健壮性

8.代码规范

老生常谈的代码规范,简单而又困难;最近scala用的多,代码简洁优雅但是可读性还是差一些

处理结果

java还是一门工程语言,有时候可读性还是挺重要的

9.接口文档

曾经最讨厌的两件事:看别人的烂代码和写无聊的文档。看别人的代码时多么希望有一份清晰准确的文档放在我的面前~

处理结果

新写的代码每个接口对应一份最新最全的文档

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值