【架构艺术】Go语言微服务monorepo的代码架构设计

近期因为项目架构升级原因,笔者着手调研一些go项目monorepo的代码架构设计,目标是长期把既有微服务项目重要的部分都转移到monorepo上面,让代码更容易维护,协作开发更加方便。虽然经验不多,但既然有了初步的调研,今天就分享一下笔者所面临场景的monorepo设计思路。

从语言特性上讲,Golang是非常适合做monorepo的,但根据不同项目研发需要,monorepo的目录结构可以定制成不同的形式。所以要做monorepo,首先要回答的问题是,做这个事情主要解决什么研发问题,优化了什么东西,否则投入量过多,ROI就会很低。

笔者所处的团队偏向于中台角色,每个同学都负责一个专项,不同专项之间可能共享很多三方能力的实现,并且团队距离业务比较近,研发更注重短平快,所以既往的代码实现质量方面,并不是非常完美。从这个角度来看,如果用monorepo做代码架构升级,主要能解决的问题,一是更精简的代码和模块化抽象,二是减少三方能力的冗余实现,三是通过一套研发实践规范代码管理,这样就能够在保证代码易扩展和模块易兼容的基础上,各个成员能够尽可能自由发挥,代码质量也不会轻易下降,这样长期就能让整个团队的技术迭代更加效率,服务实现的稳定性会更高。

然后就是整个代码架构长什么样子。笔者的项目,大概是这样设计:

markdown 复制代码
- app:所有服务各自的代码
  - ${service_group}:按架构划分的服务组(模块)
    - ${service_name}:单个服务的代码(http/rpc等)
      - biz:业务逻辑
        - handler
        - middleware
        - service
      - conf:静态配置
      - main.go
      - build.sh:每个服务的编译
- lib:所有服务公有的代码
  - client:三方能力的client实现
  - common:枚举定义
  - model:数据结构(from idl)
  - dal:数据访问(gorm自动生成)
  - util:工具函数
- idl:协议
- script:脚本(编译/本地开发)
- Makefile
- go.mod
- go.sum
- README.md

由于很多服务需要共享数据结构,所以在设计上,idl、model做了单独提出,被所有服务可以引用。开发约定上,通过在script、Makefile做一些脚本,就可以自动指定某服务创建/更新项目代码,也可以随时自动生成/更新协议结构和gorm定义。

通过这样一个架构,首先代码精简和三方能力抽象都可以解决。然后,由于各类脚本的存在,每个业务专项的研发同学就不需要把过多精力关注在代码底层架构上,可以快速适应整个项目开发。就算长期有需要单独提出的能力,代码也可以很容易迁移到lib模块。这样整体上看,整个团队的代码质量在未来都能够有质的提升。

当然,从现状来看,这个项目结构未来可能会遇到的问题是,如果存量大服务的研发过程要迁移到这个monorepo,可能会踩什么坑,比如go-mod要处理兼容性问题,服务编译部署配置需要重新调整,研发脚本需要做额外的兼容,很多模块需要未来打散挪到lib等等。

上述这些基本上是小问题,大的问题是怎么在迁移项目的过程中,不影响既有的业务迭代。排除需要周末加班的的情况,笔者认为一个合理的解决方法是,在迁移前抽一些时间间隙,先找一些小的存量项目去做试点迁移,踩坑,整理最佳实践,然后再尝试迁移大项目,这样就不至于一下迁移遇到问题就阻塞很多。迁移的话,也是先把所有代码挪到app,保证编译部署是通的,然后在这个基础上再做代码重构和打散,把重要的公有能力给提取出来,去让代码逐渐演变成理想的形态。

相关推荐
码上成长2 分钟前
长耗时接口异步改造总结
前端·git·后端
diudiu962810 分钟前
Logback使用指南
java·开发语言·spring boot·后端·spring·logback
安果移不动15 分钟前
Android 架构进化之路:为何在 Retrofit + 协程重构中,我们需要引入 Hilt?
android·架构·retrofit
Lisonseekpan27 分钟前
Elasticsearch 入门指南
大数据·分布式·后端·elasticsearch·搜索引擎
七夜zippoe27 分钟前
轻量级模型实战:使用OpenLLM构建生产级大模型服务
大数据·人工智能·机器学习·架构·openllm
zhangyifang_00929 分钟前
Spring中的BeanDefinition
java·后端·spring
Jerry9527062829 分钟前
3.集群与分布式
分布式·架构·架构师·软考·高性能·高可用·架构设计师
bigdata-rookie30 分钟前
Spark 运行架构及相关概念
大数据·架构·spark
旧梦吟33 分钟前
脚本 手机跑.简易go服务器
python·golang·css3
楠枬38 分钟前
负载均衡 -LoadBalance
后端·spring·spring cloud·负载均衡