最近有个项目,因为服务器权限问题,没办法安装安装队列程序,而且并发300+,服务商的数据库最大连接数是300,为了解决这个问题所以编写了一个简单的队列程序,代码如下
读队列代码:
<?php
set_time_limit(0);
$file_name3 = '3.txt';//这个地方是讲队列文件读出的内容写入文件,test中代替的是mysql数据库操作
$file3 = fopen($file_name3,'a');
while(true)
{
$c = FALSE;
$file_name = '1.txt';//队列文件
$file = fopen($file_name,'r');
if(!feof($f))
{
//获得第一条数据
$a = fgets($file);
if(!empty($a))
{
$c = TRUE;
fwrite($file3,$a);//这里可以改为数据库操作
}
}
fclose($file);
if($c)
{
//将文件的第一条数据删除
exec('sed -i \'1d\' /var/www/csv_sql/1.txt');
}
sleep(1);
if(time()>=strtotime('20160416150000'))
{
exit;
}
}
fclose($file3);
读队列程序其实就是一个死循环程序,如不设置关闭点,则一直循环读取文件
写入队列程序比较简单,就是写文件
<?php
set_time_limit(0);
$file_name2 = '2.txt';//test中用来比对队列程序是否正常的
$file2 = fopen($file_name2,'a');
for($i=1;$i<11;$i++)
{
$file_name = '1.txt';//队列文件
$file = fopen($file_name,'a');//fopen的mode属性必须是a或a+
$str = $i.'--'.rand(100001,999999);
fwrite($file,$str."\n");
fwrite($file2,$str."\n");
sleep(1);
fclose($file);
}
fclose($file2);