Redis 是一个开源(BSD许可)的,内存中的数据结构存储系统,它可以用作数据库、缓存和消息中间件。 它支持多种类型的数据结构,如 字符串(strings), 散列(hashes), 列表(lists), 集合(sets), 有序集合(sorted sets) 与范围查询, bitmaps, hyperloglogs 和 地理空间(geospatial) 索引半径查询。 Redis 内置了 复制(replication),LUA脚本(Lua scripting), LRU驱动事件(LRU eviction),事务(transactions) 和不同级别的 磁盘持久化(persistence), 并通过 Redis哨兵(Sentinel)和集群(Cluster)提供高可用性(high availability)。
特点:
Redis数据库完全在内存中,使用磁盘仅用于持久性。
相比许多键值数据存储,Redis拥有一套较为丰富的数据类型。
Redis可以将数据复制到任意数量的从服务器。
命令:
测试:ping 返回pong
字符串:get set
哈希:hmset hget hgetall
hmset student name "taoshihan" point 100
hgetall student
hget student name
列表:
lpush lrange
lpush users "taoshihan2"
lrange users 0 -1
集合:元素唯一
sadd smembers
sadd people aaa
smembers people
有序集合:成员有分数
zadd zrangebyscore
zadd man 2 aaa
zadd man 1 bbb
zrangebyscore man 0 1000
订阅:
subscribe publish
subscribe testChat
publish testChat "hello world"
事务:
multi exec
multi开启事务,写命令,exec开始执行
php:
1.pecl install redis;//安装扩展
2.配置php.ini
3.php -m|grep redis ;//检测扩展<?php
$redis = new Redis();
$redis->connect('127.0.0.1', 6379);
$redis->set('name_1', 'taoshihan');
$name=$redis->get('name_1');
var_dump($name);
//hash
$redis->hMSet("student",array("name"=>"taoshihan","point"=>200));
$res=$redis->hGet("student","point");
var_dump($res);
//list
$redis->lPush('users', 'lisi');
$res=$redis->lRange('users', 0, -1);
var_dump($res);
//set
$redis->sAdd('people' , 'member1');
$res=$redis->sMembers('people');
var_dump($res);
//Sorted sets
$redis->zAdd('man', 5, 'val5');
$res=$redis->zRange('man', 0, -1);
var_dump($res);
//Pub/sub
$redis->publish('testChat', 'hello, world php!');
function f($redis, $chan, $msg) {
echo $chan.":".$msg."\r\n";
}
//$redis->subscribe(array('testChat'), 'f');
//transactions
$ret = $redis->multi()
->set('key1', 'val1')
->get('key1')
->set('key2', 'val2')
->get('key2')
->exec();
var_dump($ret);
|