溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊(cè)×
其他方式登錄
點(diǎn)擊 登錄注冊(cè) 即表示同意《億速云用戶服務(wù)條款》

golang redis客戶端怎么連接

發(fā)布時(shí)間:2022-01-15 16:50:30 來源:億速云 閱讀:158 作者:iii 欄目:大數(shù)據(jù)

這篇文章主要介紹“golang redis客戶端怎么連接”的相關(guān)知識(shí),小編通過實(shí)際案例向大家展示操作過程,操作方法簡單快捷,實(shí)用性強(qiáng),希望這篇“golang redis客戶端怎么連接”文章能幫助大家解決問題。

實(shí)現(xiàn)了redis客戶端,包括一個(gè)連接池和redis pipleline

conn.go

func (c *conn) Do(cmd string, args ...interface{}) (interface{}, error){

if cmd != "" {    if err := c.writeCommand(cmd, args); err != nil {      return nil, c.fatal(err)    }  }    if err := c.bw.Flush(); err != nil {    return nil, c.fatal(err)  }      for i := 0; i <= pending; i++ {    var e error    if reply, e = c.readReply(); e != nil {      return nil, c.fatal(e)    }    if e, ok := reply.(Error); ok && err == nil {      err = e    }  }


方法封裝了一個(gè)請(qǐng)求的3個(gè)過程 Send, Flush and Receive

1,send 將請(qǐng)求寫到輸出緩沖

2, Flush將緩沖區(qū)的命令發(fā)送到服務(wù)端

3,Receive 接收服務(wù)端的響應(yīng)

https://godoc.org/github.com/gomodule/redigo/redis#hdr-Pipelining

// conn is the low-level implementation of Conntype conn struct {
 // Shared  mu      sync.Mutex  pending int  err     error  conn    net.Conn
 // Read  readTimeout time.Duration  br          *bufio.Reader
 // Write  writeTimeout time.Duration  bw           *bufio.Writer
 // Scratch space for formatting argument length.  // '*' or '$', length, "\r\n"  lenScratch [32]byte
 // Scratch space for formatting integers and floats.  numScratch [40]byte}

以上就是連接操作的核心代碼

因?yàn)閞edis是文本協(xié)議,因此發(fā)送時(shí)需要按照redis協(xié)議序列化,接收的時(shí)候按照redis協(xié)議反序列化。

客戶端發(fā)送命令的格式(類型):5種類型

    間隔符號(hào),在Linux下是\r\n,在Windows下是\n

1. 簡單字符串 Simple Strings, 以 "+"加號(hào) 開頭

      格式:+ 字符串 \r\n

               字符串不能包含 CR或者 LF(不允許換行)

      eg: "+OK\r\n"

      注意:為了發(fā)送二進(jìn)制安全的字符串,一般推薦使用后面的 Bulk Strings類型

2. 錯(cuò)誤 Errors, 以"-"減號(hào) 開頭

  格式:- 錯(cuò)誤前綴 錯(cuò)誤信息 \r\n

               錯(cuò)誤信息不能包含 CR或者 LF(不允許換行),Errors與Simple Strings很相似,不同的是Erros會(huì)被當(dāng)作異常來看待

      eg: "-Error unknow command 'foobar'\r\n"

3. 整數(shù)型 Integer, 以 ":" 冒號(hào)開頭

  格式:: 數(shù)字 \r\n

      eg: ":1000\r\n"

4. 大字符串類型 Bulk Strings, 以 "$"美元符號(hào)開頭,長度限制512M

  格式:$ 字符串的長度 \r\n 字符串 \r\n

               字符串不能包含 CR或者 LF(不允許換行);

      eg: "$6\r\nfoobar\r\n"    其中字符串為 foobar,而6就是foobar的字符長度

            "$0\r\n\r\n"       空字符串

            "$-1\r\n"           null

5. 數(shù)組類型 Arrays,以 "*"星號(hào)開頭

  格式:* 數(shù)組元素個(gè)數(shù) \r\n 其他所有類型 (結(jié)尾不需要\r\n)

             注意:只有元素個(gè)數(shù)后面的\r\n是屬于該數(shù)組的,結(jié)尾的\r\n一般是元素的

      eg: "*0\r\n"      空數(shù)組

           "*2\r\n$2\r\nfoo\r\n$3\r\nbar\r\n"      數(shù)組包含2個(gè)元素,分別是字符串foo和bar

    "*3\r\n:1\r\n:2\r\n:3\r\n"       數(shù)組包含3個(gè)整數(shù):1、2、3

           "*5\r\n:1\r\n:2\r\n:3\r\n:4\r\n$6\r\nfoobar\r\n"  包含混合類型的數(shù)組

           "*-1\r\n"         Null數(shù)組

           "*2\r\n*3\r\n:1\r\n:2\r\n:3\r\n*2\r\n+Foo\r\n-Bar\r\n"   數(shù)組嵌套,外層數(shù)組包含2個(gè)數(shù)組,整理后如下:

                 "*2\r\n

      *3\r\n:1\r\n:2\r\n:3\r\n

      *2\r\n+Foo\r\n-Bar\r\n"

關(guān)于“golang redis客戶端怎么連接”的內(nèi)容就介紹到這里了,感謝大家的閱讀。如果想了解更多行業(yè)相關(guān)的知識(shí),可以關(guān)注億速云行業(yè)資訊頻道,小編每天都會(huì)為大家更新不同的知識(shí)點(diǎn)。

向AI問一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場,如果涉及侵權(quán)請(qǐng)聯(lián)系站長郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI