作者:Jack
最近发现 golang 社区里出了一个新星的微服务框架,来自好未来,光看这个名字,就很有奔头,之前,也只是玩过 go-micro,其实真正的还没有在项目中运用过,只是觉得 微服务,grpc 这些很高大尚,还没有在项目中,真正的玩过,我看了一下官方提供的工具真的很好用,只需要定义好,舒适文件 jia 结构 都生成了,只需要关心业务,加上最近 有个投票的活动,加上最近这几年中台也比较火,所以决定玩一下,
先聊聊中台架构思路吧:
中台的概念大概就是把一个一个的 app 统一起来,反正我是这样理解的。
先聊用户服务吧,现在一个公司有很多的公众号,小程序,微信的,支付宝的,还有 xxx xxx ,很多的平台,每次开发的时候,我们总是需要做用户登陆的服务,不停的复制代码,然后我们就在思考能不能有一套独立的用户服务,只需要告诉我你需要传个你要登陆的平台(比如微信),微信登陆,需要的是客户端返回给服务端一个 code,然后服务端拿着这个 code 去微信获取用户信息,反正大家都明白。
我们决定,将所有的信息 弄到 配置公共服务中去,里面在存,微信,支付宝,以及其它平台的 appid ,appkey,还有支付的 appid,appkey,这样就写一套。
最后说说实现吧,整个就一个 repo:
网关,我们用的是: go-zero 的 Api 服务
其它它的是服务,我们就是用的 go-zero 的 rpc 服务
看下目录结构
整个项目完成,我一个人操刀, 写了 1 个来星期,我就实现了上面的中台系统。
先看官方文档 https://www.yuque.com/tal-tech/go-zero/yaoehb
我们先把网关搭建起来:
➜ blogs mkdir datacenter && cd datacenter
➜ datacenter go mod init datacenter
go: creating new go.mod: module datacenter
➜ datacenter
查看 book 目录:
➜ datacenter tree
.
└── go.mod
0 directories, 1 file
➜ datacenter goctl api -o datacenter.api
Done.
➜ datacenter tree
.
├── datacenter.api
└── go.mod
分别包含了上面的 公共服务,用户服务,投票活动服务
详情:https://github.com/jackluo2012/datacenter/blob/main/datacenter.api
➜ datacenter goctl api go -api datacenter.api -dir .
Done.
我们打开 etc/datacenter-api.yaml
把必要的配置信息加上:datacenter-api.yaml
上面的 UserRpc
, CommonRpc
,还有 VotesRpc
这些我先写上,后面再来慢慢加。
我们先来写 CommonRpc
服务。
➜ datacenter mkdir -p common/rpc && cd common/rpc
直接就新建在了,datacenter 目录中,因为 common 里面,可能以后会不只会提供 rpc 服务,可能还有 api 的服务,所以又加了 rpc 目录
➜ rpc goctl rpc template -o=common.proto
➜ rpc ls
common.proto
往里面填入内容:user.proto
➜ rpc goctl rpc proto -src common.proto -dir .
protoc -I=/Users/jackluo/works/blogs/datacenter/common/rpc common.proto --go_out=plugins=grpc:/Users/jackluo/works/blogs/datacenter/common/rpc/common
Done.
基本上,就把所有的目录规范和结构的东西都生成了,就不用纠结项目目录了,怎么放了,怎么组织了。
看一下,配置信息,里面可以写入 mysql 和其它 redis 的信息:rpc.yaml
我们再来加上数据库服务:使用 goctl model
就行
➜ rpc cd ..
➜ common ls
rpc
➜ common pwd
/Users/jackluo/works/blogs/datacenter/common
➜ common goctl model mysql datasource -url="root:admin@tcp(127.0.0.1:3306)/datacenter" -table="base_app" -dir ./model -c
Done.
这样基本的一个 rpc
就写完了,然后我们将 rpc 和 model 还有 api 串连起来,这个官方的文档已经很详细了,这里就只是贴一下代码:
➜ common cat rpc/internal/config/config.go
package config
import (
"github.com/tal-tech/go-zero/core/stores/cache"
"github.com/tal-tech/go-zero/zrpc"
)
type Config struct {
zrpc.RpcServerConf
Mysql struct {
DataSource string
}
CacheRedis cache.ClusterConf
}
再在 svc 中修改:user/rpc/internal/svc/servicecontext.go
上面的代码已经将 rpc
和 model
数据库关联起来了,我们现在再将 rpc
和 api
关联起来:internal/config/config.go
加入 svc
服务中:internal/svc/servicecontext.go
这样基本上,我们就可以在 logic
的文件目录中调用了:internal/logic/common/appinfologic.go
这样,基本就连接起来了,其它基本上就不用改了,UserRPC
, VotesRPC
类似,这里就不在写了。
go-zero
的确香,因为它有一个 goctl
的工具,他可以自动的把代码结构全部的生成好,我们就不再去纠结,目录结构 ,怎么组织,没有个好几年的架构能力是不好实现的,有什么规范那些,并发,熔断,完全不用,考滤其它的,专心的实现业务就好,像微服务,还要有服务发现,一系列的东西,都不用关心,因为 go-zero
内部已经实现了。
我写代码也写了有 10 多年了,之前一直用的 php,比较出名的就 laravel,thinkphp,基本上就是模块化的,像微服那些实现直来真的有成本,但是你用上 go-zero,你就像调 api 接口一样简单的开发,其它什么服务发现,那些根本就不用关注了,只需要关注业务。
一个好的语言,框架,他们的底层思维,永远都是效率高,不加班的思想,我相信 go-zero 会提高你和你团队或是公司的效率。go-zero 的作者说,他们有个团队专门整理 go-zero 框架,目的也应该很明显,那就是提高,他们自己的开发效率,流程化,标准化,是提高工作效率的准则,像我们平时遇到了问题,或是遇到了 bug,我第一个想到的不是怎么去解决我的 bug,而是在想我的流程是不是有问题,我的哪个流程会导致 bug,最后我相信 go-zero
能成为 微服务开发 的首选框架。
最后说说遇到的坑吧:
grpc
grpc
本人第一次用,然后就遇到了,有些字符为空时,字段值不显示的问题:
通过 grpc
官方库中的 jsonpb
来实现,官方在它的设定中有一个结构体用来实现 protoc buffer
转换为 JSON 结构,并可以根据字段来配置转换的要求。
go-zero
中设置了,感觉没有效果,大佬说通过 nginx 设置,后面发现还是不行,最近强行弄到了一个域名下,后面有时间再解决。
sqlx
go-zero
的 sqlx
问题,这个真的费了很长的时间:
time.Time
这个数据结构,数据库中用的是 timestamp 这个 比如我的字段 是 delete_at 默认数库设置的是 null,结果插入的时候,就报了Incorrect datetime value: '0000-00-00' for column 'deleted_at' at row 1"}
这个错,查询的时候报deleted_at\": unsupported Scan, storing driver.Value type \u003cnil\u003e into type *time.Time"
后面果断去掉了这个字段,字段上面加上
.omitempty
这个标签,好像也有用,db:".omitempty"
其次就是这个 Conversion from collation utf8_general_ci into utf8mb4_unicode_ci
,这个导致的大概原因是,现在都喜欢用 emj 表情了,mysql 数据识别不了。
mysql
这边照样按照原始的方式,将配置文件修改编码格式,重新创建数据库,并且设置数据库编码为 utf8mb4,排序规则为 utf8mb4_unicode_ci
。
这样的话,所有的表还有 string 字段都是这个编码格式,如果不想所有的都是,可以单独设置,这个不是重点.因为在 navicat 上都好设置,手动点一下就行了。
重点来了:golang 中使用的是 github.com/go-sql-driver/mysql
驱动,将连接 mysql
的 dsn
(因为我这使用的是 gorm,所以 dsn 可能跟原生的格式不太一样,不过没关系, 只需要关注 charset
和 collation
就行了)
root:password@/name?parseTime=True&loc=Local&charset=utf8
修改为:
root:password@/name?parseTime=True&loc=Local&charset=utf8mb4&collation=utf8mb4_unicode_ci
1
lpts007 2020-12-21 09:40:45 +08:00 via Android 7
话说用了这个框架的人,发帖格式怎么都一样啊?
看来是有魔力,我也去用下试试 |
2
kevinwan OP |
3
Geekerstar 2020-12-21 09:50:03 +08:00
@lpts007 hhhh
|
4
zarte 2020-12-21 09:53:31 +08:00
其实我只想要个 go 写的网关
|
5
putaozhenhaochi 2020-12-21 10:00:12 +08:00
不是宣传 goctl 吗?
|
6
laminux29 2020-12-21 10:09:37 +08:00
......
数据中台本质上就是存储数据、统一数据并对外提供数据检索接口,业务没有任何难点,说白了就是 CURD 。但作为胶水特性的系统,最关键是要考虑与其他语言系统的可集成性,以及二开的便捷性。 因此,数据中台的实现,关键点在于,你用的编程语言,你的编程环境,是否针对集成与二开有帮助。 而且,这类系统,一般采购方都是体制内的,为了推锅,Oracle 肯定跑不了。 那么,假设你的用户,现在有烂大街的 java + Oracle 的方案,以及你的 go 方案,你觉得用户会买哪一套? |
7
bbao 2020-12-21 10:19:11 +08:00
kevinwan
大道至简! 🏢 好未来 / 资深专家 兄弟,啥也不说了。 |
9
GM 2020-12-21 10:22:29 +08:00
|
10
ZSeptember 2020-12-21 10:22:42 +08:00
额,这不就是一个 CRUD 接口吗。
|
11
huskar 2020-12-21 10:25:29 +08:00 via Android
就这?请移到推广
|
12
kiddingU 2020-12-21 10:31:36 +08:00
哎,我看了作者的一些发帖,感觉略微有点尬....开源这玩意怎么说了,酒香不怕巷子深~~不用特意去太多推广,好东西自然会有人用的
|
14
yplove156 2020-12-21 10:48:44 +08:00
别什么都往中台上套,框架就框架,中台是企业能力的沉淀,是数据能力、技术能力,业务能力的沉淀以达到对需求对快速响应。不是某一套框架、系统就可以说是中台的。
|
16
zhaohua 2020-12-21 11:06:05 +08:00
go-zero 也挺香的,但是这玩意叫中台你不觉得丢分吗?
|
18
kevinwan OP 下次不代发,哈哈,我的错
|
19
mrhhsg 2020-12-21 11:25:23 +08:00
...楼主你推广就推广呗,推广自己的开源作品这不寒碜
|
20
laminux29 2020-12-21 12:52:18 +08:00
@hinate 你和领导讲,用 Oracle 会贵一点,但如果丢数据,不用担责,因为这是世界上最好的数据库,如果它都丢数据了,别的数据库肯定只会更惨。
但如果去 IOE,不用 Oracle,改用免费数据库比如 mysql,到时候一堆问题,天天丢数据,还要花钱招高价运维,说不定成本更高,丢了数据还要自己担责。 你觉得领导会选啥? |
21
salmon5 2020-12-21 13:51:03 +08:00
你用一周就用一周呗,标题党,我还用一天呢
|
22
teawithlife 2020-12-21 14:25:56 +08:00
十多年开发,居然连跨域问题就解决不了。。。
|
23
ben1024 2020-12-21 14:36:20 +08:00
频繁发就挺烦
|
24
gowk 2020-12-21 14:41:08 +08:00 1
虽说我喜欢 Go,本来应该不遗余力的 Go 社区的发展壮大,但这么花式的推广,我是没有想到的。。
|
27
zk123 2020-12-21 19:21:22 +08:00
vs 和 goland 哪个写起 go 来体验比较好
|
28
sampeng 2020-12-21 19:25:46 +08:00 1
麻烦把中台二字去了。这种推广真的丢研发人的脸。
我不信有企业敢选择这样的设施 |
29
ErwinCheung 2020-12-21 19:50:57 +08:00 1
@zk123 goland JB 天下第一
|
30
Numbcoder 2020-12-21 19:58:27 +08:00 2
go-zero 没用过不做评价。
但就这几个简单功能,放在我司,交给三年左右经验的开发,用 py/node,最多两天完成,超过两天我都怀疑你在摸鱼 |
33
echowuhao 2020-12-21 21:53:48 +08:00
@whimsySun V 站上吹牛逼的太多了。
v 站上都是 2 天完成一个框架,一周完成 1 个 app 。 我之前一个 bug 搞了一个星期,老板还说我搞得快。大部分时间,一个 bug,半天就过去了。你们写代码都没有 bug 么。 |
34
echowuhao 2020-12-21 21:55:56 +08:00
我觉得有些人太消极了,你说人家不好,自己弄个好的。
|
35
whimsySun 2020-12-21 22:02:33 +08:00
@echowuhao 哈哈哈,不过文章有点标题党了一些,这几个模块一般不会归类到数据中台。没有用过 go-zero,看 goctl 确实挺方便。
|
37
echowuhao 2020-12-21 22:19:45 +08:00
这些概念本来就不是确定的。对于 linus 来讲,写数据库的都是前端。
|
39
Livid MOD @huskar
@noobalex 谢谢举报。这个主题已经被移动到 /go/promotions @kevinwan 软文只能发到 /go/promotions 如果你继续持续忽略我们的规则,那么我们只能封号了。 |