怎么新建MySQL数据库

发布时间:2022-09-22 作者:admin
阅读:315
这篇文章给大家分享的是“PHP中怎样通过Red实现执行订单支付的定时任务”,对大家学习和理解有一定的参考价值和帮助,有这方面学习需要的朋友,接下来就跟随小编一起学习一下吧。


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;

    }


  };

定时任务:

  /**
   * 订单任务
   */
  public function orderAction()
  {
    error_reporting(E_ALL & ~E_NOTICE);
    $redis = Redis::getObj();
    //获取数据库连接实例
    $db = $this->getDI()->getShared('db');
    while (true) {
      print_r(' -start- ');
      $order_status = 1;
      file_put_contents(APP_PATH . "/../domain_order.log", time());
      try {
      	//防止长时间无任务导致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;
        }
        //事务开始
        $db->begin();
        ##
        这里执行订单流程操作
        ##

        $order_status = 3;//操作成功

        //修改订单状态
        $order_domain_info_save->order_status = $order_status;
        $order_domain_info_save->operation_time = time();
        $order_domain_info_save->update();
        }

        //提交事务
        $db->commit();
        printf('### succ order_id' . $order_info['id'] . ' ###');
      } catch (\Exception $e) {
        //回滚事务
        $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() . ' ');
        //异常,发送通知
        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);


感谢各位的阅读,以上就是“PHP中怎样通过Red实现执行订单支付的定时任务”的内容了,经过本文的学习后,相信大家对PHP中怎样通过Red实现执行订单支付的定时任务都有更深刻的体会了吧。这里是群英网络,小编将为大家推送更多相关知识点的文章,欢迎关注!

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:mmqy2019@163.com进行举报,并提供相关证据,查实之后,将立刻删除涉嫌侵权内容。

二维码-群英

长按识别二维码并关注微信

更方便到期提醒、手机管理

7*24 全天候服务

售前 400-678-4567

售后 0668-2555666

售后 400 678 4567

信息安全 0668-2555 118

域名空间 3004329145