這篇文章給大家介紹如何在golang開發(fā)中使用redis,內(nèi)容非常詳細(xì),感興趣的小伙伴們可以參考借鑒,希望對大家能有所幫助。
一、理論知識
Redis是一個開源的、使用C語言編寫的、支持網(wǎng)絡(luò)交互的、可基于內(nèi)存也可持久化的Key-Value數(shù)據(jù)庫。
Redis 優(yōu)勢
性能極高 – Redis能讀的速度是110000次/s,寫的速度是81000次/s 。
豐富的數(shù)據(jù)類型 – Redis支持二進(jìn)制案例的 Strings, Lists, Hashes, Sets 及 Ordered Sets 數(shù)據(jù)類型操作。
原子 – Redis的所有操作都是原子性的,同時Redis還支持對幾個操作全并后的原子性執(zhí)行。
豐富的特性 – Redis還支持 publish/subscribe, 通知, key 過期等等特性。
Redis與其他key-value存儲有什么不同?
Redis有著更為復(fù)雜的數(shù)據(jù)結(jié)構(gòu)并且提供對他們的原子性操作,這是一個不同于其他數(shù)據(jù)庫的進(jìn)化路徑。Redis的數(shù)據(jù)類型都是基于基本數(shù)據(jù)結(jié)構(gòu)的同時對程序員透明,無需進(jìn)行額外的抽象。
Redis運行在內(nèi)存中但是可以持久化到磁盤,所以在對不同數(shù)據(jù)集進(jìn)行高速讀寫時需要權(quán)衡內(nèi)存,因為數(shù)據(jù)量不能大于硬件內(nèi)存。在內(nèi)存數(shù)據(jù)庫方面的另一個優(yōu)點是,相比在磁盤上相同的復(fù)雜的數(shù)據(jù)結(jié)構(gòu),在內(nèi)存中操作起來非常簡單,這樣Redis可以做很多內(nèi)部復(fù)雜性很強(qiáng)的事情。同時,在磁盤格式方面他們是緊湊的以追加的方式產(chǎn)生的,因為他們并不需要進(jìn)行隨機(jī)訪問。
二、使用:
在開發(fā)過程中我們使用到了開源庫redis如下
github地址
https://github.com/garyburd/redigo
文檔地址:
http://godoc.org/github.com/garyburd/redigo/redis
1、數(shù)據(jù)庫的連接
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、寫入
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") } } //批量寫入 _, 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是這個值的過期時間
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 過期時間
在寫入的時候如果設(shè)置了EX的時間,則當(dāng)前的key過期時間為設(shè)置時間,不設(shè)置則當(dāng)前的key永久有效
6、讀寫json到redis
//寫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))) } }
關(guān)于如何在golang開發(fā)中使用redis就分享到這里了,希望以上內(nèi)容可以對大家有一定的幫助,可以學(xué)到更多知識。如果覺得文章不錯,可以把它分享出去讓更多的人看到。
另外有需要云服務(wù)器可以了解下創(chuàng)新互聯(lián)scvps.cn,海內(nèi)外云服務(wù)器15元起步,三天無理由+7*72小時售后在線,公司持有idc許可證,提供“云服務(wù)器、裸金屬服務(wù)器、高防服務(wù)器、香港服務(wù)器、美國服務(wù)器、虛擬主機(jī)、免備案服務(wù)器”等云主機(jī)租用服務(wù)以及企業(yè)上云的綜合解決方案,具有“安全穩(wěn)定、簡單易用、服務(wù)可用性高、性價比高”等特點與優(yōu)勢,專為企業(yè)上云打造定制,能夠滿足用戶豐富、多元化的應(yīng)用場景需求。
分享標(biāo)題:如何在golang開發(fā)中使用redis-創(chuàng)新互聯(lián)
轉(zhuǎn)載來源:http://chinadenli.net/article16/cdhigg.html
成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供建站公司、虛擬主機(jī)、小程序開發(fā)、搜索引擎優(yōu)化、Google、網(wǎng)頁設(shè)計公司
聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時需注明來源: 創(chuàng)新互聯(lián)
猜你還喜歡下面的內(nèi)容