详解thinkphp+redis+队列的实现代码(逻辑理解)
https://www.jb51.net/article/121729.html 核心在于 队列只有一条 不会因查询 并发。
1,安装Redis,根据自己的PHP版本安装对应的redis扩展(此步骤简单的描述一下)
1.1,安装 php_igbinary.dll,php_redis.dll扩展此处需要注意你的php版本如图:
1.2,php.ini文件新增 extension=php_igbinary.dll;extension=php_redis.dll两处扩展
ok此处已经完成第一步redis环境搭建完成看看phpinfo
项目中实际使用redis
2.1,第一步配置redis参数如下,redis安装的默认端口为6379:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
|
return
array
(
'DATA_CACHE_PREFIX'
=>
'Redis_'
,
//缓存前缀
'DATA_CACHE_TYPE'
=>
'Redis'
,
//默认动态缓存为Redis
'DATA_CACHE_TIMEOUT'
=> false,
'REDIS_RW_SEPARATE'
=> true,
//Redis读写分离 true 开启
'REDIS_HOST'
=>
'127.0.0.1'
,
//redis服务器ip,多台用逗号隔开;读写分离开启时,第一台负责写,其它[随机]负责读;
'REDIS_PORT'
=>
'6379'
,
//端口号
'REDIS_TIMEOUT'
=>
'300'
,
//超时时间
'REDIS_PERSISTENT'
=>false,
//是否长连接 false=短连接
'REDIS_AUTH'
=>
''
,
//AUTH认证密码
);
|
2.2,实际函数中使用redis:
1
2
3
4
5
6
7
8
9
10
11
|
private
function
connectRedis(){
$redis
=
new
\Redis();
$redis
->connect(C(
"REDIS_HOST"
),C(
"REDIS_PORT"
));
return
$redis
;
}
|
2.3,秒杀的核心问题是在大并发的情况下不会超出库存的购买,这个就是处理的关键所以思路是第一步在秒杀类的先做一些基础的数据生成: