Go语言开发中redis的使用详解

2018-09-21 21:39

阅读:605

  前段时间因为忙一些其它的事情,分享的有些少,最近学习一下redis在Go语言开发中的应用。

  一、理论知识

  Redis是一个开源的、使用C语言编写的、支持网络交互的、可基于内存也可持久化的Key-Value数据库。

  Redis 优势

  性能极高 – Redis能读的速度是110000次/s,写的速度是81000次/s 。

  丰富的数据类型 – Redis支持二进制案例的 Strings, Lists, Hashes, Sets 及 Ordered Sets 数据类型操作。

  原子 – Redis的所有操作都是原子性的,同时Redis还支持对几个操作全并后的原子性执行。

  丰富的特性 – Redis还支持 publish/subscribe, 通知, key 过期等等特性。

  Redis与其他key-value存储有什么不同?

  Redis有着更为复杂的数据结构并且提供对他们的原子性操作,这是一个不同于其他数据库的进化路径。Redis的数据类型都是基于基本数据结构的同时对程序员透明,无需进行额外的抽象。

  Redis运行在内存中但是可以持久化到磁盘,所以在对不同数据集进行高速读写时需要权衡内存,因为数据量不能大于硬件内存。在内存数据库方面的另一个优点是,相比在磁盘上相同的复杂的数据结构,在内存中操作起来非常简单,这样Redis可以做很多内部复杂性很强的事情。同时,在磁盘格式方面他们是紧凑的以追加的方式产生的,因为他们并不需要进行随机访问。

  二、使用:

  在开发过程中我们使用到了开源库redis如下

  github地址

  

  文档地址:

  1、数据库的连接

  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、设置keys 过期时间

  在写入的时候如果设置了EX的时间,则当前的key过期时间为设置时间,不设置则当前的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、列表操作,存入一组数据

   //存列表 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))) } }

  以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持脚本之家。


评论


亲,登录后才可以留言!