后端与Go框架三件套|青训营笔记

102 阅读3分钟

这是我参与「第五届青训营 」伴学笔记创作活动的第 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生态

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生态

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复用对象协议层数据解析优化