Redis简介 Redis是一个开源的使用ANSI C语言编写、支持网络、可基于内存亦可持久化的日志型、Key-Value数据库,并提供多种语言的API。从2010年3月15日起,Redis的开发工作由VMware主持。从2013年5月开始,Redis的开发由Pivotal赞助。
Redis是 NoSQL技术阵营中的一员,它通过多种键值数据类型来适应不同场景下的存储需求,借助一些高层级的接口使用其可以胜任,如缓存、队列系统的不同角色
Redis特性
1)Redis 与其他 key - value 缓存产品有以下三个特点: 2)Redis支持数据的持久化,可以将内存中的数据保存在磁盘中,重启的时候可以再次加载进行使用。 3)Redis不仅仅支持简单的key-value类型的数据,同时还提供list,set,zset,hash等数据结构的存储。 4)Redis支持数据的备份,即master-slave模式的数据备份。
Redis 优势
1)性能极高 – Redis能读的速度是110000次/s,写的速度是81000次/s 。 2)丰富的数据类型 – Redis支持二进制案例的 Strings, Lists, Hashes, Sets 及 Ordered Sets 数据类型操作。 3)原子 – Redis的所有操作都是原子性的,同时Redis还支持对几个操作全并后的原子性执行。 4)丰富的特性 – Redis还支持 publish/subscribe, 通知, key 过期等等特性。
Redis应用场景
1)用来做缓存(ehcache/memcached)——redis的所有数据是放在内存中的(内存数据库) 2)可以在某些特定应用场景下替代传统数据库——比如社交类的应用 3)在一些大型系统中,巧妙地实现一些特定的功能:session共享、购物车 4)只要你有丰富的想象力,redis可以用在可以给你无限的惊喜…….
安装 接下来以Ubuntu 18.04 系统为例安装Redis数据库:
step1:下载 wget http://download.redis.io/releases/redis-3.2.8.tar.gz
step2:解压 tar -zxvf redis-3.2.8.tar.gz
step3:复制,放到usr/local/redis⽬录下 sudo mv ./redis-3.2.8 /usr/local/redis/
step4:进⼊redis⽬录 cd /usr/local/redis/
step5:生成 a)安装c语言编译器gcc sudo apt-get install gcc b)安装编译命令make sudo apt-get install make(这一步可能会出问题,根据提示执行命令) c)生成 sudo make(比较慢)
step6:进入src下测试,这段运⾏时间会较⻓ sudo make test
可能会遇到下面的问题
解决方法 cd wget http://downloads.sourceforge.net/tcl/tcl8.6.1-src.tar.gz sudo tar xzvf tcl8.6.1-src.tar.gz -C /usr/local/ cd /usr/local/tcl8.6.1/unix/ sudo ./configure sudo make(时间比较长) sudo make install
我们继续来安装
step7:安装到usr/local/redis,将redis的命令安装到/usr/local/bin/⽬录 sudo make install (时间比较长)
step8:安装完成后,我们进入目录/usr/local/bin中查看 cd /usr/local/bin
ls -all 看到以下文件
a)redis-server redis服务器 b)redis-cli redis命令行客户端 c)redis-benchmark redis性能测试工具 d)redis-check-aof AOF文件修复工具 e)redis-check-rdb RDB文件检索工具
配置系统文件
step9:配置⽂件,移动到/etc/⽬录下 配置⽂件⽬录为/usr/local/redis/redis.conf sudo cp /usr/local/redis/redis.conf /etc/redis/ Redis的配置信息在/etc/redis/redis.conf下: 查看 sudo vi /etc/redis/redis.conf 核心配置选项 绑定ip:如果需要远程访问,可将此⾏注释,或绑定⼀个真实ip bind 127.0.0.1 端⼝,默认为6379 port 6379 是否以守护进程运⾏ a)如果以守护进程运⾏,则不会在命令⾏阻塞,类似于服务 b)如果以⾮守护进程运⾏,则当前终端被阻塞 c)设置为yes表示守护进程,设置为no表示⾮守护进程 d)推荐设置为yes daemonize yes 数据⽂件 dbfilename dump.rdb 数据⽂件存储路径 dir /var/lib/redis ⽇志⽂件 logfile /var/log/redis/redis-server.log 数据库,默认有16个 database 16 主从复制,类似于双机备份。 slaveof 服务器端和客户端命令 服务器端 服务器端的命令为redis-server 可以使⽤help查看帮助⽂档 redis-server --help 推荐使⽤服务的⽅式管理redis服务 启动 sudo service redis start 停⽌ sudo service redis stop 重启 sudo service redis restart 个人习惯 ps -aux|grep redis 查看redis服务器进程 sudo kill -9 pid 杀死redis服务器 sudo redis-server /etc/redis/redis.conf 指定加载的配置文件 客户端 客户端的命令为redis-cli 可以使⽤help查看帮助⽂档 redis-cli --help 连接redis redis-cli 运⾏测试命令 ping 出现PONG表示数据库连接成功了 切换数据库 数据库没有名称,默认有16个,通过0-15来标识,连接redis默认选择第一个数据库 select n 数据库结构 redis是key-value的数据结构,每条数据都是⼀个键值对 键的类型是字符串 注意:键不能重复
值的类型分为五种: 1)字符串string 2)哈希hash 3)列表list 4)集合set 5)有序集合zset: 数据库操作行为 1)保存 2)修改 3)获取 4)删除
通过go语言和redis数据库进行交互
安装命令 go get -u-v github.com/gomodule/redigo/redis
安装完成后,回到家目录创建test.go,把下面代码复制到test.go里面,编译执行test.go,之后在redis中查找到键c1值为hello,说明安装成功
package main import ( "github.com/gomodule/redigo/redis") func main(){ conn,_ := redis.Dial("tcp", ":6379") defer conn.Close() conn.Do("set", "c1", "hello") }
操作方法 Go操作redis文档https://godoc.org/github.com/gomodule/redigo/redis 连接数据库 Dial(network, address string)(conn,err)
执行数据库操作命令 Send(commandName string, args ...interface{}) error Flush() error Receive() (reply interface{}, err error)
Send函数发出指令,flush将连接的输出缓冲区刷新到服务器,Receive接收服务器返回的数据 例如: c.Send("SET", "foo", "bar") c.Send("GET", "foo") c.Flush()//把缓冲区命令发到服务器 c.Receive() // 接收set请求返回的数据 v, err = c.Receive() // 接收get请求传输的数据
另外一种执行数据库操作命令 Do(commandName string, args ...interface{}) (reply interface{}, err error)
reply helper functions(回复助手函数) Bool,Int,Bytes,map,String,Strings和Values函数将回复转换为特定类型的值。为了方便地包含对连接Do和Receive方法的调用,这些函数采用了类型为error的第二个参数。如果错误是非nil,则辅助函数返回错误。如果错误为nil,则该函数将回复转换为指定的类型:
exists, err := redis.Bool(c.Do("EXISTS", "foo")) if err != nil { //处理错误代码 } reflect.TypeOf(exists)//打印exists类型
Scan函数 func Scan(src [] interface {},dest ... interface {})([] interface {},error)
Scan函数从src复制到dest指向的值。 Dest参数的值必须是整数,浮点数,布尔值,字符串,[]byte,interface{}或这些类型的切片。Scan使用标准的strconv包将批量字符串转换为数字和布尔类型。
示例代码
var value1 int var value2 string reply, err := redis.Values(c.Do("MGET", "key1", "key2")) if err != nil { //处理错误代码 } if _, err := redis.Scan(reply, &value1, &value2); err != nil { // 处理错误代码 }
序列化与反序列化 序列化(字节化) var buffer bytes.Buffer//容器 enc :=gob.NewEncoder(buffer)//编码器 err:=enc.Encode(dest)//编码
反序列化(反字节化) dec := gob.NewDecoder(bytes.NewReader(buffer.bytes()))//解码器 dec.Decode(src)//解码