主頁(yè) > 知識(shí)庫(kù) > Go語(yǔ)言開(kāi)發(fā)中redis的使用詳解

Go語(yǔ)言開(kāi)發(fā)中redis的使用詳解

熱門(mén)標(biāo)簽:AI電銷(xiāo) 鐵路電話系統(tǒng) 百度競(jìng)價(jià)排名 服務(wù)外包 地方門(mén)戶網(wǎng)站 呼叫中心市場(chǎng)需求 Linux服務(wù)器 網(wǎng)站排名優(yōu)化

前段時(shí)間因?yàn)槊σ恍┢渌氖虑椋窒淼挠行┥?,最近學(xué)習(xí)一下redis在Go語(yǔ)言開(kāi)發(fā)中的應(yīng)用。

一、理論知識(shí)

Redis是一個(gè)開(kāi)源的、使用C語(yǔ)言編寫(xiě)的、支持網(wǎng)絡(luò)交互的、可基于內(nèi)存也可持久化的Key-Value數(shù)據(jù)庫(kù)。

Redis 優(yōu)勢(shì)

性能極高 – Redis能讀的速度是110000次/s,寫(xiě)的速度是81000次/s 。

豐富的數(shù)據(jù)類(lèi)型 – Redis支持二進(jìn)制案例的 Strings, Lists, Hashes, Sets 及 Ordered Sets 數(shù)據(jù)類(lèi)型操作。

原子 – Redis的所有操作都是原子性的,同時(shí)Redis還支持對(duì)幾個(gè)操作全并后的原子性執(zhí)行。

豐富的特性 – Redis還支持 publish/subscribe, 通知, key 過(guò)期等等特性。

Redis與其他key-value存儲(chǔ)有什么不同?

Redis有著更為復(fù)雜的數(shù)據(jù)結(jié)構(gòu)并且提供對(duì)他們的原子性操作,這是一個(gè)不同于其他數(shù)據(jù)庫(kù)的進(jìn)化路徑。Redis的數(shù)據(jù)類(lèi)型都是基于基本數(shù)據(jù)結(jié)構(gòu)的同時(shí)對(duì)程序員透明,無(wú)需進(jìn)行額外的抽象。

Redis運(yùn)行在內(nèi)存中但是可以持久化到磁盤(pán),所以在對(duì)不同數(shù)據(jù)集進(jìn)行高速讀寫(xiě)時(shí)需要權(quán)衡內(nèi)存,因?yàn)閿?shù)據(jù)量不能大于硬件內(nèi)存。在內(nèi)存數(shù)據(jù)庫(kù)方面的另一個(gè)優(yōu)點(diǎn)是,相比在磁盤(pán)上相同的復(fù)雜的數(shù)據(jù)結(jié)構(gòu),在內(nèi)存中操作起來(lái)非常簡(jiǎn)單,這樣Redis可以做很多內(nèi)部復(fù)雜性很強(qiáng)的事情。同時(shí),在磁盤(pán)格式方面他們是緊湊的以追加的方式產(chǎn)生的,因?yàn)樗麄儾⒉恍枰M(jìn)行隨機(jī)訪問(wèn)。

二、使用:

在開(kāi)發(fā)過(guò)程中我們使用到了開(kāi)源庫(kù)redis如下

github地址

https://github.com/garyburd/redigo

文檔地址:

http://godoc.org/github.com/garyburd/redigo/redis

1、數(shù)據(jù)庫(kù)的連接

func connDB() (c redis.Conn, err error) {
  db, err := redis.Dial("tcp", "127.0.0.1:6379")
  if err != nil {
    fmt.Println("Connect to redis error", err)
    return
  }
  return db, err
}

2、寫(xiě)入

func saveToDB(c redis.Conn) {
  _, err := c.Do("SET", "name", "qiuqiu", "EX", "50")
  if err != nil {
    fmt.Println("redis set failed:", err)
  } else {
    fmt.Println("save success")
  }
}

//批量寫(xiě)入
_, err := c.Do("MSET", "name", "superWang", "SEX", "F", "EX", "50")
  if err != nil {
    fmt.Println("redis set failed:", err)
  } else {
    fmt.Println("save success")
  }

//tips:EX是這個(gè)值的過(guò)期時(shí)間

3、讀取

func readFromDB(c redis.Conn) {
  username, err := redis.String(c.Do("GET", "name"))
  if err != nil {
    fmt.Println("redis get failed:", err)
  } else {
    fmt.Printf("Get mykey: %v \n", username)
  }

}
//批量讀取
func readFromDB(c redis.Conn) {
  username, err := redis.Strings(c.Do("MGET", "SEX", "name"))
  if err != nil {
    fmt.Println("redis get failed:", err)
  } else {
    fmt.Printf("Get mykey: %v \n", username)
  }

}

4、刪除

func delFromDB(c redis.Conn) {
  _, err := c.Do("DEL", "name", "SEX")
  if err != nil {
    fmt.Println("redis delete failed:", err)
  } else {
    fmt.Println("delete success")
  }
}

5、設(shè)置keys 過(guò)期時(shí)間

在寫(xiě)入的時(shí)候如果設(shè)置了EX的時(shí)間,則當(dāng)前的key過(guò)期時(shí)間為設(shè)置時(shí)間,不設(shè)置則當(dāng)前的key永久有效

6、讀寫(xiě)json到redis

//寫(xiě)json
func saveJsonDataToDB(c redis.Conn) {
  imap := map[string]string{"name": "waiwaigo", "phone": "13498739038"}
  value, _ := json.Marshal(imap)
  n, err := c.Do("SETNX", "jsonkey", value)
  if err != nil {
    fmt.Println(err)
  }
  if n == int64(1) {
    fmt.Println("success")
  }
}

//讀json
func readJsonFromDB(c redis.Conn) {
  var imapGet map[string]string
  valueGet, err := redis.Bytes(c.Do("GET", "jsonkey"))
  if err != nil {
    fmt.Println(err)
  }

  errShal := json.Unmarshal(valueGet, imapGet)
  if errShal != nil {
    fmt.Println(err)
  }
  fmt.Println(imapGet["name"])
  fmt.Println(imapGet["phone"])
}

7、列表操作,存入一組數(shù)據(jù)

//存列表
func saveListToDB(c redis.Conn) {
  _, err := c.Do("lpush", "username", "zhangsan")
  if err != nil {
    fmt.Println("redis set failed:", err)
  }

  _, err = c.Do("lpush", "username", "lisi")
  if err != nil {
    fmt.Println("redis set failed:", err)
  }
  _, err = c.Do("lpush", "username", "wangwu")
  if err != nil {
    fmt.Println("redis set failed:", err)
  }
}

//讀列表
func readListFromDB(c redis.Conn) {
  values, _ := redis.Values(c.Do("lrange", "username", "0", "2"))
  fmt.Printf("count%d", len(values))
  for _, v := range values {
    fmt.Println(string(v.([]byte)))
  }
}

以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。

您可能感興趣的文章:
  • 在Golang中使用Redis的方法示例
  • Go語(yǔ)言中通過(guò)Lua腳本操作Redis的方法
  • go語(yǔ)言操作redis連接池的方法
  • Go語(yǔ)言操作redis用法實(shí)例

標(biāo)簽:銅川 仙桃 蘭州 崇左 衡水 黃山 湖南 湘潭

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《Go語(yǔ)言開(kāi)發(fā)中redis的使用詳解》,本文關(guān)鍵詞  ;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問(wèn)題,煩請(qǐng)?zhí)峁┫嚓P(guān)信息告之我們,我們將及時(shí)溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無(wú)關(guān)。
  • 相關(guān)文章
  • 收縮
    • 微信客服
    • 微信二維碼
    • 電話咨詢

    • 400-1100-266