channel(); $rabbit_channel->queue_declare($queue, false, true, false, false, false, [ 'x-message-ttl' => ['I', 180000] ]); $callback = function ($msg) use ($queue){ $date_time = date('Y-m-d H:i:s'); $data = $msg->body; Log::info('MQ收到消息[订单打印]--->' . $data . '--->' . $date_time . "\n"); // 如果是数字。则打印订单 $is_log = false; $curl_error = ''; print_r($data . "\r\n"); $order_id_t = strpos($data, '_'); print_r($order_id_t . "嘿嘿\r\n"); if($order_id_t !== false) { print_r($order_id_t . "\r\n"); $order_id = substr($data, 0, $order_id_t); }else { print_r( "无下划线\r\n"); $order_id = $data; } print_r($order_id . "\r\n"); $order = Db::table('tb_order_info')->where(['id' => $order_id])->find(); if($order) { $rand = 'cashier_order' . Random::build(); $send_id = 'cashier_'. $order['shop_id']; // 收银机打印订单 $snd_data = [ 'msg' => '收银机订单打印', 'type' => 'cashier', 'operate_type' => 'order_print', 'data_type' => 'order', 'status' => 1, 'method' => 'sendToUid', 'send_num' => 0, 'send_id' => $send_id, 'msg_id' => $rand, 'data' => $data ]; $snd_data_json = json_encode($snd_data); Gateway::$registerAddress = '127.0.0.1:1238'; $res = Gateway::sendToUid($send_id, $snd_data_json); Log::info('订单打印推送结果-->' . $res); $result = Redis::get($snd_data['send_id']); if($result) { $msg_id_arr = json_decode($result, true); $msg_id_arr_c = count($msg_id_arr); $msg_id_arr[$msg_id_arr_c] = $snd_data; $result_n = json_encode($msg_id_arr); Base::setredis_new($result_n, $snd_data['send_id']); }else { $params_arr_n[] = $snd_data; print_r('数组-------->' . json_encode($params_arr_n)) . "\r\n"; Base::setredis_new(json_encode($params_arr_n), $snd_data['send_id']); } // // 内部给收银机推送打订单 // $url = 'http://127.0.0.1:8686/?method=sendToUid&account='. $send_id .'¶ms=' . $snd_data_json; // 替换为你的服务地址和端口 // $ch = curl_init(); // curl_setopt($ch, CURLOPT_URL, $url); // curl_setopt($ch, CURLOPT_RETURNTRANSFER, 1); // $output = curl_exec($ch); // if (curl_errno($ch)) { // $is_log = true; // $curl_error = 'Curl error: ' . curl_error($ch); // } // curl_close($ch); // Log::info('内部通讯结果(订单打印)--->' . $output . '通讯ID--->cashier_' .$order['shop_id']. '---' . date('Y-m-d H:i:s') . "\n"); }else { $curl_error = 'order Data is empty'; $is_log = true; } if($is_log) { Db::table('tb_mq_log')->insert([ 'queue' => $queue, 'msg' => $data, 'type' => 'orderPrint', 'plat' => 'Cashier', 'create_time' => date('Y-m-d H:i:s'), 'fail_time' => date('Y-m-d H:i:s'), 'err_info' => $curl_error, ]); } $msg->delivery_info['channel']->basic_ack($msg->delivery_info['delivery_tag']); }; $rabbit_channel->basic_consume($queue, '', false, false, false, false, $callback); while ($rabbit_channel->is_consuming()) { Log::info('order.print.queue-MQ准备调用wait'); $rabbit_channel->wait(); } $rabbit_channel->close(); $connection->close(); }catch (Exception $exception) { Log::info('order.print.queue-MQ错误' . $exception->getMessage()); }