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

學(xué)無先后,達(dá)者為師

網(wǎng)站首頁 編程語言 正文

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

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

前言摘要

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

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

GoFrame gredis

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

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

配置文件(推薦)

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

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

# Redis數(shù)據(jù)庫配置
[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]

各配置項說明如下:

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

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

不傳遞分組名稱時,默認(rèn)使用redis.default配置分組項)來獲取對應(yīng)配置的redis客戶端單例對象。 執(zhí)行后,輸出結(jié)果為:

使用示例:

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())
}

打印結(jié)果

v

配置方法(高級)

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

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

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

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

其中name參數(shù)為分組名稱,即為通過分組來對配置對象進(jìn)行管理,我們可以為不同的配置對象設(shè)置不同的分組名稱,隨后我們可以通過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))
}

總結(jié)

gredis相關(guān)的知識點比較多,所以打算拆成多篇文章進(jìn)行更新。

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

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

欄目分類
最近更新