php的redis手册
❶ 如何使用Redis 做队列操作
redis设计用来做缓存的,但是由于它自身的某种特性使得它可以用来做消息队列,它有几个阻塞式的API可以使用,正是这些阻塞式的API让其有能力做消息队列;
另外,做消息队列的其他特性例如FIFO(先入先出)也很容易实现,只需要一个list对象从头取数据,从尾部塞数据即可;
redis能做消息队列还得益于其list对象blpop brpop接口以及Pub/Sub(发布/订阅)的某些接口,它们都是阻塞版的,所以可以用来做消息队列。
❷ 怎么安装redis php扩展,windows下
1、首先到相应网站下载redis:
下载完成后解压到任意盘符如:D:/redis
里面包括:如图所示。
redis-server.exe:服务程序
redis-check-mp.exe:本地数据库检查
redis-check-aof.exe:更新日志检查
redis-benchmark.exe:性能测试,用以模拟同时由N个客户端发送M个 SETs/GETs 查询 (类似于 Apache 的ab 工具).
当然还需要一个:redis.conf(具体内容网上随便搜都会有)
8、PHP代码测试
$redis = new Redis();
$redis->connect("192.168.138.2","6379"); //php客户端设置的ip及端口
//存储一个 值
$redis->set("say","Hello World");
echo $redis->get("say"); //应输出Hello World
//存储多个值
$array = array('first_key'=>'first_val',
'second_key'=>'second_val',
'third_key'=>'third_val');
$array_get = array('first_key','second_key','third_key');
$redis->mset($array);
var_mp($redis->mget($array_get));
❸ php 怎么把session写入redis
一、 安装phpredis扩展
php连接redis需要安装phpredis扩展。
下载地址:https://github.com/phpredis/phpredis/releases,选用相应版本。
笔者用的是php5.6.29,下载了phpredis-3.0.0安装出了问题,于是换成phpredis-2.2.8,正常。
# tar zxvf phpredis-2.2.8.tar.gz && cd phpredis-2.2.8
# /usr/local/php/bin/phpize
# ./configure --with-php-config=/usr/local/php/bin/php-config
# make && make install
正常情况下会提示在下面目录下生成redis.so文件
Installing shared extensions: /usr/local/php/lib/php/extensions/no-debug-non-zts-20131226/
# sed -i '$aextension="redis.so"' /usr/local/php/etc/php.ini
# service httpd restart
验证:
# php -i | grep redis | grep -xq redis && echo ok || echo "phpredis extended failure"
二、 配置php连接redis(笔者使用的阿里云redis)
# sed -i 's/session.save_handler.*/session.save_handler = redis/' /usr/local/php/etc/php.ini
# sed -i '/session.save_handler/asession.save_path ="tcp://xxxx.rds.aliyuncs.com?auth=redis密码"' /usr/local/php/etc/php.ini
# service httpd restart
❹ thinkphp redis 怎么选择数据库
1、redis 中的每一个数据库,都由一个 redisDb 的结构存储。其中,redisDb.id 存储着 redis 数据库以整数表示的号码。redisDb.dict 存储着该库所有的键值对数据。redisDb.expires 保存着每一个键的过期时间。
2、当redis 服务器初始化时,会预先分配 16 个数据库(该数量可以通过配置文件配置),所有数据库保存到结构 redisServer 的一个成员 redisServer.db 数组中。当我们选择数据库 select number 时,程序直接通过 redisServer.db[number] 来切换数据库。有时候当程序需要知道自己是在哪个数据库时,直接读取 redisDb.id 即可。
3、既然我们知道一个数据库的所有键值都存储在redisDb.dict中,那么我们要知道如果找到key的位置,就有必要了解一下dict 的结构了:
typedef struct dict {
// 特定于类型的处理函数
dictType *type;
// 类型处理函数的私有数据
void *privdata;
// 哈希表(2个)
dictht ht[2];
// 记录 rehash 进度的标志,值为-1 表示 rehash 未进行
int rehashidx;
// 当前正在运作的安全迭代器数量
int iterators;
} dict;
由上述的结构可以看出,redis 的字典使用哈希表作为其底层实现。dict 类型使用的两个指向哈希表的指针,其中 0 号哈希表(ht[0])主要用于存储数据库的所有键值,而1号哈希表主要用于程序对 0 号哈希表进行 rehash 时使用,rehash 一般是在添加新值时会触发,这里不做过多的赘述。所以redis 中查找一个key,其实就是对进行该dict 结构中的 ht[0] 进行查找操作。
4、既然是哈希,那么我们知道就会有哈希碰撞,那么当多个键哈希之后为同一个值怎么办呢?redis采取链表的方式来存储多个哈希碰撞的键。也就是说,当根据key的哈希值找到该列表后,如果列表的长度大于1,那么我们需要遍历该链表来找到我们所查找的key。当然,一般情况下链表长度都为是1,所以时间复杂度可看作o(1)。
二、当redis 拿到一个key 时,如果找到该key的位置。
了解了上述知识之后,我们就可以来分析redis如果在内存找到一个key了。
1、当拿到一个key后, redis 先判断当前库的0号哈希表是否为空,即:if (dict->ht[0].size == 0)。如果为true直接返回NULL。
2、判断该0号哈希表是否需要rehash,因为如果在进行rehash,那么两个表中者有可能存储该key。如果正在进行rehash,将调用一次_dictRehashStep方法,_dictRehashStep 用于对数据库字典、以及哈希键的字典进行被动 rehash,这里不作赘述。
3、计算哈希表,根据当前字典与key进行哈希值的计算。
4、根据哈希值与当前字典计算哈希表的索引值。
5、根据索引值在哈希表中取出链表,遍历该链表找到key的位置。一般情况,该链表长度为1。
6、当 ht[0] 查找完了之后,再进行了次rehash判断,如果未在rehashing,则直接结束,否则对ht[1]重复345步骤。
到此我们就找到了key在内存中的位置了。
❺ php-redis扩展 怎么装安装啊
1、下载PHPredis安装包,可以去去pecl官网下载
2、解压安装并进入Redis目录
[root@Redis ~]# tar xzf redis-2.2.5.tgz
[root@Redis ~]# cd redis-2.2.5
3、在Redis文件夹下,生成configure配置文件
[root@Redis redis-2.2.5]# /usr/local/php/bin/phpize
Configuring for:
PHP Api Version:20090626
Zend Mole Api No:20090626
Zend Extension Api No:220090626
[root@Redis redis-2.2.5]# ./configure --with-php-config=/usr/local/php/bin/php-config
[root@Redis redis-2.2.5]# make
[root@Redis redis-2.2.5]# make install
Installing shared extensions:/usr/local/php/lib/php/extensions/no-debug-non-zts-20090626/
cp: cannot create regularfile`/usr/local/php/lib/php/extensions/no-debug-non-zts-20090626/#INST@6338#': Permission denied
make:***[install-moles]Error1
注意:一定要用root用户。
[root@Redis redis-2.2.5]# su
Password:
[root@web redis-2.2.5]# make install
4、在PHP配置文件php.ini里面加载Redis扩展
extension=redis.so
5、查看phpinfo,Redis扩展是否加载
redis
Redis Support enabled
Redis Version 2.2.5
至此,Redis扩展已经安装成功并加载,可以用PHP操作Redis了。
附:
windows下安装Redis扩展就更加简单了,找到对应的版本,下载dll文件,放到PHP目录下面的ext,修改PHP的配置文件php.ini,加载extension=php_redis.dll,重启Apache,查看phpinfo是否有Redis,如果有就恭喜你,已经安装成功了,就是这么简单。
❻ mac中怎样通过brew 安装php的redis扩展
1、下载php-redis;
2、下载完后进行解压,然后移动到系统自带php的同级目录;①
cp /Users/panxu/Desktop/phpredis /etc
3、进入phpredis;
cd /etc/phpredis
4、动态安装php扩展模块;②
/usr/bin/phpize
5、进行编译;
./configure --with-php-config=/usr/bin/php-config
6、开始安装;
make && make install
安装完成,如果成功,会有如下提示:
Build complete.
Don't forget to run 'make test'.
Installing shared extensions: /usr/lib/php/extensions/no-debug-non-zts-20160303/
7、找到php.ini文件,并进行编辑;③
vi php.ini
在配置文件最后一行加入:
extension=redis.so
8、重启php-fpm,完成安装。④
步骤中的涉及到的资源和详细解释请参考:https://panxu.net/article/8400.html
❼ php 使用redis锁限制并发访问类示例
本文介绍了php
使用redis锁限制并发访问类,并详细的介绍了并发访问限制方法。
1.并发访问限制问题
对于一些需要限制同一个用户并发访问的场景,如果用户并发请求多次,而服务器处理没有加锁限制,用户则可以多次请求成功。
例如换领优惠券,如果用户同一时间并发提交换领码,在没有加锁限制的情况下,用户则可以使用同一个换领码同时兑换到多张优惠券。
伪代码如下:
if
A(可以换领)
B(执行换领)
C(更新为已换领)
D(结束)
如果用户并发提交换领码,都能通过可以换领(A)的判断,因为必须有一个执行换领(B)后,才会更新为已换领(C)。因此如果用户在有一个更新为已换领之前,有多少次请求,这些请求都可以执行成功。
2.并发访问限制方法
使用文件锁可以实现并发访问限制,但对于分布式架构的环境,使用文件锁不能保证多台服务器的并发访问限制。
Redis是一个开源的使用ANSI
C语言编写、支持网络、可基于内存亦可持久化的日志型、Key-Value数据库,并提供多种语言的API。
本文将使用其setnx方法实现分布式锁功能。setnx即Set
it
N**ot
eX**ists。
当键值不存在时,插入成功(获取锁成功),如果键值已经存在,则插入失败(获取锁失败)
RedisLock.class.PHP
<?php
/**
*
Redis锁操作类
*
Date:
2016-06-30
*
Author:
fdipzone
*
Ver:
1.0
*
*
Func:
*
public
lock
获取锁
*
public
unlock
释放锁
*
private
connect
连接
*/
class
RedisLock
{
//
class
start
private
$_config;
private
$_redis;
/**
*
初始化
*
@param
Array
$config
redis连接设定
*/
public
function
__construct($config=array()){
$this->_config
=
$config;
$this->_redis
=
$this->connect();
}
/**
*
获取锁
*
@param
String
$key
锁标识
*
@param
Int
$expire
锁过期时间
*
@return
Boolean
*/
public
function
lock($key,
$expire=5){
$is_lock
=
$this->_redis->setnx($key,
time()+$expire);
//
不能获取锁
if(!$is_lock){
//
判断锁是否过期
$lock_time
=
$this->_redis->get($key);
//
锁已过期,删除锁,重新获取
if(time()>$lock_time){
$this->unlock($key);
$is_lock
=
$this->_redis->setnx($key,
time()+$expire);
}
}
return
$is_lock?
true
:
false;
}
/**
*
释放锁
*
@param
String
$key
锁标识
*
@return
Boolean
*/
public
function
unlock($key){
return
$this->_redis->del($key);
}
/**
*
创建redis连接
*
@return
Link
*/
private
function
connect(){
try{
$redis
=
new
Redis();
$redis->connect($this->_config['host'],$this->_config['port'],$this->_config['timeout'],$this->_config['reserved'],$this->_config['retry_interval']);
if(empty($this->_config['auth'])){
$redis->auth($this->_config['auth']);
}
$redis->select($this->_config['index']);
}catch(RedisException
$e){
throw
new
Exception($e->getMessage());
return
false;
}
return
$redis;
}
}
//
class
end
?>
demo.php
<?php
require
'RedisLock.class.php';
$config
=
array(
'host'
=>
'localhost',
'port'
=>
6379,
'index'
=>
0,
'auth'
=>
'',
'timeout'
=>
1,
'reserved'
=>
NULL,
'retry_interval'
=>
100,
);
//
创建redislock对象
$oRedisLock
=
new
RedisLock($config);
//
定义锁标识
$key
=
'mylock';
//
获取锁
$is_lock
=
$oRedisLock->lock($key,
10);
if($is_lock){
echo
'get
lock
success<br>';
echo
'do
sth..<br>';
sleep(5);
echo
'success<br>';
$oRedisLock->unlock($key);
//
获取锁失败
}else{
echo
'request
too
frequently<br>';
}
?>
测试方法:
打开两个不同的浏览器,同时在A,B中访问demo.php
如果先访问的会获取到锁
输出
get
lock
success
do
sth..
success
另一个获取锁失败则会输出request
too
frequently
保证同一时间只有一个访问有效,有效限制并发访问。
为了避免系统突然出错导致死锁,所以在获取锁的时候增加一个过期时间,如果已超过过期时间,即使是锁定状态都会释放锁,避免死锁导致的问题。
源码下载地址:点击查看
❽ php涓轰粈涔堜娇鐢╮edis
1銆 Redis绠浠
redis鏄疦osql鏁版嵁搴扑腑浣跨敤杈冧负骞挎硾镄勯潪鍏崇郴鍨嫔唴瀛樻暟鎹搴掳纴redis鍐呴儴鏄涓涓猭ey-value瀛桦偍绯荤粺銆傚畠鏀鎸佸瓨鍌ㄧ殑value绫诲瀷鐩稿规洿澶氾纴鍖呮嫭string(瀛楃︿覆)銆乴ist(阈捐〃)銆乻et(闆嗗悎)銆亃set(sorted set _链夊簭闆嗗悎)鍜宧ash锛埚搱甯岀被鍨嬶纴绫讳技浜嶫ava涓镄刴ap锛夈俣edis锘轰簬鍐呭瓨杩愯屽苟鏀鎸佹寔涔呭寲镄凬oSQL鏁版嵁搴掳纴鏄褰揿墠链鐑闂ㄧ殑NoSql鏁版嵁搴扑箣涓锛屼篃琚浜轰滑绉颁负鏁版嵁缁撴瀯链嶅姟鍣ㄣ
2銆 浜掕仈缃戞椂浠h儗鏅涓嫔ぇ链洪亣锛屼粈涔堣佷娇鐢∟osql锛
1锛 褰撴暟鎹閲忕殑镐诲ぇ灏忎竴涓链哄櫒鏀句笉涓嬫椂銆
2锛 鏁版嵁绱㈠紩涓涓链哄櫒镄勫唴瀛樻斁涓崭笅镞躲
3锛 璁块梾閲忥纸璇诲啓娣峰悎锛変竴涓瀹炰緥鏀句笉涓嬫椂銆
鍗曟満镞朵唬妯″瀷
濡傛灉姣忔″瓨鍌ㄦ垚鍗冧笂涓囨浔鏁版嵁锛岃繖镙峰緢浼氩艰嚧MySQL镄勬ц兘寰埚樊锛屽瓨鍌ㄤ互鍙婅诲彇阃熷害寰堟参锛岀劧钖庡氨婕斿彉鎴愮紦瀛+mysql+鍨傜洿𨰾嗗垎镄勬柟寮忋
Cache浣滀负涓闂寸紦瀛
灏嗘墍链夌殑鏁版嵁鍏堜缭瀛桦埌缂揿瓨涓锛岀劧钖庡啀瀛桦叆mysql涓锛屽噺灏忔暟鎹搴揿帇锷涳纴鎻愰珮鏁堢巼銆 浣嗘槸褰撴暟鎹鍐嶆″炲姞鍒板张涓涓閲忕骇锛屼笂闱㈢殑鏂瑰纺涔熶笉鑳芥弧瓒抽渶姹傦纴鐢变簬鏁版嵁搴撶殑鍐椤叆铡嫔姏澧炲姞锛孧emcached鍙鑳界紦瑙f暟鎹搴撶殑璇诲彇铡嫔姏銆
璇诲啓闆嗕腑鍦ㄤ竴涓鏁版嵁搴扑笂璁╂暟鎹搴扑笉鍫閲嶈礋锛屽ぇ閮ㄥ垎缃戠珯寮濮嬩娇鐢ㄤ富浠庡嶅埗鎶链𨱒ヨ揪鍒拌诲啓鍒嗙伙纴浠ユ彁楂樿诲啓镐ц兘鍜岃诲簱镄勫彲镓╁𪾢镐с侻ysql镄刴aster-slave妯″纺鎴愪负杩欎釜镞跺欑殑缃戠珯镙囬厤浜嗐
涓讳粠鍒嗙绘ā寮
鍦╮edis镄勯珮阃熺紦瀛桡纴MySQL镄勪富浠庡嶅埗锛岃诲啓鍒嗙荤殑锘虹涔嬩笂锛岃繖镞祃ySQL涓诲簱镄勫啓铡嫔姏寮濮嫔嚭鐜扮摱棰堬纴钥屾暟鎹閲忕殑鎸佺画鐚涘烇纴鐢变簬MyISAM浣跨敤琛ㄩ挛锛屽湪楂桦苟鍙戜笅浼氩嚭鐜颁弗閲岖殑阌侀梾棰桡纴澶ч噺镄勯珮骞跺彂MySQL搴旂敤寮濮嬩娇鐢↖nnoDB寮曟搸浠f浛MyISAM銆
鍒呜〃鍒嗗簱妯″纺
灏嗗彉鍖栧皬镄勚佷笟锷$浉鍏崇殑鏀惧湪涓涓鏁版嵁搴掳纴鍙桦寲澶氱殑锛屼笉鐩稿叧镄勬暟鎹鏀惧湪涓涓鏁版嵁搴撱
3銆 nosql鏁版嵁搴撶殑浼桦娍
1锛夋槗镓╁𪾢
杩欎簺绫诲瀷镄勬暟鎹瀛桦偍涓嶉渶瑕佸浐瀹氱殑妯″纺锛屾棤闇澶氢綑镄勬搷浣滃氨鍙浠ヨ繘琛屾í钖戠殑镓╁𪾢銆傜浉瀵逛簬鍏崇郴鍨嬫暟鎹搴揿彲浠ュ噺灏戣〃鍜屽瓧娈电壒鍒澶氱殑𨱍呭喌銆备篃镞犲瀷涔嬮棿鍦ㄦ灦鏋勭殑灞傞溃涓婂甫𨱒ヤ简鍙镓╁𪾢镄勮兘锷
2锛夊ぇ鏁版嵁閲忔彁楂樻ц兘
3锛夊氭牱𨱔垫椿镄勬暟鎹妯″瀷
鍦╪osql涓涓崭粎鍙浠ュ瓨鍌⊿tring锛宧ash锛宻et銆乑set绛夋暟鎹绫诲瀷锛岃缮鍙浠ヤ缭瀛榡avaBean浠ュ强澶氱嶅嶆潅镄勬暟鎹绫诲瀷銆
4銆 NoSql镄勫簲鐢
1锛 澶ф暟鎹镞朵唬娣桦疂銆佸井淇°佷互鍙婂井鍗氱瓑閮藉箍娉涚殑浣跨敤浜唕edis鏁版嵁搴掳纴灏嗕竴浜涘浐瀹氢笉鍙樼殑鏁版嵁渚嫔傚︽牎锛屽尯锘熺瓑锲哄畾镄勪俊鎭淇濆瓨鍦ㄥ叧绯诲瀷鏁版嵁搴扑腑銆傜劧钖庡逛簬缁忓父鍙桦寲镄勬暟鎹渚嫔傛窐瀹濇疮涓鑺傛棩閮戒细链夋瘆杈幂儹闂ㄧ殑鎼灭储鏄剧ず鍦ㄦ悳绱㈡嗭纴褰撹妭镞ヨ繃铡诲叧阌瀛楄嚜锷ㄥ垹闄わ纴涓轰简渚夸簬绠$悊锛屽彲浠ュ皢杩欎簺鏁版嵁淇濆瓨鍦╮edis鏁版嵁搴扑腑锛屽苟璁剧疆杩囨湡镞堕棿锛屽埌杈炬椂闂村氨镊锷ㄥ垹闄ゃ
2锛変负浜嗙紦瑙f暟鎹搴揿帇锷涳纴寰鍗氶栧厛灏嗗彂阃佺殑寰鍗氢缭瀛桦埌redis鏁版嵁搴掳纴镊宸卞彲浠ョ珛鍗虫煡鐪嫔埌锛岀劧钖庡皢鍐呭瓨涓镄勬暟鎹钖屾ュ埌鍏崇郴鍨嬫暟鎹搴撱
浠ヤ笂鍐呭逛粎渚涘弬钥冿紒
鎺ㄨ崘瑙嗛戞暀绋嬶细redis鏁欑▼