• <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>
            Fork me on GitHub
            隨筆 - 215  文章 - 13  trackbacks - 0
            <2010年2月>
            31123456
            78910111213
            14151617181920
            21222324252627
            28123456
            78910111213


            專注即時通訊及網游服務端編程
            ------------------------------------
            Openresty 官方模塊
            Openresty 標準模塊(Opm)
            Openresty 三方模塊
            ------------------------------------
            本博收藏大部分文章為轉載,并在文章開頭給出了原文出處,如有再轉,敬請保留相關信息,這是大家對原創作者勞動成果的自覺尊重!!如為您帶來不便,請于本博下留言,謝謝配合。

            常用鏈接

            留言簿(1)

            隨筆分類

            隨筆檔案

            相冊

            Awesome

            Blog

            Book

            GitHub

            Link

            搜索

            •  

            積分與排名

            • 積分 - 215465
            • 排名 - 118

            最新評論

            閱讀排行榜


            http://www.cnblogs.com/wolfred7464/p/4670864.html

            redis的client有好多好多,go語言的client在redis官方有兩個推薦,radix和redigo。選擇哪一個好呢?確實很糾結,后來擲硬幣決定選擇redigo了。

            redis、go、redigo的安裝就不需要提了,不能強行增加篇幅。

            redigo使用起來很人性化,api設計的符合直覺,我對redis了解較少,使用過程中基本沒有遇到障礙。

            redigo的使用入門可以去查godoc:http://godoc.org/github.com/garyburd/redigo/redis

            接下來就是毫無技術含量的貼代碼了:

            連接redis我一般是這樣寫的:

            c, err := redis.Dial("tcp", "127.0.0.1:6379")
            if err != nil {
                fmt.Println(err)
                return
            }
            defer c.Close()

            執行命令使用Do函數,跟在redis-cli敲命令的感覺差不多的:

            v, err := c.Do("SET", "name", "red")
            if err != nil {
                fmt.Println(err)
                return
            }
            fmt.Println(v)
            v, err = redis.String(c.Do("GET", "name"))
            if err != nil {
                fmt.Println(err)
                return
            }
            fmt.Println(v)


            列表也是一樣:

            c.Do("lpush", "redlist", "qqq")
            c.Do("lpush", "redlist", "www")
            c.Do("lpush", "redlist", "eee")


            讀取列表可以for循環遍歷,也可以使用redis.Scan函數:

            values, _ := redis.Values(c.Do("lrange", "redlist", "0", "100"))

            for _, v := range values {
                fmt.Println(string(v.([]byte)))
            }

            // 或者
            var v1 string
            redis.Scan(values, &v1)
            fmt.Println(v1)


            管道:

            c.Send("SET", "name", "red")
            c.Send("GET", "name")
            c.Flush()
            c.Receive()
            c.Receive()

            發布訂閱:

            func subscribe() {
                c, err := redis.Dial("tcp", "127.0.0.1:6379")
                if err != nil {
                    fmt.Println(err)
                    return
                }
                defer c.Close()

                psc := redis.PubSubConn{c}
                psc.Subscribe("redChatRoom")
                for {
                    switch v := psc.Receive().(type) {
                    case redis.Message:
                        fmt.Printf("%s: message: %s\n", v.Channel, v.Data)
                    case redis.Subscription:
                        fmt.Printf("%s: %s %d\n", v.Channel, v.Kind, v.Count)
                    case error:
                        fmt.Println(v)
                        return
                    }
                }
            }


            go subscribe()
            go subscribe()
            go subscribe()
            go subscribe()
            go subscribe()

            c, err := redis.Dial("tcp", "127.0.0.1:6379")
            if err != nil {
                fmt.Println(err)
                return
            }
            defer c.Close()

            for {
                var s string
                fmt.Scanln(&s)
                _, err := c.Do("PUBLISH", "redChatRoom", s)
                if err != nil {
                    fmt.Println("pub err: ", err)
                    return
                }
            }
            posted on 2016-09-22 15:41 思月行云 閱讀(2996) 評論(0)  編輯 收藏 引用 所屬分類: GolangRedis\Mongo
            久久99精品久久只有精品| 亚洲国产成人乱码精品女人久久久不卡 | 久久久久国产亚洲AV麻豆| 久久93精品国产91久久综合| 久久91精品综合国产首页| 伊人久久大香线蕉AV一区二区| 一本色道久久88精品综合| 99久久精品费精品国产| 久久久久av无码免费网| 国产精品xxxx国产喷水亚洲国产精品无码久久一区 | 婷婷久久香蕉五月综合加勒比| 久久国产精品一区二区| 亚洲精品第一综合99久久| www.久久精品| 久久精品青青草原伊人| 久久国产成人精品麻豆| 精品国产青草久久久久福利| 久久久久免费精品国产| 99久久精品国产一区二区| 久久久久亚洲AV成人网人人网站| 无码人妻久久久一区二区三区 | 久久国产成人精品国产成人亚洲| 久久国产精品无| 久久精品亚洲欧美日韩久久| 久久精品国产亚洲一区二区| 色综合久久无码中文字幕| 性做久久久久久久久浪潮| 精品视频久久久久| 成人a毛片久久免费播放| 亚洲狠狠综合久久| 7国产欧美日韩综合天堂中文久久久久 | 精品欧美一区二区三区久久久| 97精品久久天干天天天按摩| 日韩精品久久久肉伦网站| 少妇久久久久久被弄高潮| 狠狠色综合网站久久久久久久高清| 亚洲国产综合久久天堂| 亚洲国产成人久久笫一页| 欧美麻豆久久久久久中文| 午夜精品久久久久| 亚洲国产精品久久电影欧美|