Go mod 好菜系列 - 0x14 kratos 这锅微服务脚手架不是只会搭架子

详细聊 kratos 的定位、transport/service/data 分层怎么理解、它适合什么团队,以及为什么它更像工程约束工具而不只是生成目录的脚手架。

很多人第一次看到 kratos,第一反应通常是:这不就是个脚手架吗?能生成目录、能起个服务、能跑个 gRPC 和 HTTP,看起来像是“搭完骨架就没了”。但真到了团队项目里,它真正有价值的地方,反而不是“帮你少敲几十行命令”,而是它在悄悄帮你把工程结构往一个更稳的方向收。

kratos 在解决什么问题

它主要解决的是 Go 服务项目怎么组织 这件事。很多项目一开始都能跑,但跑着跑着就会开始乱:

  • handler 里直接查数据库
  • service 里顺手拼 SQL
  • 日志、配置、超时、错误码到处散落
  • HTTP 和 gRPC 两套入口越来越像两棵野生分支

kratos 并不是魔法,它做的事情更像是:先替你把这些边界画出来,再逼着你别轻易把它们写穿。

它为什么常见

因为国内 Go 团队里,尤其是做 API 服务和内部平台服务的,很多时候真正缺的不是“某个库”,而是一套大家都能看懂、也愿意按着写的项目组织方式。kratos 恰好卡在这个位置上:

  • 比从零自建框架轻松
  • 比毫无约束的自由发挥更稳
  • 对 gRPC / HTTP / 配置 / 日志 / 中间件这些常见要素有现成组合

最常见的目录分层怎么理解

cmd/
internal/
  service/
  biz/
  data/
  server/

这个分层如果只背名字,很快就会觉得空。真正要理解的是职责:

  • service:接口层,接住 transport 进来的请求,做参数翻译和响应组织
  • biz:业务层,放真正的业务规则和领域逻辑
  • data:数据层,和 DB、缓存、第三方系统打交道
  • server:把 HTTP、gRPC 服务启动起来

你会发现它想传达的不是“目录长这样”,而是“别把 transport、业务、存储搅成一锅”。

看一眼 kratos 风格的 service/biz/data 怎么接

type UserRepo interface {
    Save(ctx context.Context, user *User) error
}

type UserUsecase struct {
    repo UserRepo
}

func (uc *UserUsecase) Create(ctx context.Context, name string) error {
    return uc.repo.Save(ctx, &User{Name: name})
}

type UserService struct {
    pb.UnimplementedUserServer
    uc *UserUsecase
}

func (s *UserService) CreateUser(ctx context.Context, req *pb.CreateUserRequest) (*pb.CreateUserReply, error) {
    if err := s.uc.Create(ctx, req.Name); err != nil {
        return nil, err
    }
    return &pb.CreateUserReply{Message: "ok"}, nil
}

这段代码的重点不是语法,而是依赖方向。service 不直连数据库,biz 不关心 transport 细节,data 去实现 repo 接口,这样边界会清楚很多。

kratos 不是只给你一个生成器

很多人用完 kratos new 就觉得差不多了。其实真正进入日常开发后,你会更常碰到这些东西:

  • 配置加载
  • 日志接入
  • 中间件链路
  • 错误码和错误包装
  • 服务注册发现
  • proto 驱动的接口定义

这些才是 kratos 更常被提起的原因。它不只是“把目录搭出来”,而是给了你一套偏工程化的默认组合。

什么时候它特别适合

  • 团队里不止一个人维护服务
  • 项目有 HTTP 和 gRPC 双入口需求
  • 你希望服务结构尽量统一
  • 后面可能要接注册发现、链路追踪、配置中心

这类场景里,kratos 能帮你少走很多“每个项目都重新吵一次目录结构”的弯路。

什么时候它反而可能有点重

如果你只是写一个很小的单体 API,或者只是想快速验证一个想法,那 kratos 也可能显得有点“正经过头”。因为它默认带来的,是工程约束,而不是最短启动路径。

所以它并不是所有项目都该上,而是更适合那些你已经知道自己会长期维护、会继续扩张的服务。

一个简单的理解方式

如果说 Gin 更像是“给你一把快刀,你自己决定怎么切”,那 kratos 更像是“给你一套后厨分区和配菜流程”。它不是为了让第一道菜炒得最快,而是为了让后面几十道菜别全乱套。

小结

kratos 这锅菜不在于炫技,而在于稳定:

  • 它的核心价值是工程组织,不只是代码生成
  • service / biz / data 分层是为了职责边界,不是为了看起来专业
  • 适合长期维护、多人协作、微服务倾向的项目
  • 小项目不一定非上,但复杂项目里它确实能减少混乱

Read more

序章:长夜之后

后来的历史书把那一天称为“长夜之后”。 这个名字并不准确。事情发生在地球上的许多个白天和夜晚之间,发生在不同经度的清晨、午后、傍晚,发生在地下库房、山体掩体、海军基地、荒原试验场和无人值守的材料贮存井里。它既不是一场战争,也不是一次统一指挥的袭击。没有人按下那个能够解释一切的按钮。 但历史需要一个名称。 “长夜之后”最终被保留下来,是因为调查者在追溯事件源头时,不得不一次又一次回到海王星。回到那颗距离太阳太远、光照近乎吝啬的蓝色行星。回到六名中国宇航员死去的地方。回到一艘核动力科考船熄灭后的漫长黑暗。 在联合调查委员会公开的第一版报告中,事件时间线被压缩成了一页表格。 2030年9月,问海一号在海王星附近失联。 2034年11月,问海二号抵达失事区域,确认问海一号全员死亡。 2035年1月,问海二号完成样本封装,开始返航。 2038年6月,海王星样本进入地球高等级隔离实验室。 2038年7月,全球多个核材料设施发生不可逆事故,部分核电站进入最高级别应急。 2038年8月,所有已知核武库事实上失效,全球核电装机大规模停运。 这张表格后来被反复引用,因为它足够冷静,也

By Fuyu Jia

第一章:四小时以前的地球

林予舟第一次听见“问海一号”的最后通信,是在距离地面三百九十公里的轨道上。 那不是一个适合听遗言的地方。 舷窗外,地球从飞船腹侧缓慢转过去,云层像被谁铺平的白色金属屑,青藏高原的阴影压在晨昏线上。太阳还没有完全越出地平线,近地轨道的黑暗因此显得很薄,像一层马上要被擦掉的墨。 “链路稳定。”林予舟说。 他的声音被舱内麦克风收进去,压缩,打包,送进中继卫星,再落回海南深空任务中心。延迟不到一秒。这样奢侈的实时感,在他们离开地月系统后会迅速消失。等飞船抵达海王星附近,地球说一句话,要四个小时左右才能抵达;他们回一句,地球也要再等四个小时。 对话会变成考古。 控制台上方的状态灯一排排亮着,绿色多得几乎让人不安。问海二号还在近地轨道泊位上,推进舱、居住舱、通信桁架和补给舱刚完成最后一次组合检查。它不像公众宣传片里那样优雅。现实中的深空飞船更像一串被迫相互妥协的工程物:银灰色隔热层、外露管线、姿控喷口、展开到一半的高增益天线,所有东西都为了质量、功耗、散热和冗余让步。 它也不像一艘该去海王星的船。 至少不像一艘该去救援核动力深空飞船的船。 问海二号没有主反应堆。 这件事在公开报

By Fuyu Jia

第二章:没有核反应堆的船

发射前四十分钟,林予舟收到了一条来自地面的私人通信。 通信被压在任务数据包后面,标记为低优先级。它随着推进剂温度曲线、姿态平台校准结果、医学监测基线和最后一版逃逸窗口修正量一起进入问海二号的主机,像一枚被夹在工具箱里的薄纸片。 林予舟本来不该在这个时候打开它。 发射前四十分钟,人的每一个动作都应当有明确目的。检查阀门状态,确认加压序列,复诵逃逸程序,核对地面口令。人的情绪如果在这个时候出现,就应该被折叠起来,放进某个不影响任务的地方。 他还是点开了。 画面里是母亲的厨房。抽油烟机没有开,镜头被热气熏得微微发白。桌上摆着一碗面,青菜、荷包蛋和切得很薄的牛肉。母亲没有出镜,只在画面外说:“我知道你现在不能吃,等回来再吃也一样。” 林予舟看着那碗面,隔了几秒才意识到自己没有呼吸。 “怎么了?”沈从越问。 “私人包。” “家里?” “嗯。” “看完删掉。”沈从越说,“别让它留在主屏缓存里。发射时系统会重排任务窗口,乱七八糟的东西越少越好。” 他语气平淡,不像关心,也不像责备。沈从越说话常常这样,像把所有情绪都预先压成了流程。林予舟关掉视频,把它转存进私人存储区。那碗面从

By Fuyu Jia

第三章:地球变成录音

离开地月系统后的第十九天,林予舟第一次觉得,地球不是一个地方,而是一种延迟。 最初的几天,通信仍然近乎实时。地面问,他们答;他们报数,地面确认。贺岚的声音穿过中继链路抵达舱内时,还带着地球上办公室的秩序感:清晰、稳定、克制。林予舟甚至能从她停顿的长度判断总控大厅里有多少人在看同一块屏幕。 后来,停顿被拉长。 五秒。 十七秒。 一分钟。 再后来,地球的每一句话都像从更早的时间里寄来。母亲发来的第二条视频在一个姿态修正段后抵达。她说北京降温了,问他那边冷不冷。林予舟看着舷窗外没有温度的黑暗,忽然不知道该怎么回答。 他当然冷。 但那不是气温。 “私人日志,任务日二十。”他说,“今天第一次做梦,梦见自己回到地面,站在厨房里。锅里有水,水一直不开。母亲在旁边说火太小,我低头看,灶台下面接着的是问海二号的离子推进器。” 他说完后,自己笑了一下。 笑声在舱内很短,很快被风机吞掉。 沈从越从设备舱飘过,听见最后半句:“梦境记录?” “心理监测要求。” “别把自己写得太正常。

By Fuyu Jia