activemq-artemis/docs/user-manual/zh/examples.xml

428 lines
30 KiB
XML
Raw Blame History

This file contains ambiguous Unicode characters

This file contains Unicode characters that might be confused with other characters. If you think that this is intentional, you can safely ignore this warning. Use the Escape button to reveal them.

<?xml version="1.0" encoding="UTF-8"?>
<!-- ============================================================================= -->
<!-- Copyright © 2009 Red Hat, Inc. and others. -->
<!-- -->
<!-- The text of and illustrations in this document are licensed by Red Hat under -->
<!-- a Creative Commons AttributionShare Alike 3.0 Unported license ("CC-BY-SA"). -->
<!-- -->
<!-- An explanation of CC-BY-SA is available at -->
<!-- -->
<!-- http://creativecommons.org/licenses/by-sa/3.0/. -->
<!-- -->
<!-- In accordance with CC-BY-SA, if you distribute this document or an adaptation -->
<!-- of it, you must provide the URL for the original version. -->
<!-- -->
<!-- Red Hat, as the licensor of this document, waives the right to enforce, -->
<!-- and agrees not to assert, Section 4d of CC-BY-SA to the fullest extent -->
<!-- permitted by applicable law. -->
<!-- ============================================================================= -->
<chapter id="examples">
<title>例子</title>
<para>在ActiveMQ的发布包中有超过70个不同的例子。这些例子直接可以运行。它们分别展示了ActiveMQ所具有的各种功能。</para>
<para>所有的例子都在ActiveMQ发布包的 <literal>examples</literal>目录下。所有的例子被分成了两大类:
JMS例子和内核例子。JMS例子展现的是JMS的各种功能内核的例子则展示的是内核API的功能。
</para>
<para>此外ActiveMQ还提供了一些Java EE的例子这些例子需要JBoss应用服务器才能运行。</para>
<section>
<title>JMS 例子</title>
<para>要运行一个JMS例子只要进入到相应例子的子目录运行 <literal>./build.sh</literal> (或者
在Windows平台上运行<literal>build.bat</literal>)即可。</para>
<para>下面列出的这些JMS例子并配有简要的说明。</para>
<section id="application-level-failover">
<title>应用层的失效备援Failover</title>
<para>ActiveMQ支持应用层的失效备援。这在服务器端没有复制replication配置的情况下是很有用的。</para>
<para>应用程序可以注册一个JMS <literal>ExceptionListener</literal>。当ActiveMQ检测到连接故障时它会
通知这个注册的Listener。</para>
<para>这个<literal>ExceptionListener</literal>在接到ActiveMQ的通知后可以与其它的节点创建
新的连接、会话等对象,以使应用程序能继续运行。</para>
<para>应用层的失效备援是实现高可获得性HA的一种方法。它与自动失效备援不同之处在于它需要编写额外的代码。
同时由于发生故障时旧的会话结束,这会造成那些还没来得及提交的工作丢失,还会造成任何没有通知的消息被重发。</para>
</section>
<section id="examples.bridge">
<title>内核桥Bridge例子</title>
<para><literal>bridge</literal>例子展示的是将一个内核桥部署到一个服务器上从本地的queue接收消息并将其转发到
另一服务器的地址上。</para>
<para>内核的bridge可用来在两个互相分开的ActiveMQ的服务器间建立一个消息流。它可以处理临时性的连接故障特别适用于
不可靠的网络的情况。广域网就是一个例子。</para>
</section>
<section id="examples.browsers">
<title>浏览器Browser</title>
<para><literal>browser</literal>例子展示的是在ActiveMQ中如何使用JMS <literal
>QueueBrowser</literal></para>
<para>有关JMS queue的概念在JMS 1.1 specification有明确的定义这里就不再叙述。</para>
<para> 一个<literal>QueueBrowser</literal>可以用来观察queue中的消息而影响它们。它可以观察queue中的全部
消息也可以定义一个选择器selector来选择性地察看消息。</para>
</section>
<section>
<title>Client Kickoff</title>
<para><literal>client-kickoff</literal>例子展示的是如何利用JMX管理接口通过已知的IP地址来断开客户端的连接。</para>
</section>
<section>
<title>客户端的负载均衡</title>
<para><literal>client-side-load-balancing</literal>例子展示的是通过一个JMS连接可以在集群的不同节点上创建
会话。也就是说ActiveMQ可以对客户端的会话创建进行集群内的负载均衡。</para>
</section>
<section id="examples.clustered.grouping">
<title>集群分组</title>
<para>与分组grouping例子相似只是本例所展示的是集群的情况。发向不同节点的具有相同组id的消息
都会传送到同一个节点上的同一个接收者consumer</para>
</section>
<section>
<title>集群队列</title>
<para><literal>clustered-queue</literal> 例子将一个JMS queue部署到两个节点上。这两个节点组成一个集群。
我们在每个节点上各创建一个接收者consumer但只在其中一个节点上创建一个发送者producer。利用发送者
发送一些消息然后确认两个接收者以轮换方式round-robin接收这些消息。</para>
</section>
<section>
<title>单机集群</title>
<para><literal>clustered-standalone</literal>例子所展示的是如何在同一台机器上配置并运行
3个节点的集群。在每个节点上都创建了一个JMS topic的订阅者subscriber。只在其中一个节点上
创建了一相发送者来向这个topic发送一些消息。然后我们确认所有的subscriber都接收到了这些消息。</para>
</section>
<section>
<title>集群的Topic</title>
<para><literal>clustered-topic</literal>例子将一个JMS topic部署到两个节点上。这两个节点组成一个集群。
然后在每个节点上创建了一个订阅者subscriber只在一个节点上创建一个发送者producer。通过这个发
送者发送一些消息,确认两个订阅者都收到了这些消息。</para>
</section>
<section id="examples.consumer-rate-limit">
<title>限制接收速率</title>
<para>ActiveMQ可以控制一个JMS消息接收者接收消息的速度。这是在创建或部署连接工厂时通过其配置参数来完成的。</para>
<para>如果设置了这个速度的限制ActiveMQ会保证其向接收者传递消息的速度永远不会超过这个限制。</para>
</section>
<section id="examples.dead-letter">
<title>死消息Dead Letter</title>
<para><literal>dead-letter</literal>例子让你了解如何定义和处理死消息。有时候消息由于某种原因不能成功
地传递出去,比如接收者在接收消息的交易中发生回滚。</para>
<para>发生回滚后消息被”退回“到JMS目标destination准备进行重发。这一过程可能会被不停地重复下去造成
消息永远发不出去,而且浪费系统的时间。</para>
<para>为了避免上述情况的发生,消息系统引入了死消息的概念:即当一个消息被反复重发不成功达到一定的次数时,该消息
便成为了死消息它将从所属目标destination中删除并发送到一个称为死消息目标的目标。用户可以从死消息目标
          上接收这些死消息以便进行分析。</para>
</section>
<section id="examples.delayed-redelivery">
<title>延迟再发送</title>
<para><literal>delayed-redelivery</literal>是一个展示如何配置ActiveMQ延迟再发送消息的例子。</para>
<para>当客户端经常发生故障或发生事务回滚时消息会不停地重复发送这样会造成CPU和网络资源被不间断的
重复发送所占用,影响其它工作的进行。延迟再发送可以有效地减轻这种情况。</para>
</section>
<section id="divert-example">
<title>转移Divert</title>
<para>ActiveMQ通过配置可以将消息从一个地址自动地转移到另一地址。这个例子就是向用户展示转移的配置和使用。</para>
</section>
<section>
<title>持久订阅Durable Subscription</title>
<para><literal>durable-subscription</literal>是一个在ActiveMQ中如何使用持久订阅durable
subscription的例子。持久订阅是标准JMS的一部分在JMS 1.1规范中有它的详细定义。</para>
<para>对于一个持久订阅来说,它的消息可以在订阅没有处于接收状态时被保留。另外,如果发到它的消息是持久
消息的话,这些消息可以在服务器故障或重启时不丢失。 </para>
</section>
<section>
<title>嵌入方式Embedded</title>
<para><literal>embedded</literal>是一个如何将ActiveMQ服务嵌入到你的应用中的例子。</para>
</section>
<section>
<title>HTTP 传输协议的支持</title>
<para><literal>http-transport</literal>展示了ActiveMQ如何支持在传输层使用HTTP协议来发送和接收消息。</para>
</section>
<section>
<title>直接实例化JMS对象</title>
<para>JMS 对象是指 <literal>连接工厂ConnectionFactory</literal><literal
>队列Queue</literal><literal>话题Topic</literal> 的实例。通常情况下它们通过JNDI服务
来获取。它们在JMS术语中被称为“被管理的对象administered objects”。</para>
<para>有的时候客户端没有JNDI服务可用或者不适合使用JNDI。那么在没有JNDI的情况下ActiveMQ允许直接在客户端
将这些JMS对象实例化。</para>
</section>
<section id="examples.interceptor">
<title>拦截器Interceptor</title>
<para>ActiveMQ可以配置拦截器以便用户可以自己处理各种各样的消息事件。这个例子就是给用户展示如何使用
拦截器。</para>
</section>
<section id="examples.jaas">
<title>JAAS</title>
<para><literal>jaas</literal>是一个如何配置JAAS安全模式的例子。ActiveMQ可以使用JAAS来进行用户的验证与权限控制。</para>
</section>
<section id="examples.jms.jms-bridge">
<title>JMS桥Bridge</title>
<para><literal>jms-brige</literal>是一个在两个单独ActiveMQ服务器之间设置桥的例子。</para>
</section>
<section id="examples.jmx">
<title>JMX管理</title>
<para><literal>jmx</literal>例子展示了如何使用JMX来管理ActiveMQ。</para>
</section>
<section id="examples.large-message">
<title>大消息</title>
<para><literal>large-message</literal>例子给用户展示了使用ActiveMQ来发送和接收大消息的功能。ActiveMQ
支持超大消息的发送与接收。这些消息可以大到内存无法装下。它的大小只受服务器的硬盘空间的限制。</para>
<para>在服务器端大消息是被持久化的,所以它可以承受服务器的崩溃或重启而不丢失或损坏。</para>
</section>
<section id="examples.last-value-queue">
<title>最新值队列</title>
<para><literal>last-value-queue</literal>向用户展示了如何定义与使用最新值队列。当在配置文件定义好
最新值的参数后,这些最新值队列就会自动地用新的消息取代旧的消息,也就是说旧的消息被抛弃掉。这样一个最新
值的队列总是保留最新的消息在队列中。</para>
<para>股票价格消息就是一个典型的最新值队列的用例。对用户来说他所关心的是一支股票的最新价格,对于过去的价格
是没有多大兴趣的。</para>
</section>
<section>
<title>分布式队列的负载均衡</title>
<para><literal>clustered-queue</literal>例子中配置了一个2节点的ActiveMQ服务集群。在集群上部署了
一个分布式JMS队列。</para>
<para>然后在一个节点上创建了一个发送者producer在两个节点上分别创建一个接收者consumer。通过
发送者向队列发送一些消息然后被两的接收者以轮流round-robin的方式接收。</para>
<para>本例说明了ActiveMQ可以将消息向集群中的每个接收者分布式地传递消息。</para>
</section>
<section id="examples.management">
<title>管理</title>
<para><literal>management</literal>例子展示的是如何使用JMS消息来实现对ActiveMQ的管理。</para>
</section>
<section id="examples.management-notifications">
<title>管理通知</title>
<para><literal>management-notification</literal>展示了ActiveMQ如何以JMS消息的形式向用户发送
管理通知。当某些事件发生时如接收都创建关闭地址创建与删除安全验证失败等等ActiveMQ会向客户
发出JMS消息以通知客户这些事件的相关信息。客户接收到这些信息后可以作出相应的处理。</para>
</section>
<section id="examples.message-counters">
<title>消息计数器</title>
<para><literal>message-counters</literal>是一个展示如何使用消息计数器获取JMS队列中的消息信息。</para>
</section>
<section id="examples.expiry">
<title>消息失效</title>
<para><literal>expiry</literal>例子中包括了如何定义和使用消息失效期。消息如果在消息服务器中存留超过一定
的时间就可以被删除。根据JMS规范接收者就不应该接收到已经过了失效期的消息。但是并不保证一定接收不到</para>
<para>ActiveMQ可以给一个队列配上一个失效地址当队列中的消息失效时它们就会从队列中删除并转移到该失效地址。
这些“失效"的消息可以从失效地址中接收并进行分析。</para>
</section>
<section id="examples.message-group">
<title>消息组</title>
<para><literal>message-group</literal>展示的是如何在ActiveMQ中配置消息组。消息组可以让你的消息
只被一个接收者接收。属于一个消息组中的消息有如下特性:</para>
<para>
<itemizedlist>
<listitem>
<para>同一个消息组中的消息都有相同的组ID。即它们的JMSXGroupID属性值相同。</para>
</listitem>
<listitem>
<para>第一个接收到消息组中的消息的接收者将会接收到所有该组中的消息。</para>
</listitem>
</itemizedlist>
</para>
</section>
<section id="examples.message-group2">
<title>消息组例2</title>
<para><literal>message-group2</literal>是另外一个消息组的例子。它展示的是通过配置连接工厂来实现
消息组的功能。</para>
</section>
<section id="examples.message-priority">
<title>消息优先级</title>
<para>消息优先级会影响消息的传递顺序。</para>
<para>消息优先级由标准的JMS消息头属性JMSPriority的值确定。参见JMS 1.1规范。</para>
<para>优先级是一个0到9之间的整数值。当消息被传递时根据优先级的不同消息的传递顺序会收到影响。优先级
高的消息往往会比优先级低的先传递给接收者。 </para>
<para>优先级相同的消息会按照它们到达目标的顺序来传递。在JMS 1.1规范中有详细的规定。</para>
</section>
<section id="examples.no-consumer-buffering">
<title>零接收缓冲</title>
<para>默认时ActiveMQ的接收者客户端有一个消息缓冲它用来保存从服务器上预先接收的消息。这样做是为了提高
性能。因为如果没有这个缓冲每次调用receive()或onMessage()后ActiveMQ就会访问一次服务器请求下
一个消息。</para>
<para>这样每接收一个消息就会增加一次网络往返的传输。因此ActiveMQ在默认情况下使用客户端的接收缓冲来
预先接收消息,以提高效率。</para>
<para>然而在某些情况下这样的缓冲不符合应用需要。那么可以将缓冲关闭。本例就是展示如何关闭接收缓冲。</para>
</section>
<section id="examples.non-transaction-failover">
<title>带有服务器数据复制的非事务失效备援</title>
<para><literal>non-transaction-failover</literal>例子展示了由两个服务器组成的高可获得性主/从关系。
客户端使用一个非交易的JMS会话session可以在主节点崩溃的情况下从主节点失效备援到备份节点。</para>
<para>ActiveMQ的这一功能是通过主、备节点间的状态复制来实现的。当主节点发生故障崩溃时客户端的连接可以自动
转向备份节点以继续的发送或接收消息。当使用非事务性的会话时,有可能发生消息丢失或重复传递的情况。</para>
</section>
<section id="examples.paging">
<title>分页paging</title>
<para><literal>paging</literal>例子展示了ActiveMQ在内存有限时如何支持超大容量的队列。当内存不够时
ActiveMQ会将消息保存到磁盘上需要时再将它们从磁盘读入内存。这一过程对用户是透明的。</para>
</section>
<section id="examples.pre-acknowledge">
<title>预先通知</title>
<para>标准的JMS支持3种通知模式<literal>
AUTO_ACKNOWLEDGE</literal>(自动通知)、<literal>CLIENT_ACKNOWLEDGE</literal>客户通知以及 <literal
>DUPS_OK_ACKNOWLEDGE</literal>可重复通知。请参阅JMS规范和教程来进一步了解这几种通知方式。</para>
<para>所有方式都需要从客户端发通知到服务器端。有时当发生故障时你并不在乎丢失一些消息,这样可以采用在服务器端在消息
传递前进行通知就显得比较合理。本例就是展示如何使用这一ActiveMQ独有的通知方式。</para>
</section>
<section id="producer-rate-limiting-example">
<title>消息发送速度限制</title>
<para><literal>producer-rte-limit</literal>例子展示了如何设置ActiveMQ的最大消息发送速率。它控制消息的
发送者JMS producer发送消息的最大速度。</para>
</section>
<section>
<title>队列</title>
<para>这一个简单的JMS队列的例子。</para>
</section>
<section>
<title>Message再分配</title>
<para><literal>queue-message-redistribution</literal>例子展示了如何将消息在集群的各节点同名的队列
间进行再分配。</para>
</section>
<section>
<title>队列请求</title>
<para>这是一个简单的实现队列请求的例子。</para>
</section>
<section>
<title>带消息选择器selector的队列</title>
<para><literal>queue-selector</literal>例子展示了如何使用选择器来有条件地选择消息进行接收。</para>
</section>
<section>
<title>节点连接重试</title>
<para><literal>reattach-node</literal>例子展示了如何使客户端在发生故障时重试连接到原有服务器,而不是
直接放弃并通知用户的ExceptionListener。通过配置客户端可以自动的不断重试连接直到服务器连接上为止。</para>
</section>
<section>
<title>请求/应答</title>
<para>一个简单的展示JMS 请求/应答消息方式的例子。</para>
</section>
<section id="examples.scheduled-message">
<title>定时消息</title>
<para><literal>scheduled-message</literal>例子展示了如何向ActiveMQ发送定时消息scheduled message
所谓定时消息就是在规定的将来的某一时间传递的消息。</para>
</section>
<section>
<title>安全</title>
<para><literal>security</literal>例子展示了如何配置ActiveMQ的安全参数。</para>
</section>
<section id="asynchronous-send-acknowledgements-example">
<title>发送通知</title>
<para><literal>send-acknowledgements</literal>例子展示了如何使用ActiveMQ提供的高级异步发送通知功能
<emphasis>asynchronous send acknowledgements</emphasis>)。这是服务器向客户端通知消息已经
被接收。</para>
</section>
<section>
<title>SSL传输支持</title>
<para><literal>ssl-enabled</literal>例子展示了如何配置使用SSL来发送与接收消息。</para>
</section>
<section>
<title>静态消息选择器</title>
<para><literal>static-selector</literal>例子展示了如何配置ActiveMQ核心队列的静态消息选择器又称过滤器</para>
</section>
<section>
<title>使用JMS方法来配置静态消息选择器</title>
<para><literal>static-selector-jms</literal>例子采用JMS方法来配置ActiveMQ的队列的静态选择器过滤器</para>
</section>
<section>
<title>Stomp</title>
<para><literal>stomp</literal>例子展示了如何配置ActiveMQ来发送与接收Stomp消息。</para>
</section>
<section>
<title>Stomp与Web Sockets</title>
<para><literal>stomp-websockets</literal>例子给出了如何配置一个ActiveMQ服务器直接从Web浏览器
需要支持Web Socket发送和接收Stomp消息。</para>
</section>
<section>
<title>对称型集群</title>
<para><literal>symmetric-cluster</literal>例子展示如何设置一个ActiveMQ的对称型集群。</para>
<para>ActiveMQ的集群配置是非常灵活的。你可以根据需要设置不同的集群结构。最常用的就是对称型的集群了。这是在应用
服务器中常见的集群类型。</para>
<para>对称型的集群具有同一性,即每个节点与其他节点处于同等地位,并且每一个节点都与其他任一节点相连接。</para>
</section>
<section>
<title>临时队列</title>
<para>本例展示的是如何使用一个JMS临时队列temporary queue</para>
</section>
<section>
<title>话题Topic</title>
<para>一个简单的JMS topic的例子。</para>
</section>
<section id="topic-hierarchy-example">
<title>话题体系Topic Hierarchy</title>
<para>ActiveMQ支持话题体系。所谓话题体系就是允许你使用通配符来注册一个订阅subscriber),这样所有发送到
与该通配符相匹配的地址的消息都可以被该订阅收到。</para>
</section>
<section>
<title>话题选择器例1</title>
<para><literal>topic-selector-example1</literal>例子展示的是如何创建带有选择器的JMS话题Topic订阅。</para>
</section>
<section>
<title>话题选择器例2</title>
<para><literal>topic-selector-example2</literal> 是另一个使用带有选择器的JMS话题Topic订阅的例子。</para>
</section>
<section id="examples.transaction-failover">
<title>带有数据复制的事务性失效备援</title>
<para><literal>transaction-failover</literal>例子展示了由两个服务器组成的高可获得性主/备关系。
客户端使用一个交易的JMS会话session可以在主节点崩溃的情况下从主节点失效备援到备份节点。</para>
<para>ActiveMQ的这一功能是通过主、备节点间的状态复制来实现的。当主节点发生故障崩溃时客户端的连接可以自动
转向备份节点以继续的发送或接收消息。当使用事务性的会话时,能够保证消息被传递并且只被传递一次。</para>
</section>
<section>
<title>事务性会话</title>
<para><literal>transactional</literal>例子展示了如何在ActiveMQ中使用事务性会话。</para>
</section>
<section>
<title>XA Heuristic</title>
<para><literal>xa-heuristic</literal>例子给出了如何通过ActiveMQ的管理接口来做出一个XA的heuristic决定。
一个XA的heuristic决定是一个单方面的对一个已经准备的preparedXA事务分支提交或回滚的决定。</para>
</section>
<section>
<title>XA 接收</title>
<para><literal>xa-receive</literal>例子展示的是如何使用ActiveMQ在一个XA事务内接收消息。</para>
</section>
<section>
<title>XA 发送</title>
<para><literal>xa-send</literal>例子展示的是如何使用ActiveMQ在一个XA事务内发送消息。</para>
</section>
<section>
<title>XA与事务管理器transaction manager</title>
<para><literal>xa-with-jta</literal>展示了如何在ActiveMQ中使用JTA接口来控制事务。</para>
</section>
</section>
<section>
<title>核心API的例子</title>
<para>运行核心API的例子很简单只要进到相应的例子目录下运行“<literal>ant</literal>"即可。 </para>
<section id="examples.embedded">
<title>嵌入式</title>
<para>本例展示了如何将ActiveMQ服务器嵌入到你的代码中。</para>
</section>
</section>
<section>
<title>Java EE 例子</title>
<para>绝大多数的Java EE例子都可以按如下步骤运行进入到相应的目录中先运行<literal>ant deploy</literal>
这一步创建了一个新的JBoss的服务器配置方案并启动它。当JBoss服务器启动后再运行<literal>ant run</literal>
启动例子程序。有些例子需要额外的步骤,请参见相关的例子的文档。</para>
<section>
<title>EJB/JMS 事务</title>
<para>这个例子展示了在一个事务内使用EJB和JMS的方法。</para>
</section>
<section>
<title>HAJNDI (High Availability)</title>
<para>这个例子展示了如何使用集群中的JNDI服务。</para>
</section>
<section>
<title>资源适配器的配置JCA</title>
<para>本例展示了如何配置ActiveMQ的JCA适配器的各种参数。</para>
</section>
<section>
<title>资源适配器运程服务器的配置</title>
<para>本例展示了如何配置ActiveMQ的JCA适配器来与远程的ActiveMQ服务器通迅。</para>
</section>
<section id="examples.javaee.jms-bridge">
<title>JMS 桥Bridge</title>
<para>本例展示了如何使用ActiveMQ的JMS bridge。</para>
</section>
<section>
<title>MDB (消息驱动Bean)</title>
<para>一个消息驱动bean的例子。</para>
</section>
<section>
<title>Servlet传输</title>
<para>一个展示在ActiveMQ中使用servlet作为传输层的例子。</para>
</section>
<section>
<title>Servlet SSL 传输</title>
<para>一个展示在ActiveMQ中使用基于SSL之上的servlet传输的例子。</para>
</section>
<section id="xa-recovery-example">
<title>XA 恢复recovery</title>
<para>这是一个展示ActiveMQ在JBoss应用服务器中的XA recovery是如何工作的例子。</para>
</section>
</section>
</chapter>