So verwenden Sie Rabbitmq in thinkPHP5
Wie verwende ich Rabbitmq mit thinkPHP5?
Nach der Installation der Rabbitmq-Erweiterung von tp5 fügen Sie die Datei Rabbitmq.php zur Projektstammverzeichnisdatei hinzu, um Rabbitmq zu starten.
<?php define('APP_PATH', __DIR__ . '/application/'); define('BIND_MODULE','rabbitmq/Client'); // 加载框架引导文件 require __DIR__ . '/thinkphp/start.php';
Generator
private function queueEvent($message) { // error_log("\n******" . date("His") . "********\n" . print_r($message, 1) . "\n*************\n", 3, 'messag_event.log'); dump($message); //设置你的连接 $conn_args = array('host' => 'ip', 'port' => '5672', 'login' => 'ymq', 'password' => '123456', 'vhost'=>'/'); $content = $message; //创建连接和channel $conn = new \AMQPConnection($conn_args); if (!$conn->connect()) { die("Cannot connect to the broker!\n"); } $channel = new \AMQPChannel($conn); //创建交换机 $e_name = 'MQTT_device_event'; //交换机名 $ex = new \AMQPExchange($channel); $ex->setName($e_name); // $ex->setType(AMQP_EX_TYPE_TOPIC); //direct类型 $ex->setType(AMQP_EX_TYPE_DIRECT); //direct类型 $ex->setFlags(AMQP_DURABLE); //持久化 $ex->declareExchange(); }
Verwandte Empfehlungen: „ThinkPHP Tutorial“
Run php Directory Run Producer
Consumer
public function index() { //连接RabbitMQ $conn_args = array('host' => 'ip', 'port' => '5672', 'login' => 'ymq', 'password' => '123456', 'vhost' => '/'); $e_name = 'MQTT_device_event'; //交换机名 $q_name = 'q_event'; //队列名 $k_route = 'key_event'; //路由key //创建连接和channel $conn = new \AMQPConnection($conn_args); if (!$conn->connect()) { die("Cannot connect to the broker!\n"); } $channel = new \AMQPChannel($conn); //创建交换机 $ex = new \AMQPExchange($channel); $ex->setName($e_name); $ex->setType(AMQP_EX_TYPE_DIRECT); //direct类型 $ex->setFlags(AMQP_DURABLE); //持久化 $ex->declareExchange(); //创建队列 $q = new \AMQPQueue($channel); $q->setName($q_name); $q->setFlags(AMQP_DURABLE); //持久化 $q->declareQueue(); //最好队列object在这里declare()下,否则如果是新的queue会报错 //绑定交换机与队列,并指定路由键,可以多个路由键 $q->bind($e_name, $k_route); //$q->bind($e_name, 'key_33'); //阻塞模式接收消息 echo "Message:\n"; while(True){ $q->consume(function($envelope, $queue) { $msg = $envelope->getBody(); //处理数据 echo $msg . PHP_EOL; //处理消息 $queue->ack($envelope->getDeliveryTag()); //手动发送ACK应答 }); //$q->consume('processMessage', AMQP_AUTOACK); //自动ACK应答 } $conn->disconnect(); }
Führen Sie den Befehl php Rabbitmq aus
zum Starten
Überprüfen Sie, ob die Warteschlange belegt ist
Einloggen bei http://127.0.0.115672/# / Warteschlangen Adresse
Das obige ist der detaillierte Inhalt vonSo verwenden Sie Rabbitmq in thinkPHP5. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Heiße KI -Werkzeuge

Undresser.AI Undress
KI-gestützte App zum Erstellen realistischer Aktfotos

AI Clothes Remover
Online-KI-Tool zum Entfernen von Kleidung aus Fotos.

Undress AI Tool
Ausziehbilder kostenlos

Clothoff.io
KI-Kleiderentferner

Video Face Swap
Tauschen Sie Gesichter in jedem Video mühelos mit unserem völlig kostenlosen KI-Gesichtstausch-Tool aus!

Heißer Artikel

Heiße Werkzeuge

Notepad++7.3.1
Einfach zu bedienender und kostenloser Code-Editor

SublimeText3 chinesische Version
Chinesische Version, sehr einfach zu bedienen

Senden Sie Studio 13.0.1
Leistungsstarke integrierte PHP-Entwicklungsumgebung

Dreamweaver CS6
Visuelle Webentwicklungstools

SublimeText3 Mac-Version
Codebearbeitungssoftware auf Gottesniveau (SublimeText3)

Heiße Themen

So erstellen Sie eine zuverlässige Messaging-Anwendung mit React und RabbitMQ Einführung: Moderne Anwendungen müssen zuverlässiges Messaging unterstützen, um Funktionen wie Echtzeitaktualisierungen und Datensynchronisierung zu erreichen. React ist eine beliebte JavaScript-Bibliothek zum Erstellen von Benutzeroberflächen, während RabbitMQ eine zuverlässige Messaging-Middleware ist. In diesem Artikel wird erläutert, wie Sie React und RabbitMQ kombinieren, um eine zuverlässige Messaging-Anwendung zu erstellen, und es werden spezifische Codebeispiele bereitgestellt. RabbitMQ-Übersicht:

So verwenden Sie RabbitMQ, um die verteilte Nachrichtenverarbeitung in PHP zu implementieren. Einführung: In der groß angelegten Anwendungsentwicklung sind verteilte Systeme zu einer häufigen Anforderung geworden. Die verteilte Nachrichtenverarbeitung ist ein Muster, das die Effizienz und Zuverlässigkeit des Systems verbessert, indem Aufgaben auf mehrere Verarbeitungsknoten verteilt werden. RabbitMQ ist ein zuverlässiges Open-Source-Nachrichtenwarteschlangensystem, das das AMQP-Protokoll verwendet, um die Nachrichtenzustellung und -verarbeitung zu implementieren. In diesem Artikel erfahren Sie, wie Sie RabbitMQ in PHP zur Verteilung verwenden

So stellen Sie sicher, dass Nachrichten nicht verloren gehen: Der Rabbitmq-Nachrichtenübermittlungspfad Producer->Switch->Queue->Consumer ist im Allgemeinen in drei Phasen unterteilt. 1. Der Produzent stellt die Zuverlässigkeit der Nachrichtenübermittlung sicher. 2.MQ-interne Nachrichten gehen nicht verloren. 3. Der Verbraucherkonsum ist erfolgreich. Was ist die Zuverlässigkeit der Nachrichtenzustellung? Einfach ausgedrückt bedeutet dies, dass Nachrichten zu 100 % an die Nachrichtenwarteschlange gesendet werden. Nachdem der Produzent die Nachricht übermittelt hat, kann er bestätigen, dass die Nachricht an mq gesendet wurde. #NONE: deaktivieren Der Release-Bestätigungsmodus, der der Standardwert ist, korreliert:

Da moderne Anwendungen immer komplexer werden, ist Messaging zu einem leistungsstarken Werkzeug geworden. In diesem Bereich hat sich RabbitMQ zu einem sehr beliebten Nachrichtenbroker entwickelt, mit dem Nachrichten zwischen verschiedenen Anwendungen übermittelt werden können. In diesem Artikel erfahren Sie, wie Sie RabbitMQ in der Go-Sprache verwenden. Dieses Handbuch behandelt Folgendes: Einführung in RabbitMQ RabbitMQ-Installation RabbitMQ-Grundkonzepte Erste Schritte mit RabbitMQ in Go RabbitMQ und Go

Einführung in die Lösung für die Echtzeit-Datensynchronisierung zwischen Golang und RabbitMQ: In der heutigen Zeit, mit der Popularität des Internets und dem explosionsartigen Wachstum des Datenvolumens, wird die Echtzeit-Datensynchronisierung immer wichtiger. Um die Probleme der asynchronen Datenübertragung und Datensynchronisierung zu lösen, haben viele Unternehmen damit begonnen, Nachrichtenwarteschlangen zu verwenden, um eine Echtzeitsynchronisierung von Daten zu erreichen. In diesem Artikel wird eine Echtzeit-Datensynchronisierungslösung basierend auf Golang und RabbitMQ vorgestellt und spezifische Codebeispiele bereitgestellt. 1. Was ist RabbitMQ? Rabbi

Jetzt beginnen immer mehr Unternehmen, das Microservice-Architekturmodell zu übernehmen, und in dieser Architektur sind Nachrichtenwarteschlangen zu einer wichtigen Kommunikationsmethode geworden, unter denen RabbitMQ weit verbreitet ist. In der Go-Sprache ist Go-Zero ein Framework, das in den letzten Jahren entstanden ist. Es bietet Entwicklern eine einfachere Verwendung von Nachrichtenwarteschlangen. Im Folgenden werden wir Go-Zero anhand praktischer Anwendungen vorstellen und Anwendungspraxis von RabbitMQ. 1.RabbitMQ-ÜbersichtRabbit

GolangRabbitMQ: Der architektonische Entwurf und die Implementierung eines hochverfügbaren Nachrichtenwarteschlangensystems erfordern spezifische Codebeispiele. Einführung: Mit der kontinuierlichen Entwicklung der Internettechnologie und ihrer breiten Anwendung sind Nachrichtenwarteschlangen zu einem unverzichtbaren Bestandteil moderner Softwaresysteme geworden. Als Werkzeug zur Erzielung von Entkopplung, asynchroner Kommunikation, fehlertoleranter Verarbeitung und anderen Funktionen bietet die Nachrichtenwarteschlange Unterstützung für hohe Verfügbarkeit und Skalierbarkeit für verteilte Systeme. Als effiziente und prägnante Programmiersprache wird Golang häufig zum Aufbau von Systemen mit hoher Parallelität und hoher Leistung verwendet.

Mit dem Aufkommen des Internetzeitalters haben Nachrichtenwarteschlangensysteme immer mehr an Bedeutung gewonnen. Es ermöglicht asynchrone Vorgänge zwischen verschiedenen Anwendungen, reduziert die Kopplung und verbessert die Skalierbarkeit, wodurch die Leistung und das Benutzererlebnis des gesamten Systems verbessert werden. Im Nachrichtenwarteschlangensystem ist RabbitMQ eine leistungsstarke Open-Source-Nachrichtenwarteschlangensoftware, die eine Vielzahl von Nachrichtenprotokollen unterstützt und häufig in Finanztransaktionen, E-Commerce, Online-Spielen und anderen Bereichen eingesetzt wird. In praktischen Anwendungen ist es häufig notwendig, RabbitMQ mit anderen Systemen zu integrieren. In diesem Artikel wird die Verwendung von sw vorgestellt
