1.什么是Redis
Redis是一个基于BSD开源的使用ANSI C语言编写、支持网络、可基于内存亦可持久化的日志型、Key-Value数据库,并提供多种语言的API.
- 1.Redis存储的是一个个的键值对
- 2.通常用Redis做缓存数据库
- 3.Redis的五种数据类型(字符串,哈希,链表,无序集合,有序集合)
2.Redis安装
Redis官方不支持windows安装,所以我们这里以ubuntu为例
wget http://download.redis.io/redis-stable.tar.gz
tar xzf redis-stable.tar.gz
cd redis-stable
make
3.Redis运行
Redis服务器默认使用6379端口
resis-server
也可以自己指定端口
redis-server --port 6380
客户端通过
redis-cli
来连接数据库服务器
也可以指定服务器地址和端口
redis-cli -h 127.0.0.1 -p 6380
测试客户端和服务器是否连通
PING
返回PONG说明连通了
4.Redis的基本使用
4.1 字符串
set key value 设置key的value
get key 得到key的value
incr key key如果是整型自增1
keys * 得到所有key
4.2 哈希
hset key filed value 设置key对象的field属性的value
hget key filed 得到key对象的field属性的value
hgetall key 得到key对象的所有的属性和值
4.3 链表
适合存储社交网站的新鲜事
lpush key value [value ...] 向链表key左边添加元素
rpush key value [value...] 向链表key右边添加元素
lpop key 移除key链表左边第一个元素
rpop key 移除key链表右边第一元素
lrange key start stop 获取链表中某一段,包含最大值,-1表示最后一个元素
4.4 集合类型
适合存储文章的标签,因为是唯一的
sadd key member [member ...] 向集合key中添加元素,如果元素已经存在则忽略
srem key member [member ...] 从集合key中删除元素
smembers key 返回集合key中所有的元素
sinter key [key ...] 多个集合执行交集运算
sdiff key [key ...] 多个集合执行差集运算
sunion key [key ...] 多个集合执行并集运算
4.5 有序集合
适用于通过文章访问量排序
zadd key score member [score member ...] 向有序集合key中加入一个或多个元素和分数,如果元素已经存在,则替换分数
zrem key member [member ...] 删除集合中一个或多个元素
zrange key start stop [withscores] 按元素分数从小到大顺序返回元素,如需获得对应元素的分数,在尾部加上withscores
zrevrange key start stop [withscores] 按元素分数从大到小顺序返回元素
5.Redis 数据库桌面管理工具
下载地址:http://redisdesktop.com/download
可以很方便的管理Redis数据库里的键值对
6.Redis 数据库其他说明
Redis默认支持16个数据库,编号0~15,每个数据库是独立的不能相互访问,可以通过
SELECT 数据库编号
来更换数据库
Redis不支持自定义数据库名字
Redis不支持每个数据库设置不同的密码
我们可以通过配置参数database修改支持的数据库个数,当选择的数据库编号超过最大数据库编号,默认使用最大数据库编号的数据库
清空当前数据库的所有内容
flushdb
清空所有数据库的所有内容
flushall
随机返回当前数据库的一个键
randomkey
删除一个或多个key
del key
返回给定哈希表中所有键的值
hvals key
如果需要将redis用作缓存,可以设置生存时间,这样就不会持久化存储
设置某个键的生存时间
1.(以秒为单位)
expire key time
2.(以毫秒为单位)
pexpire key time
以秒为单位返回给定key的剩余生存时间,没有设置生存时间则返回-1
tll key
下面我们来看一下怎么样在nodejs中使用redis
1.安装redis模块
npm install redis
通过redis.createClient(port,host,options)来连接redis服务器
var redis = require("redis"),
client = redis.createClient(6380,"117.121.25.228",{});
exports.throw = function(bottle,callback){
bottle.time = bottle.time || Date.now();
var bottleId = Math.random().toString(16);
var type = {male:0,female:1};
console.log(type[bottle.type]);
/*client.SELECT选择数据库编号*/
client.SELECT(type[bottle.type],function(){
/*client.HMSET 保存哈希键值*/
client.HMSET(bottleId,bottle,function(err,result){
if(err){
return callback({code:0,msg:"过会儿再来试试吧!"});
}
callback({code:1,msg:result});
/*设置过期时间为1天*/
client.EXPIRE(bottleId,86400);
});
});
}
exports.pick = function(info,callback){
var type = {all:Math.round(Math.random()),male:0,female:1};
info.type = info.type || 'all';
client.SELECT(type[info.type],function(){
/*随机返回当前数据库的一个键*/
client.RANDOMKEY(function(err,bottleId){
if(!bottleId){
return callback({code:0,msg:"大海空空如也..."});
}
/*根据key返回哈希对象*/
client.HGETALL(bottleId,function(err,bottle){
if(err){
return callback({code:0,msg:"漂流瓶破损了..."});
}
callback({code:1,msg:bottle});
/*根据key删除键值*/
client.DEL(bottleId);
});
});
});
}
网友评论