Redis類:
?php
namespace Utils;
use Phalcon\Config\Adapter\Ini as ConfigIni;
class Redis{
private static $redis1;
private static $session;
/**
* 獲取一個單例的redis對象
* @param string $name
* @return \Redis
*/
public static function getObj($name='redis1')
{
try{
if(!empty(self::$$name)){
return self::$$name;
}
$config = new ConfigIni(APP_PATH."/config".ENV."/redis.ini");
self::$$name = new \Redis();
self::$$name->connect($config[$name]['host'], $config[$name]['port'],2);
if(isset($config[$name]['password']) !empty($config[$name]['password'])){
self::$$name->auth($config[$name]['password']);
}
self::$$name->select($config[$name]['database']);
}catch (\Exception $exception){
self::$$name = false;
}
return self::$$name;
}
};
定時任務(wù):
/**
* 訂單任務(wù)
*/
public function orderAction()
{
error_reporting(E_ALL ~E_NOTICE);
$redis = Redis::getObj();
//獲取數(shù)據(jù)庫連接實例
$db = $this->getDI()->getShared('db');
while (true) {
print_r(' -start- ');
$order_status = 1;
file_put_contents(APP_PATH . "/../domain_order.log", time());
try {
//防止長時間無任務(wù)導(dǎo)致MySQL超時
$db->query("select 1");
//出列
$order_info = $redis->lPop('order');
if (!$order_info) {//隊列為空時暫停
echo ' -empty- ';
sleep(1);
continue;
}
$order_info = json_decode($order_info, true);
$model_order_info = NetUserOrder::findFirst(['order_sn = :order_sn:','bind'=>['order_sn'=>$order_domain_info_save->order_sn]]);
//未支付
if($model_order_info->pay_status != 200){
echo 'no pay';
continue;
}
//已操作
if ($order_domain_info_save->order_status == 3) {
echo ' -Operated- ';
continue;
}
//事務(wù)開始
$db->begin();
##
這里執(zhí)行訂單流程操作
##
$order_status = 3;//操作成功
//修改訂單狀態(tài)
$order_domain_info_save->order_status = $order_status;
$order_domain_info_save->operation_time = time();
$order_domain_info_save->update();
}
//提交事務(wù)
$db->commit();
printf('### succ order_id' . $order_info['id'] . ' ###');
} catch (\Exception $e) {
//回滾事務(wù)
$db->rollback();
$order_status = 2;//操作失敗
$order_domain_info_save->order_status = $order_status;
$order_domain_info_save->operation_time = time();
$order_domain_info_save->update();
printf(' error ' . $e->getMessage() . ' ');
//異常,發(fā)送通知
Log::error($e->getMessage());
$redis->hSet('order_domain_retry', 'domain_retry_' . $order_info['id'], json_encode($order_info));
}
Redis常用隊列方法:
//隊列第一個 =>出列
$Redis->lPop($key);
//入到 =>隊列最后
$Redis->rPush($key);
//隊列最后一個 =>出列
$Redis->rPop($key);
//入到 =>隊列第一個
$Redis->rPop($key);
//返回整個列表的值,不出列
$redis->lRange($key,0,-1);
到此這篇關(guān)于PHP使用Redis隊列執(zhí)行定時任務(wù)實例講解的文章就介紹到這了,更多相關(guān)PHP使用Redis隊列執(zhí)行定時任務(wù)內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
您可能感興趣的文章:- 詳解PHP解決守護(hù)進(jìn)程Redis假死
- thinkphp5redis緩存新增方法實例講解
- php基于redis的分布式鎖實例詳解
- Thinkphp5+Redis實現(xiàn)商品秒殺代碼實例講解
- PHP操作Redis常用命令的實例詳解
- php在linux環(huán)境中如何使用redis詳解
- php操作redis命令及代碼實例大全
- php之redis短線重連案例講解