[2024 年] 有哪些大家觉得好用的 Go Web 框架/脚手架?
在仅考虑 HTTP API 开发的前提下,大家有什么推荐的 Golang Web 框架或脚手架吗?
如果不使用框架/脚手架自己组合的话,常用组件大家是如何选型的呢?
www.goravel.dev/
没一个好用的,就算做好了心理建设接受了有些残疾的脚手架,后面还得去接受残疾的 ORM ,我觉得人生苦短,不应该在这上面浪费时间,最后还是决定不用 golang 作为业务层了,只用来做一部分非常边缘且简单的服务。
echo
额,我正在搞一个,刚开始。
- 不写 tag 的 binding 和校验
- 自动的路由注册和导入(一点点代码生成,且不需要额外的命令)
自动的 api 文档生成
sql 层面确实很难抽象,我还在想怎么做。
我不用 orm ,只用 db/sql
极简脚手架: github.com/elliotxx/go-web-template
http: github.com/labstack/echo
orm: github.com/ent/ent
validate: github.com/Oudwins/zog
error: github.com/joomcode/errorx用 Go 做业务开发/后端 API ,唯一的劣势就是没有一个统一的标准,没有好用的脚手架
Java 有 Spring Boot ,.NET 有 ASP.NET/Entity Framework ,Python 有 Django
Go 现在也进入主流开发视野了,但这方面还是挺残废的,写业务没有其他语言好用kratos 习惯了依赖注入后就挺不错的。还有就是未开源的 tRPC 生态非常好用。
kratos 和 go-zero 都支持了脚手架创建 http 和 grpc 的代码,但是太抽象了,定位问题和接口时要跳转很多次才能看到重点....我现在还是再用 gin+wire
在 go 里写 DI ,理由是什么...
go 里面加 Wire 太恶心了。。。
蹲一个答案,主要是 orm 这块
中小型公司没必要用什么 DI, 另外 DI 这种东西说实话就是为了控制人的,好让你们成为像 Java 那样的 curd boy ,
DI 的确也有好处,项目模块化更明显,剥离出业务逻辑,使得分工更明确。
不过我想说这种脚手架真的没必要学,因为你到一个自研实力还不错的公司,这种东西都会有核心成员研发的,然后让其他人成为工具人,哈哈。
几个 web 框架比如 gin, echo, beego 要会点,其他的都可以自己造的。
go-zero 重度用户
楼上 n 多人还在纠结 orm ,真的大可不必——gpt 类出来就是节省这些方面的时间的
可以自动生成 http/grpc 框架代码,若喜欢一样可以生成 model 代码。这就够了
GoFiber + Ent 吧
DI 是什么? dependency injection ?
如果是很大型的项目确实有点头疼,一般的 web 应用搞个 httprouter 都行,又不是非要什么 spring 一样的东西
不写 tag 的 binding 和校验听起来很有趣,请问是通过什么方式做呢
是的, 这方面 go 有好几个, 一些业务团队会把 DI 用到各个 web 框架上并组成自己的脚手架,
常见的 DI 有 google/wire(代码生成), uber-go/dig (反射)
紫薇,答应我,不要为两抽象而抽象,好吗?
gin+xorm
pocketbase.io/
难受,java 转的 go 。感觉 go 是一个项目一个规范
是不是? 这大屏看的真受不了 z3.ax1x.com/2021/09/28/4huQAS.jpg 这还是半屏的截图,下边全屏截图,我天 …… z3.ax1x.com/2…
前几天元旦放假,顺手在马云家的电商平台搜 4K 屏幕的笔记本电脑。 我用的关键字是“4K 笔记本电脑” 搜索结果实在大开眼界,除了预期中的游戏本、中高端轻薄本,竟然还有一堆…
或者在原理上该如何实现一个 12306 ,技术难点有哪些,欢迎大家讨论 感觉难度被夸大了。 用 bit 表示列车的站点区间,卖出一张票,就把对应的 bit 置 true , …