PHP 数据结构队列(SplQueue)和优先队列(SplPriorityQueue)简单使用实例队列这种数据结构更简单,就像我们生活中排队一样,它的特性是先进先出(FIFO) 。
PHP
SPL中SplQueue类就是实现队列操作 , 和栈一样,它也可以继承双链表(SplDoublyLinkedList)轻松实现 。
SplQueue类摘要如下:
SplQueue简单使用如下:
复制代码
代码如下:
$queue
=
new
SplQueue();
/**
*
可见队列和双链表的区别就是IteratorMode改变了而已,栈的IteratorMode只能为:
*
(1)SplDoublyLinkedList::IT_MODE_FIFO
|
SplDoublyLinkedList::IT_MODE_KEEP
(默认值,迭代后数据保存)
*
(2)SplDoublyLinkedList::IT_MODE_FIFO
|
SplDoublyLinkedList::IT_MODE_DELETE
(迭代后数据删除)
*/
$queue-setIteratorMode(SplDoublyLinkedList::IT_MODE_FIFO
|
SplDoublyLinkedList::IT_MODE_DELETE);
//SplQueue::enqueue()其实就是
SplDoublyLinkedList::push()
$queue-enqueue('a');
$queue-enqueue('b');
$queue-enqueue('c');
//SplQueue::dequeue()其实就是
SplDoublyLinkedList::shift()
print_r($queue-dequeue());
foreach($queue
as
$item)
{
echo
$item
.
PHP_EOL;
}
print_r($queue);
而优先队列SplPriorityQueue是基于堆(后文介绍)实现的 。
SplPriorityQueue的类摘要如下:
SplPriorityQueue简单使用:
$pq
=
new
SplPriorityQueue();
$pq-insert('a',
10);
$pq-insert('b',
1);
$pq-insert('c',
8);
echo
$pq-count()
.PHP_EOL;
//3
echo
$pq-current()
.
PHP_EOL;
//a
/**
*
设置元素出队模式
*
SplPriorityQueue::EXTR_DATA
仅提取值
*
SplPriorityQueue::EXTR_PRIORITY
仅提取优先级
*
SplPriorityQueue::EXTR_BOTH
提取数组包含值和优先级
*/
$pq-setExtractFlags(SplPriorityQueue::EXTR_DATA);
while($pq-valid())
{
print_r($pq-current());
//a
c
b
$pq-next();
}
PHP用什么来快速消费队列php变量的生命周期属于页面级,页面访问完变量就自动销毁了 。所以要实现多个php进程都可以使用的队列,需要借助第三方存储系统 。比如mysql、redis等,个人推荐redis,它本身里面的链表类型数据库就支持队列,非常好用
请教PHP Redis实现任务队列的思路// 创建请求ID标志, uniqid 无法保证唯一, 自己去搜索生成唯一的方法
$uuid = uniqid();
$tsk_name = "mytask";
$time_out = 30000; // 超时策略: 30秒
$time_start = time();
$redis-rPush($tsk_name, $uuid); // 右(后)插入队列
// 堵塞等待队列中第一个和$uuid匹配的(到我了)
while($uuid != $redis-lGet($tsk_name, 0)){
if((time()-$time_start) $time_out) {
break; // 超时跳出(某些原因队列异常了, 可能永远取不到)
}
usleep(10); // sleep 10ms, 再次尝试
}
// 这里执行任务的处理代码....
// $response 已拼装好要返回的内容
// 处理完成后(数据库等已入库更新), 需要:
if($redis-lGet($tsk_name, 0) == $uuid){ // 再次确认第一个是本请求
$redis-lPop($tsk_name); // 完成任务了, 从队列中移除
}else{
// 出现这种情况, 是因为超时了, 或前面的$uuid没有被消费
// 若不清除, 后续的请求, 都将无法正常进入队列执行
// 取队列中的所有$uuid
$queues = $redis-lRange($tsk_name, 0, -1);
foreach($queues as $i=$uid){
if($uid==$uuid){
php 用 redis做队列 运行过程是什么样的Reids是一个比较高级的开源key-value存储系统,采用ANSI C实现 。其与memcached类似,但是支持持久化数据存储入队操作
复制代码 代码如下:
?php
$redis = new Redis();
$redis-connect('127.0.0.1',6379);
while(True){
try{
$value = 'https://www.04ip.com/post/value_'.date('Y-m-d H:i:s');
$redis-LPUSH('key1',$value);
sleep(rand()%3);
echo $value."\n";
}catch(Exception $e){
echo $e-getMessage()."\n";
}
}
?
出队操作
复制代码 代码如下:
?php
$redis = new Redis();
$redis-pconnect('127.0.0.1',6379);
while(True){
try{
echo $redis-LPOP('key1')."\n";
【php数据库队列 php对接数据库的表】}catch(Exception $e){
echo $e-getMessage()."\n";
}
sleep(rand()%3);
}?
如何使用Redis 做队列操作
Reids是一个比较高级的开源key-value存储系统,采用ANSI C实现 。其与memcached类似,但是支持持久化数据存储,同时value支持多种类型:字符串 (同memcached中的value) , 列表 ,集合 (Set),有序集合 (OrderSet)和Hash。所有的值类型均支持原子操作,如列表中追加弹出元素 , 集合中插入移除元素等 。Rdids的数据大部分位于内存中,其读写效率非常高,其提供AOF(追加 式操作记录文件)和DUMP(定期数据备份)两种持久化方式 。Redis支持自定义的VM(虚拟内存)机制,当数据容量超过内存时,可以将部分Value 存储到文件中 。同时Redis支持Master-Slave机制,可以进行数据复制 。
可以把Redis的list结构当队列来用.
从上面Redis的场景和作用来说,对于我们现在的开发活动,究竟能把Redis引入在那些场景,而不是把这么好的东东演变成“为了使用Redis,而Redis”的惨烈局面呢?当然 , 具体问题具体分析,这个真的很重要哈 。
缓存?分布式缓存?
队列?分布式队列?
某些系统应用(例如,电信、银行和大型互联网应用等)都会使用到,当然 , 现在大行其道的memcache就是很好的证明;但从某一方面来说,memcache是否能把两张囊括其中,而且能做到更好(没有实际的应用过 , 所以只是抛出) 。但从Redis身上,我就能感觉到,Redis , 就能把队列和缓存两张都囊括其中,而且都不会产生并发环境下的困扰 , 因为Redis中的操作都是原子操作来着 。
至于评论两者的孰好孰坏就免了,存在就是理由,选择适合的就是最好的 。
下面开始玩玩Redis中的队列(分布式)设计YY吧,请大虾们多多指点 。
状况场景:
现在的项目,都是部署在多个服务器,或者多个IP上,而且前台经由F5分发,所以用户的请求究竟落在那一台的服务器上,是无法确定的 。对于项目中 , 有一秒杀设计,刚开始没有考虑到这种部署 , 同时也是使用最容易处理的方式,直接给数据库表锁行记录(Oracle上的) 。可以说,对于不同的应用部署,而只有一台数据库服务器来说 , 很“轻松”的就解决了这个并发的问题 。所以现在考虑一下,是不是挪到应用上,避免数据库服务器也掺杂到业务上 。
比如,现在有2台应用服务器,1台数据库服务器 。想法是,把Redis部署在数据库服务器上,两台服务器在操作并发缓存或者队列时,先从Redis服务器上,取得在两台应用服务器的代理对象,再做入列出列的操作 。
看代码实现(PHP)
入队列操作文件 list_push.php
复制代码 代码如下:
?php
$redis = getRedisInstance();//从Redis服务器拿到redis实例$redis-connect('Redis服务器IP', 6379);
while (true) {
$redis-lPush('list1', 'A_'.date('Y-m-d H:i:s'));sleep(rand()%3);
}
?
执行# php list_push.php
出队列操作 list_pop.php文件
复制代码 代码如下:
?php
$redis = getRedisInstance();//从Redis服务器拿到redis实例$redis-pconnect('Redis服务器IP', 6379);
while(true) {
try {
var_export( $redis-blPop('list1', 10) );} catch(Exception $e) {
//echo $e;
}
}
实现方法(Python)
1.入队列(write.py)
复制代码 代码如下:
#!/usr/bin/env python
import time
from redis import Redis
redis = Redis(host='127.0.0.1', port=6379)while True:
now = time.strftime("%Y/%m/%d %H:%M:%S")
redis.lpush('test_queue', now)
time.sleep(1)
2.出队列(read.py)
复制代码 代码如下:
#!/usr/bin/env python
import sys
from redis import Redis
redis = Redis(host='127.0.0.1', port=6379)while True:
res = redis.rpop('test_queue')
if res == None:
pass
else:
print str(res)
请教php事务里可以用队列么事务处理是数据库的能力、队列可以使用nosql实现、比如redis、mongodb、或者用数据库也可以模拟实现 。两个人做同一件事可以使用队列,先依照两个人做事的先后顺序放到队列,在通过后台程序顺序读取队列操作逻辑
php数据库队列的介绍就聊到这里吧 , 感谢你花时间阅读本站内容,更多关于php对接数据库的表、php数据库队列的信息别忘了在本站进行查找喔 。
推荐阅读
- 图片幻灯片+js实现,js怎么实现图片滚动
- pg库数据导入到oracle,oracle数据库迁移到pg数据库
- 驾照考试下载,驾照考试下载什么软件刷题
- 包含windows系统好用的记事本的词条
- 火锅店如何推广和营销策略,火锅店如何推广和营销策略分析
- 一岁宝宝益智早教游戏大全,一岁宝宝的早教游戏
- 怎样关闭安卓手机后台应用的简单介绍
- 如何查询oracle表名 查看oracle所有表名
- ios10.2系统有没有关闭,iphone10关闭系统更新