前段时间因为忙一些其它的事情,分享的有些少,最近学习一下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地址
https://github.com/garyburd/redigo
文档地址:
http://godoc.org/github.com/garyburd/redigo/redis
1、数据库的连接
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、设置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))) } }
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。
免责声明:本站资源来自互联网收集,仅供用于学习和交流,请遵循相关法律法规,本站一切资源不代表本站立场,如有侵权、后门、不妥请联系本站删除!
《魔兽世界》大逃杀!60人新游玩模式《强袭风暴》3月21日上线
暴雪近日发布了《魔兽世界》10.2.6 更新内容,新游玩模式《强袭风暴》即将于3月21 日在亚服上线,届时玩家将前往阿拉希高地展开一场 60 人大逃杀对战。
艾泽拉斯的冒险者已经征服了艾泽拉斯的大地及遥远的彼岸。他们在对抗世界上最致命的敌人时展现出过人的手腕,并且成功阻止终结宇宙等级的威胁。当他们在为即将于《魔兽世界》资料片《地心之战》中来袭的萨拉塔斯势力做战斗准备时,他们还需要在熟悉的阿拉希高地面对一个全新的敌人──那就是彼此。在《巨龙崛起》10.2.6 更新的《强袭风暴》中,玩家将会进入一个全新的海盗主题大逃杀式限时活动,其中包含极高的风险和史诗级的奖励。
《强袭风暴》不是普通的战场,作为一个独立于主游戏之外的活动,玩家可以用大逃杀的风格来体验《魔兽世界》,不分职业、不分装备(除了你在赛局中捡到的),光是技巧和战略的强弱之分就能决定出谁才是能坚持到最后的赢家。本次活动将会开放单人和双人模式,玩家在加入海盗主题的预赛大厅区域前,可以从强袭风暴角色画面新增好友。游玩游戏将可以累计名望轨迹,《巨龙崛起》和《魔兽世界:巫妖王之怒 经典版》的玩家都可以获得奖励。