検索
ホームページphp教程PHP开发ActiveMQ のセッション設定の関連理解

参考ブログ投稿: http://www.cnblogs.com/SzeCheng/p/4792084.html

参考ブログ投稿: http://activemq.apache.org/Producer-flow-control.html

用語の説明:

P: プロデューサー

C: コンシューマー

サーバー: P または ActiveMQ サービス

クライアント: ActiveMQ サービスまたは C

クライアントがメッセージを正常に受信したという兆候は、メッセージが署名されていることです。メッセージを正常に受信するには、通常、次の 3 つの段階が含まれます。

1.クライアントはメッセージを受け取ります

2.クライアントはメッセージを処理します

3.メッセージは署名されています。

session = connection.createSession(Boolean.false, Session.CLIENT_ACKNOWLEDGE);##第一个参数控制事务,第二个参数控制消息

トランザクションのないセッションでは、メッセージがいつどのように署名されるかは、セッションの設定によって異なります。

1. Session.AUTO_ACKNOWLEDGE

クライアントが受信または onMessage から正常に戻ると、Session はクライアントによるこのメッセージの受信に自動的に署名します。

2. Session.CLIENT_ACKNOWLEDGE

クライアントは、メッセージのacknowledgeメソッドを呼び出してメッセージに署名します。

message.acknowledge();

トランザクションを伴うセッションでは、トランザクションが送信されると署名が自動的に発生します。トランザクションがロールバックされると、受信したすべてのメッセージが再度配信されます。実際、ここでの Session.CLIENT_ACKNOWLEDGE はほとんど役に立ちません。

session = connection.createSession(Boolean.TRUE, Session.CLIENT_ACKNOWLEDGE);
session.commit();

概要:

1. プロデューサーの場合: サーバーは P、クライアントは ActiveMQ サービスです。 セッションは AUTO_ACKNOWLEDGE と CLIENT_ACKNOWLEDGE に設定されますが、状況によりますが、その差はそれほど大きくありません。

2. コンシューマの場合: サーバーは ActiveMQ で、クライアントは C です。セッションは AUTO_ACKNOWLEDGE に設定され、メッセージが受信されると (受信または onMessage が正常に返される)、消費は成功し、データはキューから削除されます。データが目的の結果に正しく処理されるかどうかは気にしません。セッションが CLIENT_ACKNOWLEDGE に設定されている場合、正常に消費するには確認メソッドを手動で呼び出す必要があり、その後データはキューから削除されます。

3. P と C のセッションが相互に影響を与えないように設定されているモード。


声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
Java ActiveMQ 的 20 个最佳实践Java ActiveMQ 的 20 个最佳实践Feb 20, 2024 pm 09:48 PM

1.选择合适的客户端传输协议ActiveMQ支持多种客户端传输协议,包括STOMP、AMQP和OpenWire。根据您的应用程序需求选择合适的协议,以优化性能和可靠性。2.配置消息持久性持久性消息即使在服务器重新启动后也能持久化,而非持久性消息则不会。对于关键消息,选择持久性以确保可靠传递。演示代码://设置消息持久性MessageProducerproducer=session.createProducer(destination);producer.setDeliveryMode(Deliv

Java ActiveMQ 的 20 个高级技巧Java ActiveMQ 的 20 个高级技巧Feb 20, 2024 pm 09:51 PM

1.消息路由使用JMSSelectors过滤消息:使用JMSSelectors根据消息属性对传入消息进行筛选,仅处理相关消息。创建自定义消息路由器:扩展ActiveMQ的路由功能,通过编写自定义路由器将消息发送到特定目的地。配置轮询负载均衡:将传入消息均匀分布到多个消息消费者,提高处理能力。2.持久性启用持久性会话:确保即使应用程序或服务器发生故障,消息也能持久存储,避免丢失。配置死信队列(DLQ):将处理失败的消息移至DLQ,以便重新处理或分析。使用Journal存储:提高持久性消息的性能,减

Java ActiveMQ:轻松实现分布式系统的异步通信Java ActiveMQ:轻松实现分布式系统的异步通信Feb 19, 2024 pm 10:18 PM

ActiveMQ是Apache出品的一款开源消息中间件,它使用Java语言开发,具有可靠的消息传递、异步通信和集群支持等特点。ActiveMQ能够在不同的应用之间进行数据交换,并且支持多种消息协议,如JMS、AMQP和MQtT等。1.ActiveMQ的优势ActiveMQ是一款非常成熟的消息中间件,它具有以下优势:可靠的消息传递:ActiveMQ能够保证消息的可靠传递,即使在网络故障或服务器宕机的情况下,消息也不会丢失。异步通信:ActiveMQ支持异步通信,允许不同的应用之间进行非实时的通信。

怎么在SpringBoot中整合ActiveMQ怎么在SpringBoot中整合ActiveMQMay 11, 2023 pm 06:16 PM

目录结构引入maven依赖org.springframework.bootspring-boot-starter-parent1.5.4.RELEASEUTF-8UTF-81.8org.springframework.bootspring-boot-starterorg.springframework.bootspring-boot-starter-weborg.springframework.bootspring-boot-starter-testtestorg.springframework

Java JMS入门:轻松掌握消息传递技术的基础知识Java JMS入门:轻松掌握消息传递技术的基础知识Feb 26, 2024 am 10:34 AM

1.JavaJMS简介JavaJMS是一个用于建立、发送和接收消息的Javaapi。它提供了可靠的消息传递功能,非常适合分布式系统和企业级应用程序。消息传递系统可以将消息从一个应用程序发送到另一个应用程序,即使这两个应用程序位于不同的机器上。2.JMSAPIJMSAPI定义了一系列接口和类,用于发送和接收消息。这些接口和类包括:javax.jms.ConnectionFactory:用于创建连接到JMS服务器的连接。javax.jms.Connection:连接到JMS服务器的连接。javax.

Springboot中如何整合ActivemqSpringboot中如何整合ActivemqMay 21, 2023 pm 01:13 PM

1导入整合所需要的依赖:org.springframework.bootspring-boot-starter-activemq2创建application.properties文件spring.activemq.broker-url=tcp://127.0.0.1:61616spring.activemq.user=adminspring.activemq.password=adminserver.port=8080queue=myqueue3.自定义配置文件QueueConfig读取配置文件

Java ActiveMQ 的 20 个必知概念Java ActiveMQ 的 20 个必知概念Feb 21, 2024 am 08:40 AM

1.消息代理(Broker)ActiveMQ核心组件,负责处理所有消息流。它提供一个平台,应用程序可以连接、发送和接收消息。BrokerServicebroker=newBrokerService();broker.addConnector("tcp://0.0.0.0:61616");broker.start();2.消息队列在ActiveMQ中存储消息的逻辑概念容器。消息队列可以从多个生产者接收消息,并将其传递给多个消费者。Queuequeue=session.createQueue("my

Java ActiveMQ:助力企业实现可靠、高效的消息传输Java ActiveMQ:助力企业实现可靠、高效的消息传输Feb 19, 2024 pm 10:12 PM

ActiveMQ是一个完全开源的Java消息服务器,也是Apache软件基金会旗下最受欢迎的项目之一。它遵循Java消息服务(JMS)规范,提供了一套用于构建分布式、异步和面向消息的应用程序的api。ActiveMQ以其可靠性、高效性和灵活性而著称,使其成为各种企业应用程序的理想选择。可靠性:ActiveMQ使用持久化存储机制来确保消息的可靠传递。当消息被发送到ActiveMQ时,它将被写入磁盘,即使服务器发生故障,这些消息也不会丢失。当服务器重新启动时,它会从持久化存储中恢复这些消息,并将其传

See all articles

ホットAIツール

Undresser.AI Undress

Undresser.AI Undress

リアルなヌード写真を作成する AI 搭載アプリ

AI Clothes Remover

AI Clothes Remover

写真から衣服を削除するオンライン AI ツール。

Undress AI Tool

Undress AI Tool

脱衣画像を無料で

Clothoff.io

Clothoff.io

AI衣類リムーバー

AI Hentai Generator

AI Hentai Generator

AIヘンタイを無料で生成します。

ホットツール

ZendStudio 13.5.1 Mac

ZendStudio 13.5.1 Mac

強力な PHP 統合開発環境

EditPlus 中国語クラック版

EditPlus 中国語クラック版

サイズが小さく、構文の強調表示、コード プロンプト機能はサポートされていません

MantisBT

MantisBT

Mantis は、製品の欠陥追跡を支援するために設計された、導入が簡単な Web ベースの欠陥追跡ツールです。 PHP、MySQL、Web サーバーが必要です。デモおよびホスティング サービスをチェックしてください。

SublimeText3 Linux 新バージョン

SublimeText3 Linux 新バージョン

SublimeText3 Linux 最新バージョン

mPDF

mPDF

mPDF は、UTF-8 でエンコードされた HTML から PDF ファイルを生成できる PHP ライブラリです。オリジナルの作者である Ian Back は、Web サイトから「オンザフライ」で PDF ファイルを出力し、さまざまな言語を処理するために mPDF を作成しました。 HTML2FPDF などのオリジナルのスクリプトよりも遅く、Unicode フォントを使用すると生成されるファイルが大きくなりますが、CSS スタイルなどをサポートし、多くの機能強化が施されています。 RTL (アラビア語とヘブライ語) や CJK (中国語、日本語、韓国語) を含むほぼすべての言語をサポートします。ネストされたブロックレベル要素 (P、DIV など) をサポートします。