PHP에서 간단하고 안정적인 Rabbitmq 구성 요소 패키지를 사용하는 방법
rabbitmq가 프로젝트에서 널리 사용될 때, Rabbitmq의 일반적인 기능에 대한 간단한 요약이 있으며, 작곡가 패키지 주소, github 주소로 캡슐화되어 있습니다. 제한된 수준이므로 버그는 불가피합니다. . 환영합니다. 귀중한 조언을 해주세요.
easy-rabbitmq 패키지 소개
php-amqplib/php-amqplib 패키지의 보조 캡슐화로, 공통 기능을 위한 즉시 사용 가능한 제작 솔루션 세트를 제공합니다. 현재 지원되는 기능 목록은 다음과 같습니다.
직접 스위치에 메시지 푸시(지연된 메시지 포함)
섹터 스위치에 메시지 푸시(지연된 메시지 포함)
주제 스위치에 메시지 푸시(지연된 메시지 포함) 메시지)
구독 모델 하에서 안정적인 소비가 가능하며 소비자는 실패 후에도 최대 5번까지 소비를 계속 시도합니다.
풀 모드에서 안정적인 소비가 가능하며, 소비자는 실패 후에도 최대 5번까지 소비를 계속하려고 시도합니다.
다른 장면이 있다면 계속해서 추가하고 나중에 반복해주세요! !
Requirements
설치 패키지의 PHP 버전 요구 사항은 주로 php-amqplib/php-amqplib 패키지 자체의 요구 사항에 따라 달라집니다. php5.0 사용자를 고려하기 위해 php-amqplib/를 사용합니다. php-amqplib 패키지 V2.
구체적인 요구 사항은 여기를 참조하세요.
하지만 저자는 php7.0 이상 사용을 권장합니다. 이 개발 패키지도 버전 7.0에서 개발되었습니다!
Installation
composer require maweibinguo/easyrabbitmq
Use
여기서는 소비 프로세스의 신뢰성을 보장하고 작업자의 소비 능력을 향상시키기 위해 PHP 스크립트 + 감독자의 조합을 권장합니다! 감독자에 대해 들어본 적이 없다면 여기를 클릭하여 자세히 알아보세요.
1-1. 직접 연결된 스위치에 메시지 푸시
$config = [ "host" => "127.0.0.1", "port" => "5672", "user" => "guest", "password" => "guest", "vhost" => "/", "channel_max_num" => 10, ]; $instance = RabbitMq::getInstance($config); //延迟消息,30 秒中后才会到达指定的交换机 $instance->pushToDirect( $msg = time(), //消息体内容 $exchange = "easy_direct_exchange", //交换机名称 $routingKey = "direct_test_queue", //消息的routingKey,consume(get) 方法到bingdingKey 要和routingKey保持一致 $delaySec = 30 //延迟秒数 ); //无延迟,推入到指定到直链交换机 $instance->pushToDirect( $msg = time(), //消息体内容 $exchange = "easy_direct_exchange", //交换机名称 $routingKey = "direct_test_queue", //消息的routingKey,consume(get) 方法到bingdingKey 要和routingKey保持一致 );
1-2.
1-3, 주제 교환에 메시지 푸시 $config = [
"host" => "127.0.0.1",
"port" => "5672",
"user" => "guest",
"password" => "guest",
"vhost" => "/",
"channel_max_num" => 10,
];
$instance = RabbitMq::getInstance($config);
//延迟消息,30 秒中后才会到达指定的交换机
$instance->pushToFanout(
$msg = time(), //消息体内容
$exchange = "easy_fanout_exchange", //交换机名称
$delaySec = 30 //延迟秒数
);
//无延迟,推入到指定到直链交换机
$instance->pushToFanout(
$msg = time(), //消息体内容
$exchange = "easy_fanout_exchange" //交换机名称
);
로그인 후 복사
2. 메시지 소비 소비는 자동 재시도를 지원하며, 각 소비 실패 후 메시지는 다시 소비 대기열에 들어갑니다. 이 클라이언트에서 지원하는 지연 전략은 다음과 같습니다. 1회 실패(1초 후에 다시 전달됨), 2번 실패(2초 후에 다시 전달됨) 전달), 3번 실패(4초 후 다시 전달), 4번 실패(8초 후 다시 전달), 5번 실패(16초 후 다시 전달) 2-1, 구독 모드$config = [ "host" => "127.0.0.1", "port" => "5672", "user" => "guest", "password" => "guest", "vhost" => "/", "channel_max_num" => 10, ]; $instance = RabbitMq::getInstance($config); //延迟消息,30 秒中后才会到达指定的交换机 $instance->pushToFanout( $msg = time(), //消息体内容 $exchange = "easy_fanout_exchange", //交换机名称 $delaySec = 30 //延迟秒数 ); //无延迟,推入到指定到直链交换机 $instance->pushToFanout( $msg = time(), //消息体内容 $exchange = "easy_fanout_exchange" //交换机名称 );
구독 모드에서 안정적인 소비
$config = [
"host" => "127.0.0.1",
"port" => "5672",
"user" => "guest",
"password" => "guest",
"vhost" => "/",
"channel_max_num" => 10,
];
$instance = RabbitMq::getInstance($config);
//延迟消息,30 秒中后才会到达指定的交换机
$instance->pushToTopic(
$msg = time(), //消息体内容
$exchange = "easy_topic_exchange", //交换机名称
/**
* routingKey 要同consum(get)方法的bindingKey相匹配
* bindingKey支持两种特殊的字符"*"、“#”,用作模糊匹配, 其中"*"用于匹配一个单词、“#”用于匹配多个单词(也可以是0个)
* 无论是bindingKey还是routingKey, 被"."分隔开的每一段独立的字符串就是一个单词, easy.topic.queue, 包含三个单词easy、topic、queue
*/
$routingKey = "easy.topic.queue",
$delaySec = 30 //延迟秒数
);
//无延迟,推入到指定到直链交换机
$instance->pushToTopic(
$msg = time(), //消息体内容
$exchange = "easy_topic_exchange", //交换机名称
$routingKey = "easy.topic.queue"
);
로그인 후 복사
2-2, 풀 모드풀 모드에서 안정적인 소비$config = [ "host" => "127.0.0.1", "port" => "5672", "user" => "guest", "password" => "guest", "vhost" => "/", "channel_max_num" => 10, ]; $instance = RabbitMq::getInstance($config); //延迟消息,30 秒中后才会到达指定的交换机 $instance->pushToTopic( $msg = time(), //消息体内容 $exchange = "easy_topic_exchange", //交换机名称 /** * routingKey 要同consum(get)方法的bindingKey相匹配 * bindingKey支持两种特殊的字符"*"、“#”,用作模糊匹配, 其中"*"用于匹配一个单词、“#”用于匹配多个单词(也可以是0个) * 无论是bindingKey还是routingKey, 被"."分隔开的每一段独立的字符串就是一个单词, easy.topic.queue, 包含三个单词easy、topic、queue */ $routingKey = "easy.topic.queue", $delaySec = 30 //延迟秒数 ); //无延迟,推入到指定到直链交换机 $instance->pushToTopic( $msg = time(), //消息体内容 $exchange = "easy_topic_exchange", //交换机名称 $routingKey = "easy.topic.queue" );
$config = [
"host" => "127.0.0.1",
"port" => "5672",
"user" => "guest",
"password" => "guest",
"vhost" => "/",
"channel_max_num" => 10,
];
$instance = RabbitMq::getInstance($config);
$instance->consume(
$queueName = "direct_test_queue",//订阅的队列名称
$consumerTag = "c1",//消费标记
$exchange = "easy_direct_exchange",//交换机名称
$bindingKey = "direct_test_queue",//bindingkey,如果是直链交换机需要同routingKey保持一致
$callback = function($msg){
$body = $msg->body;
file_put_contents("./test.log", "time => " . time() . "\t" . " body => " . $body . PHP_EOL , FILE_APPEND);
//如果返回结果不绝对等于(===)true,那么将触发消息重试机制
return false;
},
//5次消费消费失败后,失败消息将会投递到的队列名称
$failedQueue = "easymq@failed"
);
로그인 후 복사추천 학습: php 비디오 튜토리얼
$config = [ "host" => "127.0.0.1", "port" => "5672", "user" => "guest", "password" => "guest", "vhost" => "/", "channel_max_num" => 10, ]; $instance = RabbitMq::getInstance($config); $instance->consume( $queueName = "direct_test_queue",//订阅的队列名称 $consumerTag = "c1",//消费标记 $exchange = "easy_direct_exchange",//交换机名称 $bindingKey = "direct_test_queue",//bindingkey,如果是直链交换机需要同routingKey保持一致 $callback = function($msg){ $body = $msg->body; file_put_contents("./test.log", "time => " . time() . "\t" . " body => " . $body . PHP_EOL , FILE_APPEND); //如果返回结果不绝对等于(===)true,那么将触发消息重试机制 return false; }, //5次消费消费失败后,失败消息将会投递到的队列名称 $failedQueue = "easymq@failed" );
위 내용은 PHP에서 간단하고 안정적인 Rabbitmq 구성 요소 패키지를 사용하는 방법의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

핫 AI 도구

Undresser.AI Undress
사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover
사진에서 옷을 제거하는 온라인 AI 도구입니다.

Undress AI Tool
무료로 이미지를 벗다

Clothoff.io
AI 옷 제거제

AI Hentai Generator
AI Hentai를 무료로 생성하십시오.

인기 기사

뜨거운 도구

메모장++7.3.1
사용하기 쉬운 무료 코드 편집기

SublimeText3 중국어 버전
중국어 버전, 사용하기 매우 쉽습니다.

스튜디오 13.0.1 보내기
강력한 PHP 통합 개발 환경

드림위버 CS6
시각적 웹 개발 도구

SublimeText3 Mac 버전
신 수준의 코드 편집 소프트웨어(SublimeText3)

뜨거운 주제











PHP 8.4는 상당한 양의 기능 중단 및 제거를 통해 몇 가지 새로운 기능, 보안 개선 및 성능 개선을 제공합니다. 이 가이드에서는 Ubuntu, Debian 또는 해당 파생 제품에서 PHP 8.4를 설치하거나 PHP 8.4로 업그레이드하는 방법을 설명합니다.

CakePHP는 PHP용 오픈 소스 프레임워크입니다. 이는 애플리케이션을 훨씬 쉽게 개발, 배포 및 유지 관리할 수 있도록 하기 위한 것입니다. CakePHP는 강력하고 이해하기 쉬운 MVC와 유사한 아키텍처를 기반으로 합니다. 모델, 뷰 및 컨트롤러 gu

CakePHP에 로그인하는 것은 매우 쉬운 작업입니다. 한 가지 기능만 사용하면 됩니다. cronjob과 같은 백그라운드 프로세스에 대해 오류, 예외, 사용자 활동, 사용자가 취한 조치를 기록할 수 있습니다. CakePHP에 데이터를 기록하는 것은 쉽습니다. log() 함수는 다음과 같습니다.

VS Code라고도 알려진 Visual Studio Code는 모든 주요 운영 체제에서 사용할 수 있는 무료 소스 코드 편집기 또는 통합 개발 환경(IDE)입니다. 다양한 프로그래밍 언어에 대한 대규모 확장 모음을 통해 VS Code는

CakePHP는 오픈 소스 MVC 프레임워크입니다. 이를 통해 애플리케이션 개발, 배포 및 유지 관리가 훨씬 쉬워집니다. CakePHP에는 가장 일반적인 작업의 과부하를 줄이기 위한 여러 라이브러리가 있습니다.
