addArgument('name', InputArgument::OPTIONAL, 'Name description'); } /** * @param InputInterface $input * @param OutputInterface $output * @return int */ protected function execute(InputInterface $input, OutputInterface $output): int { $host = RabbitMqConfig::$host; $port = RabbitMqConfig::$port; $user = RabbitMqConfig::$user; $password = RabbitMqConfig::$password; $queue = RabbitMqConfig::$queue_t . '-send.mark.sms'; // 防止空闲时间断线必须设置心跳 $connection = new AMQPStreamConnection($host, $port, $user, $password, '/', false, 'AMQPLAIN', null, 'en_US', 60, 60, null, false, 30 ); $rabbit_channel = $connection->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"); // 发给队列 Redis::send('send.mark.sms', $data); $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()) { $rabbit_channel->wait(); } $rabbit_channel->close(); $connection->close(); return self::SUCCESS; } }