202 Star 1.9K Fork 613

张奇峰 / GinSkeleton

加入 Gitee
与超过 1200万 开发者一起发现、参与优秀开源项目,私有仓库也完全免费 :)
免费加入
克隆/下载
global_variable.md 4.12 KB
一键复制 编辑 原始数据 按行查看 历史
WormW 提交于 2022-06-15 16:56 . 修正拼写错误global(golobal)

项目中被初始化的全局变量清单介绍

1.前言

1.程序启动时初始化动作统一由 bootstrap/init.go 文件中的代码段负责,本次我们将介绍3个常用的全局变量.
2.全局变量只会使用法简洁化, 不对原始语法造成任何破坏, 封装全局变量时我们经过谨慎地评估、测试相关代码段、从而保证并发安全性.

2.gorm 全局变量

1.请按照配置文件 congfig/gorm_v2.yml 中的提示正确配置数据库,开启程序启动初始化数据库参数,程序在启动时会自动为您初始化全局变量.
2.不同类型的数据库全局变量名不一样, 对照关系参见以下代码段说明.
3.更多用法参见单元测试:gorm_v2单元测试.
4.本文档我们主要介绍 gorm 全局变量初始化的核心.


//  例如:原始语法,我们以 mysql 驱动的初始化为例进行说明
// 1.连接数据库,获取mysql连接
 dsn := "user:pass@tcp(127.0.0.1:3306)/dbname?charset=utf8mb4&parseTime=True&loc=Local"
 mysqlDb, err := gorm.Open(mysql.Open(dsn), &gorm.Config{})  

// 2.查询
db.Select("id", "name", "phone", "email", "remark").Where("name  like ?", "%test%").Find(&users)


// 本项目中, `variable.GormDbMysql` 完全等于上文中返回的 mysqlDb
variable.GormDbMysql.Select("id", "name", "phone", "email", "remark").Where("name  like ?", "%test%").Find(&users)

// gorm 数据库驱动与本项目骨架对照关系
variable.GormDbMysql       <====完全等于==>      gorm.Open(mysql.Open(dsn), &gorm.Config{})    
variable.GormDbSqlserver   <====完全等于==>      gorm.Open(sqlserver.Open(dsn), &gorm.Config{})    
variable.GormDbPostgreSql  <====完全等于==>      gorm.Open(postgres.Open(dsn), &gorm.Config{})   

3.日志全局变量

1.为了随意、方便地记录项目中日志,我们封装了全局变量 variable.ZapLog .
2.由于日志操作内容比较多,我们对它进行了单独介绍,详情参见: zap高性能日志

4.配置文件全局变量

1.为了更方便地操作配置文件 config/config.ymlconfig/gorm_v2.yml 我们同样在项目启动时封装了全局变量.
2.variable.ConfigYml ,该变量相当于配置文件 config/config.yml 文件打开后的指针.
3.variable.ConfigGormv2Yml ,该变量相当于配置文件 config/gorm_v2.yml 文件打开后的指针.
4.在任何地方您都可以使用以上全局变量直接获取对应配置文件的 键==>值.


// 获取 config/config.yml 文件中 Websocket.Start 对应的 Int 值
variable.ConfigYml.GetInt("Websocket.Start")

// 获取 config/gorm_v2.yml 文件中 Gormv2.Mysql.IsInitGlobalGormMysql 对应的 Int 值
variable.ConfigGormv2Yml.GetInt("Gormv2.Mysql.IsInitGlobalGormMysql")

5.获取配置文件中键对应的值数据类型,函数清单,您可以使用 variable.ConfigYml. 或者 variable.ConfigGormv2Yml. 以下函数名 获取值

    // 开发者常用函数
	GetString(keyName string) string
	GetInt(keyName string) int
	GetInt32(keyName string) int32
	GetInt64(keyName string) int64
	GetFloat64(keyName string) float64
	GetDuration(keyName string) time.Duration
	GetBool(keyName string) bool

    // 非常用函数,主要是项目骨架在使用
	ConfigFileChangeListen()
	Clone(fileName string) YmlConfigInterf
	Get(keyName string) interface{} // 该函数获取一个 键 对应的原始值,因此返回类型为 interface , 基本很少用
	GetStringSlice(keyName string) []string

5.雪花算法(snowflake)生成分布式场景唯一ID

1.相关配置 config>config.yml 配置项 SnowFlakeMachineId , 如果本项目同时部署在多台机器,并且需要同时使用该算法,请为每一台机器设置不同的ID,区间范围: [0,1023]
2.随时随地,您可以非常方便的获取一个分布式场景的唯一ID
3.更多详情参见: SnowFlake单元测试


# 雪花算法生成的全局唯一ID数据类型为 int64
variable.SnowFlake.GetId()
Go
1
https://gitee.com/daitougege/GinSkeleton.git
git@gitee.com:daitougege/GinSkeleton.git
daitougege
GinSkeleton
GinSkeleton
master

搜索帮助