- Created by 郭强, last modified on Oct 11, 2022
👋 Hi,朋友们!GoFrame
框架v2.2.0
版本在今天正式发布啦!
本次版本的最大的看点在于:
- 重构并改进了开发者最频繁使用的校验组件,使得社区的开发者可以很方便地开发和维护内置校验规则。并且扩增了一些常用校验规则,使得组件内置规则更加丰富强大。
- 改建了数据库组件接口设计,使得社区开发者可以更简单地新增一个数据库类型的
driver
,目前框架通过社区组件的方式提供了9
种数据库类型的driver
实现,满足绝大部分业务项目的需求。尤其是本次版本新增了对国产达梦数据库的支持,未来我们期望社区的开发者能提供更多国产数据库类型的driver
实现,贡献给开源社区。 - 社区组件的丰富,本次主要新增了
3
种类型的配置中心接口实现,支持Apollo/Polaris/Kubernetes ConfigMap
。GoFrame
框架采用了模块化低耦设计,组件分为框架主库与社区组件。框架主库提供核心通用轻量的基础组件,而社区组件是与框架主库解耦的单独组件包,保证主库通用轻量的同时为框架扩充了更多的能力。 - 本次版本的代码贡献者超过
44
位,框架的贡献者达到了107
位。感谢大家为社区付出的努力和贡献!💖
Github ChangeLog:https://github.com/gogf/gf/releases/tag/v2.2.0
新特性
- 重构校验组件的内置校验规则管理器,增加并支持到了
59
种常用内置校验规则:数据校验-校验规则 - 新增社区组件
contrib/config/kubecm
,实现基于kubernetes configmap
的配置组件Adapter
实现:https://github.com/gogf/gf/tree/master/contrib/config/kubecm - 新增社区组件
contrib/config/apollo
,实现基于apollo
配置中心的配置组件Adapter
实现:https://github.com/gogf/gf/tree/master/contrib/config/apollo - 新增社区组件
contrib/config/polaris
,实现基于polaris
配置中心的配置组件Adapter
实现:https://github.com/gogf/gf/tree/master/contrib/config/polaris - 新增
contrib/drivers/dm
国产达梦数据库支持:https://github.com/gogf/gf/tree/master/contrib/drivers
主要改进
社区组件
ORM驱动实现
- 改进
contrib/drivers/pgsql
在ORM组件层面支持更多pgsql
内置的数据类型。 - 改进
contrib/drivers/pgsql
支持写入操作下的LastInsertId
特性。 - 改进
contrib/drivers/clickhouse
支持decimal.Decimal
数据类型。 - 新增
contrib/drivers/dm
国产达梦数据库支持:https://github.com/gogf/gf/tree/master/contrib/drivers
注册发现组件
- 改进
contrib/registry/etcd
实现,将日志对象改为接口属性,允许外部注册自定义的日志对象。
配置组件
- 新增社区组件
contrib/config/kubecm
,实现基于kubernetes configmap
的配置组件Adapter
实现:https://github.com/gogf/gf/tree/master/contrib/config/kubecm - 新增社区组件
contrib/config/apollo
,实现基于apollo
配置中心的配置组件Adapter
实现:https://github.com/gogf/gf/tree/master/contrib/config/apollo - 新增社区组件
contrib/config/polaris
,实现基于polaris
配置中心的配置组件Adapter
实现:https://github.com/gogf/gf/tree/master/contrib/config/polaris
数据库ORM
- 统一不同数据库类型下,单行字符串配置管理格式,并兼容支持已有不同数据库类型特定的配置格式:ORM使用配置
- 改进接口设计,简化
driver
实现逻辑,后续新增更多的数据库driver
支持更加简便。 - 新增
ToSQL
方法,用于将ORM操作生成可供调试的SQL
语句,并不真正执行SQL
。 - 新增
CatchSQL
方法,用于通过闭包方法获取内部执行的SQL
语句列表。 - 废弃
Core
对象中的GetStruct/GetStructs
方法,统一使用Scan
方法操作,以提高易用性。 - 数据库对象使用日志对象改为接口属性,允许外部注册自定义的日志对象。
- 新增
Extra
及Protocol
配置,用于设置额外的配置参数以及链接协议,默认通过Link
配置自动解析。 - 去掉
Filtered
接口,采用默认实现,简化复杂度、提高易用性。 - 新增
ConvertValueForLocal
及CheckLocalTypeForField
接口,用于自定义的数据类型转换及数据类型获取,并提供默认实现。 - 新增
ClearTableFields
方法,用于清理特定数据表的数据结构缓存:ORM高级特性-字段映射 - 新增
ClearTableFieldsAll
方法,用于清理当前数据库对象所有的数据表数据结构缓存:ORM高级特性-字段映射 - 新增
ClearCache
方法,用于清理特定数据表的所有查询缓存:ORM链式操作-查询缓存 - 新增
ClearCacheAll
方法,用于清理当前数据库对象所有的查询缓存:ORM链式操作-查询缓存 - 其他一些改进。
编解码组件
gcompress
- 新增
GzipPathWriter
方法没用与将特定路径下的文件压缩到指定的io.Writer
中。 - 新增ZipPathContent方法,用于使用
zip
算法打包压缩文件/目录并返回字节内容。
- 新增
gjson
- 将
ContentTypeJson
等字符串参数调整为ContentType
类型
- 将
错误处理
- 增加命令行参数
--gf.gerror.brief
及GF_GERROR_BRIEF
环境变量开关,控制是否在错误堆栈打印时过滤框架堆栈:错误处理-其他特性 - 其他一些细节改进。
网络组件
ghttp
- 新增常用中间件
MiddlewareJsonBody
用于校验请求Body
是否JSON
格式。 - 新增
GetListenedAddress
方法,用于获取HTTP Server
在指定:0
监听端口时系统随机分配的监听地址。 - 当服务端执行出错时,修改返回HTTP状态码为
500
。
- 新增常用中间件
gtcp
- 新增
GetListenedAddress/GetListenedPort
方法,用于获取TCP Server
在指定:0
监听端口时系统随机分配的监听地址/端口。
- 新增
gudp
- 新增
GetListenedAddress/GetListenedPort
方法,用于获取UDP Server
在指定:0
监听端口时系统随机分配的监听地址/端口。
- 新增
goai
- 生成接口文档时,支持内嵌结构体定义的属性。
- 去掉接口文档中重复的参数说明,特别是在
URL
和Body
中存在相同参数时。
gtrace
- 改进
WithTraceID
方法的错误提示为更明确的信息。 - 新增
WithUUID
方法,用于将标准的UUID
转换为OpenTelemetry
的TraceID
。
- 改进
系统组件
gcfg
- 调整
Available
接口方法定义,将resource
参数改为非必须参数。
- 调整
gcron
- 针对定时任务延迟的场景,增加时间差异计算逻辑,尽可能减少对定时任务的影响。
gctx
- 新增跨进程的链路跟踪支持。
- 新增
GetInitCtx/SetInitCtx
方法,用于main
包及包init
包初始化方法执行时的context
获取和设置。
glog
- 新增
ILogger
接口定义,用于跨组件使用日志组件时的接口化解耦。 - 其他细节改进。
- 新增
gres
- 资源
File
对象新增Export
方法,用于将该对象关联的资源导出到指定的磁盘路径。
- 资源
gstructs
- 将
RecursiveOption
从int
类型改进为自定义类型,并调整对应的方法参数定义。
- 将
文本处理
- 新增
gstr.IsGNUVersion
方法,用于判断给定的字符串是否满足GNU
版本规则。
工具方法
gconv
- 改进对
NaN
特殊字符串的int64/uint64
转换支持。
- 改进对
gutil
- 新增
GetOrDefaultStr/GetOrDefaultAny
方法,用于默认值和非必须参数的便捷处理。
- 新增
gvalid
- 重构内置校验规则管理器,使得新增一个内置校验非常简便。
- 增加并支持到了
59
种常用内置校验规则:数据校验-校验规则
功能修复
- 修复
garray/gmap/gset/glist/gtype/gvar
在容器对象为nil
场景下DeepCopy
的panic
问题。 - 修复
gtime
在对象为nil
场景下DeepCopy
的panic
问题。 - 修复数据库ORM链式操作
Group
方法在给定多个排序条件时的覆盖问题。 - 修复
HTTP Server
在JSON
格式字符串返回时的内容重复输出问题。 - 修复
gstr.Nl2Br
方法在部分场景下由于逻辑判断引起的数组访问越界问题。 - 修复查询数据表字段信息时表名为空场景的错误打印问题。
- 修复
Req
对象属性为*gjson.Json
类型的参数接收问题。
开发工具
- 改进
gen dao
命令,增加clear
参数,用于自动清理目标数据库中不存在的本地数据模型Go文件:数据规范-gen dao - 改进
gen service
命令:模块规范-gen service- 按照业务模块对结构体对象生成的接口进行整合。
- 增加
clear
参数,用于自动清理在logic
没有对应的接口代码及文件。 - 其他一些细节改进。
- 改进
run
命令,增加自定义的程序运行参数。
Content Menu
- No labels
3 Comments
hanqian
小陈
2.2的api稳定了没.....
huruhi
当前使用的gf版本为 2.4.1 版本但是 pgsql 在事物内使用 InsertAndGetId 方法依旧提示 LastInsertId is not supported by this driver" 是什么情况呀?代码如下:
g.DB().Transaction(ctx, func(ctx context.Context, tx gdb.TX) error {
var id int64
if id, err = tx.Model(dao.User.Table()).Ctx(ctx).InsertAndGetId(do.User{
Uid: uid,
Active: true,
}); err != nil {
return err
}