~~~
package main
import (
"encoding/json"
"fmt"
"tanex.com/library/dao/common"
"tanex.com/library/dao/config"
"tanex.com/library/dao/gorm"
"tanex.com/library/dao/log"
"tanex.com/library/dao/redis"
"tanex.com/library/dao/sqlx"
"tanex.com/library/dao/zookeeper"
)
const (
MySqlList_1 = "/MySqlList_1"
RedisPath = "/RedisPath"
MySqlList_2 = "/MySqlList_2"
ZaptestLog = "Zap_test_Log"
)
var (
testCfg = &config.Config{}
testReady = &GetReady{}
testService = &Service{}
)
type GetReady struct {
zookeeperClient *zookeeper.ZookeeperMgr
}
func InitZookeeper(cfg *config.Config) *GetReady {
return &GetReady{
zookeeperClient: zookeeper.InitZookeeper(cfg.ZkCfg),
}
}
type Service struct {
redisClient *redis.RedisSingleMgr
logClient *log.LogMgr
mysqlTest1Client *sqlx.SqlxMgr
mysqlTest2Client *gorm.GormMgr
}
func InitService(cfg *config.Config) *Service {
return &Service{
redisClient: redis.InitRedisSingle(cfg.RedisCfg),
logClient: log.InitLog(cfg.LogCfg),
mysqlTest1Client: sqlx.InitSqlx(cfg.MysqlCfg),
mysqlTest2Client: gorm.InitGorm(ChangeDbName(cfg)),
}
}
func ChangeDbName(cfg *config.Config) (cfg2 *config.MysqlCfg) {
cfg2 = &config.MysqlCfg{
User: cfg.MysqlCfg.User,
Password: cfg.MysqlCfg.Password,
Addrs: cfg.MysqlCfg.Addrs,
DBName: "test_2",
}
return cfg2
}
func InitConfig(cfg []string) {
//初始化Zk
testCfg.ZkCfg = &config.ZkCfg{cfg}
testReady = InitZookeeper(testCfg)
//獲取Zk上Redis配置
redisConfigByte, _, err := testReady.zookeeperClient.Get(RedisPath)
if err != nil {
common.SimplePanic("獲取ZK上"+RedisPath+"的配置失敗", "Error", err.Error(), "Path", RedisPath)
}
var redisConfigList []config.RedisCfg
if err = json.Unmarshal(redisConfigByte, &redisConfigList); err != nil {
common.SimplePanic("解析ZK上RedisCluster的數據失敗", "Error", err.Error())
}
//獲取Zk上MySQL配置
mysqlConfigByte, _, err := testReady.zookeeperClient.Get(MySqlList_2)
if err != nil {
common.SimplePanic("獲取ZK上"+MySqlList_2+"的配置失敗", "Error", err.Error(), "Path", MySqlList_2)
}
var mysqlConfig []config.MysqlCfg
if err = json.Unmarshal(mysqlConfigByte, &mysqlConfig); err != nil {
common.SimplePanic("解析ZK上MysqlCfg的數據失敗", "Error", err.Error())
}
testCfg = &config.Config{
RedisCfg: &config.RedisCfg{Addr: fmt.Sprintf("%s:%d", redisConfigList[0].IP, redisConfigList[0].Port), Password: redisConfigList[0].Password},
LogCfg: &config.LogCfg{ProgramName: "Test", Debug: true},
MysqlCfg: &config.MysqlCfg{
Addrs: fmt.Sprintf("%s:%d", mysqlConfig[0].IP, mysqlConfig[0].Port),
User: mysqlConfig[0].User,
Password: mysqlConfig[0].Password,
DBName: mysqlConfig[0].DBName,
},
}
testService = InitService(testCfg)
fmt.Println("-------InitConfig-------")
//初始化日記
testService.logClient.ZapCustom(ZaptestLog)
//日志庫在寫的時候是異步的, 如果主進程過快結束可能沒有東西打印
}
~~~
- 第一例 留言板
- 第二例 gRPC使用例子
- 第三例 基于go-micro做服務注冊和服務發現
- 第四例 聊天室
- 第五例 工具庫 第五例 并發安全字典
- dao
- common
- common.go
- config
- config.go
- gorm
- grom.go
- sqlx
- sqlx.go
- kafka
- kafka.go
- log
- log.go
- log2.go
- redis
- redis.go
- zookeeper
- zookeeper.go
- init
- main.go
- 第六例 原生sql操作
- 第七例 sqlx操作
- 第八例 Redis數據庫(gomodule/redigo)
- 第九例 Redis消息隊列
- 第十例 Redis集群連接
- 第十一例 Zookeeper操作
- 第十二例 Kafka操作
- 第十三例 NSQ操作
- 第十四例 二分查找
- 第十五例 交換排序 - 冒泡排序
- 第十六例 插入排序 - 直接插入排序
- 第十七例 插入排序 - 希爾排序
- 第十八例 交換排序 - 快速排序
- 第十九例 算法求解應用
- 第二十例 pprof性能分析
- 第二一例 CPU信息采集
- 第二二例 Heap信息采集
- 第二三例 Http信息采集
- 第二四例 單元測試(功能測試)
- 第二五例 基準測試(壓力測試/性能測試)
- 第二六例 gdb調試
- 第二七例 json序列化和反序列化
- 第二八例 protobuf序列化和反序列化
- 第二九例 包管理工具 go vendor
- 第三十例 包管理工具 go mod
- 第三一例 zip壓縮
- 第三二例 交叉編譯
- 第三三例 線上環境部署
- 第三四例 業務:實現固定周期維護
- 第三五例 聊天室(精簡版)
- 第三六例 并發安全字典
- 第三七例 導出Excel表格
- 第三八例 導出CSV表格
- 第三九例 聊天室(高并發)
- 第四十例 JWT (Json Web Token)
- 第四一例 雪花算法生成 Id
- 第四二例 對稱加密 AES
- 第四三例 非對稱加密 RSA
- 第四四例 簽名算法 SHA1
- 第四五例 數據庫操作 gorm
- 第四六例 數據庫操作 gorm 集合
- 數據庫連接和創建表
- 查詢 - 分頁
- 查詢所有數據
- 查詢單條數據
- 插入一條或多條數據
- 更新一條或多條數據
- 更新一條或多條數據(有零值)
- 第四七例 RSA(MD5WithRSA 算法)簽名和驗簽方式
- 第四八例 線上部署腳本
- 第四九例 Elasticsearch
- 第五十例 對象池
- 第五十一例 相關閱讀