我用CentOS 7的VMware 虚拟机作为redis-server
- 安装 调试
yum install redis
vim /etc/redis.conf
修改 bind 0.0.0.0 使其监听在所有地址, 默认端口6379,不用更改
systemctl start redis
这个时候我们就可以连接上去了
好!
接下来 安装golang的redis 库
go get github.com/go-redis/redis
接下来,我们开始使用golang操作redis
先创建连接
conn := redis.NewClient(&redis.Options{
Addr:"192.168.66.139:6379",
Password:"",
DB:0,
})
返回的conn结构,NewClient的参数为Options结构体
其中Addr为redis服务器的地址,Password为密码,DB为数据库号,默认0号
我们使用经典的ping-pong来测试连通性
pong,err := conn.Ping().Result()
if err != nil {
panic(err)
return
}
fmt.Println(pong)
如果能连上,则会在终端打印PONG
连接成功后,我们开始执行一些操作,
String操作
set(key, value):给数据库中名称为key的string赋予值value
get(key):返回数据库中名称为key的string的value
getset(key, value):给名称为key的string赋予上一次的value
mget(key1, key2,…, key N):返回库中多个string的value
setnx(key, value):添加string,名称为key,值为value
setex(key, time, value):向库中添加string,设定过期时间time
mset(key , value ,key,value...):批量设置多个string的值
msetnx(key N, value N):如果所有名称为key i的string都不存在
incr(key):名称为key的string增1操作
incrby(key, integer):名称为key的string增加integer
decr(key):名称为key的string减1操作
decrby(key, integer):名称为key的string减少integer
append(key, value):名称为key的string的值附加value
substr(key, start, end):返回名称为key的string的value的子串
来一部分简单实例, 以及Set方法详细类型
err = conn.Set("city","zyxasr@qq.com",100*time.Second).Err()
if err != nil {
panic(err)
return
}
//func (c *cmdable) Set(key, value interface{},过期时间) *StatusCmd
//key string
//过期时间 time.Duration
/*
type StatusCmd struct {
baseCmd
val string
}
Methods:
redis.Val() string
redis.Result() (string, error)
redis.String() string
redis.readReply(cn *pool.Conn) error
*/
val,err := conn.Get("city").Result()
if err != nil {
panic(err)
return
}
fmt.Println(val)
err = conn.MSet("city","1","haha","2").Err()
if err != nil {
panic(err)
}
conn.Incr("city") //自增
//func (c *cmdable) Incr(key string) *IntCmd
conn.IncrBy("city",10000)//增加制定数值
//func (c *cmdable) IncrBy(key string, value int64) *IntCmd
conn.SetNX("woaini","nihaoa",100*time.Second)
xx,err := conn.MGet("city","haha").Result()
//一次获得多个key
if err != nil{panic(err)}
fmt.Println(xx)
List 操作
rpush(key, value):在名称为key的list尾添加一个值为value的元素
lpush(key, value):在名称为key的list头添加一个值为value的 元素
llen(key):返回名称为key的list的长度
lrange(key, start, end):返回名称为key的list中start至end之间的元素
ltrim(key, start, end):截取名称为key的list
lindex(key, index):返回名称为key的list中index位置的元素
lset(key, index, value):给名称为key的list中index位置的元素赋值
lrem(key, count, value):删除count个key的list中值为value的元素
lpop(key):返回并删除名称为key的list中的首元素
rpop(key):返回并删除名称为key的list中的尾元素
blpop(key1, key2,… key N, timeout):lpop命令的block版本。
brpop(key1, key2,… key N, timeout):rpop的block版本。
rpoplpush(srckey, dstkey):返回并删除名称为srckey的list的尾元素,并将该元素添加到名称为dstkey的list的头部
还是写一写栗子.
func ListOperation(conn *redis.Client) {
err := conn.RPush("hanzhong","dwadwa","dwadwada").Err()
if err != nil {
panic(err)
return
}
//func (c *cmdable) RPush(key string, values ...interface{}) *IntCmd
//RPush 从右侧插入
err = conn.LPush("hangzhou","xxx","zzz","ccc").Err()
if err != nil {
panic(err)
return
}
b := conn.LLen("hangzhou").Val()
fmt.Println(b)
//计算给定key的长度
n:= conn.LRem("hangzhou",10,"xxx")
fmt.Println(n)
//func (c *cmdable) LRem(key string, count int64, value interface{}) *IntCmd
// 删除key的一个值 多少次
xixi,err := conn.LRange("hangzhou",0,-1).Result()
fmt.Println(xixi)
// 遍历List
haha := conn.LPop("hangzhou")
fmt.Println(haha)
//左侧弹出,并打印
}
Set 操作方法
sadd(key, member):向名称为key的set中添加元素member
srem(key, member) :删除名称为key的set中的元素member
spop(key) :随机返回并删除名称为key的set中一个元素
smove(srckey, dstkey, member) :移到集合元素
scard(key) :返回名称为key的set的基数
sismember(key, member) :member是否是名称为key的set的元素
sinter(key1, key2,…key N) :求交集
sinterstore(dstkey, (keys)) :求交集并将交集保存到dstkey的集合
sunion(key1, (keys)) :求并集
sunionstore(dstkey, (keys)) :求并集并将并集保存到dstkey的集合
sdiff(key1, (keys)) :求差集
sdiffstore(dstkey, (keys)) :求差集并将差集保存到dstkey的集合
smembers(key) :返回名称为key的set的所有元素
srandmember(key) :随机返回名称为key的set的一个元素
实例
func SetOperation(conn *redis.Client) {
conn.SAdd("blacklist","tom")
conn.SAdd("blacklist","jerry")
conn.SAdd("blacklist","jenny")
conn.SAdd("whitelist","danny")
conn.SAdd("whitelist","jenny")
Isval,err := conn.SIsMember("blacklist","jenny").Result()
if err != nil {
fmt.Println(err)
return
}
fmt.Printf("is blacklist member: %v\n",Isval)
Jiaoji,err := conn.SInter("blacklist","whitelist").Result()
checkError(err)
fmt.Println(Jiaoji)
n,err :=conn.SInterStore("jiaoji","blacklist","whitelist").Result()
fmt.Println(n)
Chaji :=conn.SDiff("whitelist","blacklist")
fmt.Println(Chaji)
str,err := conn.SMembers("blacklist").Result()
checkError(err)
fmt.Println(str)
str2,err := conn.SRandMemberN("blacklist",2).Result()
checkError(err)
fmt.Println(str2)
str3,err := conn.SRandMember("blacklist").Result()
checkError(err)
fmt.Println(str3)
}
func checkError(err error) {
if err!= nil {
panic(err)
return
}
}
Hash 操作
hset(key, field, value):向名称为key的hash中添加元素field
hget(key, field):返回名称为key的hash中field对应的value
hmget(key, (fields)):返回名称为key的hash中field i对应的value
hmset(key, (fields)):向名称为key的hash中添加元素field
hincrby(key, field, integer):将名称为key的hash中field的value增加integer
hexists(key, field):名称为key的hash中是否存在键为field的域
hdel(key, field):删除名称为key的hash中键为field的域
hlen(key):返回名称为key的hash中元素个数
hkeys(key):返回名称为key的hash中所有键
hvals(key):返回名称为key的hash中所有键对应的value
hgetall(key):返回名称为key的hash中所有的键(field)及其对应的value
func hashOperation(conn *redis.Client) {
err:= conn.HSet("Name","address","hanzhong").Err()
checkError(err)
str1 := conn.HGet("Name","address")
fmt.Println(str1)
var map1 = make(map[string]interface{})
map1["hello"] = "nihao"
map1["huashan"] = "HuChong Ling"
map1["shuzi"] = 1
conn.HMSet("Name",map1)
//func (c *cmdable) HMSet(keystring, fields map[string]interface{}) *StatusCmd
slice1,err:=conn.HMGet("Name","hello","address","huashan","shuzi").Result()
checkError(err)
fmt.Println(slice1)
conn.HIncrBy("Name","shuzi",100)
str2,err := conn.HGet("Name","shuzi").Result()
checkError(err)
fmt.Println(str2)
flag,_ :=conn.HExists("Name","shuzi").Result()
if flag {
fmt.Println("They Have The field shuzi")
}
str3,err :=conn.HDel("Name","wocao").Result()
checkError(err)
fmt.Println(str3)
slice2,_ := conn.HKeys("Name").Result()
fmt.Println(slice2)
slice3,_ :=conn.HVals("Name").Result()
fmt.Println(slice3)
map2,_:= conn.HGetAll("Name").Result()
fmt.Println(map2)
}
To be Continue…