日本免费高清视频-国产福利视频导航-黄色在线播放国产-天天操天天操天天操天天操|www.shdianci.com

學無先后,達者為師

網站首頁 編程語言 正文

GoFrame?gredis配置文件及配置方法對比_Golang

作者:王中陽Go ? 更新時間: 2022-08-04 編程語言

前言摘要

上一篇文章為大家介紹了 GoFrame gcache使用實踐 | 緩存控制 淘汰策略 ,得到了大家積極的反饋。

后續幾篇文章再接再厲,仍然為大家介紹GoFrame框架緩存相關的知識點,以及自己項目使用中的一些總結思考,GoFrame框架下文簡稱gf。

GoFrame gredis

goframe框架支持兩種方式來管理redis配置和獲取redis對象,一種是通過配置文件+單例對象的方式;一種是模塊化通過配置管理方法及對象創建方法。

而我們是使用的前者:通過配置文件+單例對象的方式。

配置文件(推薦)

絕大部分情況下推薦使用g.Redis單例方式來操作redis。

推薦使用配置文件來管理Redis配置,在config.toml中的配置示例如下:

# Redis數據庫配置
[redis]
    default = "127.0.0.1:6379,0"
    cache   = "127.0.0.1:6379,1,123456?idleTimeout=600"

其中,Redis的配置格式為:

host:port[,db,pass?maxIdle=x&maxActive=x&idleTimeout=x&maxConnLifetime=x]

各配置項說明如下:

配置項名稱 是否必須 默認值 說明
host - 地址
port - 端口
db 0 數據庫
pass - 授權密碼
maxIdle 10 允許閑置的連接數(0表示不限制)
maxActive 100 最大連接數量限制(0表示不限制)
idleTimeout 10 連接最大空閑時間(單位秒,不允許設置為0)
maxConnLifetime 30 連接最長存活時間(單位秒,不允許設置為0)
tls false 是否使用TLS認證
skipVerify false 通過TLS連接時,是否禁用服務器名稱驗證

其中的default和cache分別表示配置分組名稱,我們在程序中可以通過該名稱獲取對應配置的redis單例對象。

不傳遞分組名稱時,默認使用redis.default配置分組項)來獲取對應配置的redis客戶端單例對象。 執行后,輸出結果為:

使用示例:

package main
import (
    "fmt"
    "github.com/gogf/gf/frame/g"
    "github.com/gogf/gf/util/gconv"
)
func main() {
    g.Redis().DoVar("SET", "k", "v")
    v, _ := g.Redis().DoVar("GET", "k")
    fmt.Println(v.String())
}

打印結果

v

配置方法(高級)

由于gf是模塊化的框架,除了可以通過耦合且便捷的g模塊來自動解析配置文件并獲得單例對象之外,也支持開發者模塊化使用gredis包。

但是這種用法對開發者的要求相對較高。

gredis提供了全局的分組配置功能,相關配置管理方法如下:

func SetConfig(config Config, name ...string)
func GetConfig(name ...string) (config Config, ok bool)
func RemoveConfig(name ...string)
func ClearConfig()

其中name參數為分組名稱,即為通過分組來對配置對象進行管理,我們可以為不同的配置對象設置不同的分組名稱,隨后我們可以通過Instance單例方法獲取redis客戶端操作對象單例。

func Instance(name ...string) *Redis

使用示例:

package main
import (
	"fmt"
	"github.com/gogf/gf/database/gredis"
	"github.com/gogf/gf/util/gconv"
)
var (
	config = gredis.Config{
		Host : "127.0.0.1",
		Port : 6379,
		Db   : 0,
	}
)
func main() {
	group := "test"
	gredis.SetConfig(&config, group)
	redis := gredis.Instance(group)
	defer redis.Close()
	_, err := redis.Do("SET", "k", "v")
	if err != nil {
		panic(err)
	}
	r, err := redis.Do("GET", "k")
	if err != nil {
		panic(err)
	}
	fmt.Println(gconv.String(r))
}

總結

gredis相關的知識點比較多,所以打算拆成多篇文章進行更新。

這篇文章重點為大家介紹了gredis的配置方式:支持配置文件進行管理,也支持通過配置方法進行管理。

原文鏈接:https://juejin.cn/post/7108272085452980261

欄目分類
最近更新