GO(9[TCP/Redis/原子操作])

发布时间:2020-07-30 18:20:15 作者:zhaichaoqun
来源:网络 阅读:1596

Tcp编程

.....

Redis


使⽤第三⽅开源的redis库: github.com/garyburd/redigo/redis
import(

“github.com/garyburd/redigo/redis"
)
9. 链接redis
    

redis
package main
import (
"fmt"
"github.com/garyburd/redigo/redis"
)
func main() {
    c, err := redis.Dial("tcp", "localhost:6379")
    if err != nil {
    fmt.Println("conn redis failed,", err)
    return
    }
    defer c.Close()
}

10. Set 接⼝

package main
import (
"fmt"
"github.com/garyburd/redigo/redis"
)
func main() {
    c, err := redis.Dial("tcp", "localhost:6379")
    if err != nil {
    fmt.Println("conn redis failed,", err)
    return
    }
    defer c.Close()
    _, err = c.Do("Set", "abc", 100)
    if err != nil {
    fmt.Println(err)
    return
    }
    r, err := redis.Int(c.Do("Get", "abc"))
    if err != nil {
    fmt.Println("get abc failed,", err)
    return
    }
    fmt.Println(r)
}

11. Hash表
    

package main
import (
"fmt"
"github.com/garyburd/redigo/redis"
)
func main() {
    c, err := redis.Dial("tcp", "localhost:6379")
    if err != nil {
    fmt.Println("conn redis failed,", err)
    return
    }
    defer c.Close()
    _, err = c.Do("HSet", "books", "abc", 100)
    if err != nil {
    fmt.Println(err)
    return
    }
    r, err := redis.Int(c.Do("HGet", "books", "abc"))
    if err != nil {
    fmt.Println("get abc failed,", err)
    return
    }
    fmt.Println(r)
}

11. 批量Set
    

package main
import (
"fmt"
"github.com/garyburd/redigo/redis"
)
func main() {
    c, err := redis.Dial("tcp", "localhost:6379")
    if err != nil {
    fmt.Println("conn redis failed,", err)
    return
    }
    defer c.Close()
    _, err = c.Do("MSet", "abc", 100, "efg", 300)
    if err != nil {
    fmt.Println(err)
    return
    }
    r, err := redis.Ints(c.Do("MGet", "abc", "efg"))
    if err != nil {
    fmt.Println("get abc failed,", err)
    return
    }
    for _, v := range r {
    fmt.Println(v)
    }
}

11. 过期时间
    

package main
import (
"fmt"
"github.com/garyburd/redigo/redis"
)
func main() {
    c, err := redis.Dial("tcp", "localhost:6379")
    if err != nil {
    fmt.Println("conn redis failed,", err)
    return
    }
    defer c.Close()
    _, err = c.Do("expire", "abc", 10)
    if err != nil {
    fmt.Println(err)
    return
    }
}

12. 队列操作
    

package main
import (
"fmt"
"github.com/garyburd/redigo/redis"
)
func main() {
    c, err := redis.Dial("tcp", "localhost:6379")
    if err != nil {
    fmt.Println("conn redis failed,", err)
    return
    }
    defer c.Close()
    _, err = c.Do("lpush", "book_list", "abc", "ceg", 300)
    if err != nil {
    fmt.Println(err)
    return
    }
r, err := redis.String(c.Do("lpop", "book_list"))
    if err != nil {
    fmt.Println("get abc failed,", err)
    return
    }
fmt.Println(r)



推荐阅读:
  1. go mysql 报错-表的字符集和代码链接的字符集合不同
  2. Go语言之并发示例-Pool(二)

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

go tcp redis

上一篇:nagios插件脚本check_linux_stats.pl 安装

下一篇:基于ESRIMAP的WPF地图效果

相关阅读

您好,登录后才能下订单哦!

密码登录
登录注册
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》