每一个 go 库都是精品,组合到一块儿就这么恶心

2022-12-31 23:34:17 +08:00
 fxjson

最近在学习使用 go  stars 比较多的库,比如 gin,gorm,go redis 等,单独用一个写段代码,感觉很舒服,挺爽,于是想把他们整合到一块儿,感觉很郁闷,数据库,redis 库底层 error 和业务空都归类为 error,我整合成一个业务框架以后写业务就很啰嗦了,要区分是业务 error 还是底层 error ,总不能把底层 error 抛出来前端显示吧,go 又不提倡 panic ,大家有木有用 go 写业务的,用啥框架,还是自己封装?发现 go zero 是个好东西,大部分代码都可脚手架生成

2364 次点击
所在节点    程序员
6 条回复
lscho
2023-01-01 00:25:59 +08:00
同感,说到底还是异常处理太恶心
wangritian
2023-01-01 10:45:00 +08:00
goframe ,大而全方向的,用自带 code 的 gerror 解决
dacapoday
2023-01-01 11:53:50 +08:00
1. gorm 不是精品,至少是鸡肋。无论其 api 风格还是库的实现,都能看出作者 与 go 本身的设计思想 以及其标准库实现 的对抗,但又不得不迁就的无奈(比如配置连接池,raw sql ,自定义 colum 类型的接口设计)
2. 既然是集成第三方库,必然需要封装,无论是出于统一业务逻辑(比如报错方式),还是可维护性(仅就 go-redis 库,难道直接在业务代码里写 redis cmd ?为啥不封装一个面向业务的方法,将 key, ttl 等细节屏蔽)。
3. 如果是纯写业务,对性能,自定义底层行为,以及 第三方依赖管理 没有需求。应该是选择主流的框架或项目模版,按其文档进行开发。而非仅靠 stars 挑选第三方库并集成
lvsshuttao
2023-01-01 14:00:17 +08:00
目前使用的是 goframe (2.0) + xorm ,然后自己写的错误处理:1. 非业务代码产生的错误全部写入日志; 2. 业务代码根据需要写入日志(简单的参数错误不写日志)

之前尝试用 go zero 写项目,感觉太麻烦了,可能我这种简单的 CURD 项目不太适合
janxin
2023-01-01 18:43:43 +08:00
错误要做额外包装方便统一处理
lookStupiToForce
2023-01-03 11:54:00 +08:00
虽然语言不同,但处理这些非算法的工程事务的方法可以相通
推荐阅读一下这个文章(因为带过多地址会导致多扣铜币,地址经过 base64 编码)

Python 工匠: 异常处理的三个好习惯
aHR0cHM6Ly9naXRodWIuY29tL3BpZ2xlaS9vbmUtcHl0aG9uLWNyYWZ0c21hbi9ibG9iL21hc3Rlci96aF9DTi82LXRocmVlLXJpdHVhbHMtb2YtZXhjZXB0aW9ucy1oYW5kbGluZy5tZA==

顺带一提,这个文章出自这位 v 友 piglei ,你可以关注一下他
aHR0cHM6Ly93d3cudjJleC5jb20vbWVtYmVyL3BpZ2xlaQ==

这是一个专为移动设备优化的页面(即为了让你能够在 Google 搜索结果里秒开这个页面),如果你希望参与 V2EX 社区的讨论,你可以继续到 V2EX 上打开本讨论主题的完整版本。

https://www.v2ex.com/t/905854

V2EX 是创意工作者们的社区,是一个分享自己正在做的有趣事物、交流想法,可以遇见新朋友甚至新机会的地方。

V2EX is a community of developers, designers and creative people.

© 2021 V2EX