Inhaltsverzeichnis
回复内容:
Heim Backend-Entwicklung PHP-Tutorial rabbitmq与gearman有什么不同之处?

rabbitmq与gearman有什么不同之处?

Jun 06, 2016 pm 04:45 PM
gearman rabbitmq

rabbitmq与gearman都是做消息队列的,那么两者之间有什么区别,或者说优点与缺点的比较各在哪里?

回复内容:

Gearman是分布式任务分发系统,重点是job
RabbitMQ是分布式消息队列,重在message/data

Gearman要实现Message的priority、order、filter、persistence..都比较麻烦(或者说不够直接),而这些都是典型的MQ系统要考虑的。 正如楼上回复的一样,Gearman 偏重任务分发(也有调度),基本工作模式,是由 Client (多个)向 Server 去注册一些函数,当然 Server 接受到任务后,分发到这些函数上。

RabbitMQ 则是很多消息模型的实现,比如简单的生产者消费者、发布订阅、广播,甚至可以模拟 RPC 等等,Gearman 的功能,简单的生产者消费者模型就可以实现,只是思路上稍微换一下,需要消费消息来实现,官方也有类似参考例子:RabbitMQ - RabbitMQ tutorial - Work queues

建议看下 RabbitMQ 官方这个例子教程 RabbitMQ - Getting started with RabbitMQ ,里面包含了几种模型的实例,很容易结合我们现实中场景。

至于优缺点,仁者见仁。

大概三年前吧,我给一家某行业内比较知名公司优化过 Gearman 到 RabbitMQ 的方案,高峰时候一小时消息量在 x 千万以上,优化前 Gearman Server 负载较重,包括 Client(Worker)也会经常挂掉,很多消息会丢失,后来迁移到 RabbitMQ 上面,Server 只有一台(备份一台基本从来就没用过),Client 采用 ACK 确认消息成功消费掉,后来就没有然后了。。。这里故事不在描述。

推荐使用 RabbitMQ,不仅仅是作为消息模型,还可以改善系统架构设计。
Erklärung dieser Website
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn

Heiße KI -Werkzeuge

Undresser.AI Undress

Undresser.AI Undress

KI-gestützte App zum Erstellen realistischer Aktfotos

AI Clothes Remover

AI Clothes Remover

Online-KI-Tool zum Entfernen von Kleidung aus Fotos.

Undress AI Tool

Undress AI Tool

Ausziehbilder kostenlos

Clothoff.io

Clothoff.io

KI-Kleiderentferner

AI Hentai Generator

AI Hentai Generator

Erstellen Sie kostenlos Ai Hentai.

Heiße Werkzeuge

Notepad++7.3.1

Notepad++7.3.1

Einfach zu bedienender und kostenloser Code-Editor

SublimeText3 chinesische Version

SublimeText3 chinesische Version

Chinesische Version, sehr einfach zu bedienen

Senden Sie Studio 13.0.1

Senden Sie Studio 13.0.1

Leistungsstarke integrierte PHP-Entwicklungsumgebung

Dreamweaver CS6

Dreamweaver CS6

Visuelle Webentwicklungstools

SublimeText3 Mac-Version

SublimeText3 Mac-Version

Codebearbeitungssoftware auf Gottesniveau (SublimeText3)

So erstellen Sie eine zuverlässige Messaging-App mit React und RabbitMQ So erstellen Sie eine zuverlässige Messaging-App mit React und RabbitMQ Sep 28, 2023 pm 08:24 PM

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 So verwenden Sie RabbitMQ, um die verteilte Nachrichtenverarbeitung in PHP zu implementieren Jul 18, 2023 am 11:00 AM

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

Verwenden von RabbitMQ in Go: Eine vollständige Anleitung Verwenden von RabbitMQ in Go: Eine vollständige Anleitung Jun 19, 2023 am 08:10 AM

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

Wie SpringBoot RabbitMQ integriert, um eine Verzögerungswarteschlange zu implementieren Wie SpringBoot RabbitMQ integriert, um eine Verzögerungswarteschlange zu implementieren May 16, 2023 pm 08:31 PM

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:

Lösung für die Echtzeit-Datensynchronisierung zwischen Golang und RabbitMQ Lösung für die Echtzeit-Datensynchronisierung zwischen Golang und RabbitMQ Sep 27, 2023 pm 10:41 PM

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

Anwendungspraxis von Go-Zero und RabbitMQ Anwendungspraxis von Go-Zero und RabbitMQ Jun 23, 2023 pm 12:54 PM

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

Golang RabbitMQ: Architekturentwurf und Implementierung eines hochverfügbaren Nachrichtenwarteschlangensystems Golang RabbitMQ: Architekturentwurf und Implementierung eines hochverfügbaren Nachrichtenwarteschlangensystems Sep 28, 2023 am 08:18 AM

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.

Integrationspraxis von Swoole und RabbitMQ: Aufbau eines hochverfügbaren Nachrichtenwarteschlangensystems Integrationspraxis von Swoole und RabbitMQ: Aufbau eines hochverfügbaren Nachrichtenwarteschlangensystems Jun 14, 2023 pm 12:56 PM

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

See all articles