这是我参与「第五届青训营 」伴学笔记创作活动的第 5 天
一、本章重点知识
Go框架三件套详解(Web/RPC/ORM) 并了解Gorm、Kitex和Hertz
二、详细知识介绍
Go框架三件套详解(Web/RPC/ORM)
Gorm
(1)定义gorm model //使用名为ID的字段作为主键
(2)为model定义表名
(3)连接数据库
(4)创建数据
如何使用Upsert:使用clause.OnConflict处理数据冲突
如何使用默认值:通过使用default标签为字段定义默认值
(5)查询数据
使用结构体作为查询条件
当使用结构作为条件查询时,GORM只会查询非零值字段。这意味着如果您的字段值为0、“、false或其他零值,该字段不会被用于构建查询条件,使用Map来构建查询条件
(6)更新数据
使用Struct更新时,只会更新非零值,如果需要更新零值可以使用Map更新或使用Select选择字段
(7)删除数据
GORM提供了gorm.DeleteAt用于帮助用户实现软删
拥有软删除能力的Model调用Delete时,记录不会被从数据库中真正删除。但GORM会将DeletedAt置为当前时间,并且你不能再通过正常的查询方法找到该记录
使用Unscoped可以查询到被软删的数据
(8)事物
GORM提供了Begin、Commit、Rollback方法用于使用事物。提供了Tansaction方法用于自动提交事务,避免用户漏写Commit、Rollback
Gorm支持数据库
Gorm性能提高:对于写操作(创建、更新、删除),为了确保数据的完整性,Gorm会将它们封装在事物内运行。但这会降低性能,你可以使用SkipDefaultTransaction关闭默认事务。使用PrepareStmt缓存编译语句可以提高后续调用的速度。
Gorm生态
- GORM代码生成工具 github.com/go-gorm/gen
- GORM分片库方案 github.com/go-gorm/sha…
- GORM手动索引 github.com/go-gorm/hin…
- GORM乐观锁 github.com/go-gorm/opt…
- GORM读写分离 github.com/go-gorm/dbr…
- GORM OpenTelemetry扩展 github.com/go-gorm/ope…
Kitex
使用IDL定义服务与接口
如果我们要进行RPC,就需要知道对方的接口是什么,需要传什么参数,同时也需要知道返回值是什么样的。这时候就需要通过IDL来约定双方的协议。
定义IDL
namespace go api
struct Request{
1:string message
}
struct Response{
1:string message
}
service Echo{
Response echo(1:Request req)
}
使用kitex -module example -service example echo.thrift 命令生成代码
Kitex Client 发起请求
创建Client
import"example/kitex_gen/api/echo"
import"github.com/cloudwego/kitex/client"
c,err:=echo.NewClient("example",client.WithHostPorts("0.0.0.0:8888"))
if err!=nil{
log.Fatal(err)
}
发起请求
import"example/kitex_gen/api"
req:=&api.Request{Message:"my request"}
resp,err:=c.Echo(context.Background(),req,callopt.WithRPCTimeout(3*time.Second))
if err!=nil{
log.Fatal(err)
}
log.Println(resp)
Kitex生态
- XDS扩展 github.com/kitex-contr…
- opentelemetry扩展 github.com/kitex-contr…
- ETCD服务注册与发展扩展 github.com/kitex-contr…
- Nacos服务注册与发展扩展 github.com/kitex-contr…
- Zookeeper服务注册与发展扩展 github.com/kitex-contr…
- polaris扩展 github.com/kitex-contr…
- 丰富的示例代码与业务Demo github.com/cloudwego/k…
Hertz
基本使用:使用Hertz实现,服务监听8080端口并注册了一个GET方法的路由函数
Hertz提供了GET、POST、PUT、DELETE、ANY等方法用于注册路由
Hertz提供了路由组(Group)的能力,用于支持路由分组的功能
Hertz提供了参数路由和通配路由,路由的优先级为:静态路由>命名路由>通配路由
Hertz提供了Bind、Validate、BindAndValidate函数用于进行参数绑定和校验
Hertz提供了HTTP Client用于帮助用户发送HTTP请求
Hertz性能
- 网络Netpoll
- Json编解码Sonic
- 使用sync.Pool复用对象协议层数据解析优化