activemq-artemis/docs/user-manual/zh/using-server.xml

313 lines
20 KiB
XML
Raw Blame History

This file contains invisible Unicode characters

This file contains invisible Unicode characters that are indistinguishable to humans but may be processed differently by a computer. If you think that this is intentional, you can safely ignore this warning. Use the Escape button to reveal them.

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="using-server">
<title>使用HornetQ服务</title>
<para>本章将介绍如何使用HornetQ服务。</para>
<para>其中的内容包括服务器的位置如何启动和停止HornetQ服务器。本章还将解释HornetQ的目录结构其中的文件及其用途。</para>
<para>本章中所提到的HornetQ服务器是指HornetQ默认配置的独立服务器包含JMS服务和JNDI服务。</para>
<para>对于运行于JBoss应用服务器中的HornetQ其基本结构是一样的只是有一些小的差别。</para>
<section>
<title>服务的启动和停止</title>
<para>在HornetQ的安装目录下<literal>bin</literal>子目录中包含有一个unit/linux脚本run.sh和对应的Windows批处理文件run.bat。</para>
<para>如果你是在Unix/Linux环境在bin目录下运行<literal>./run.sh</literal></para>
<para>如果是在Windows环境则在bin目录下运行 <literal>run.bat</literal></para>
<para>这个脚本文件会设置classpath以及各种JVM参数并启动JBoss Microcontainer。JBoss Microcontainer是一个轻量级的容器。
它被用来部署HornetQ的POJO对象。</para>
<para>要停止服务运行其中的相应脚本在Unix/Linux环境下运行 <literal>stop.sh</literal>
在Windows环境运行 <literal>run.bat</literal></para>
<para>注意HornetQ需要在Java 6及以上版本才能正常运行。</para>
<para>启动和停止脚本在默认条件下读取<literal>config/stand-alone/non-clustered</literal>目录下的配置文件。
如果要指向其他目录,可以在命令行实现,例如: <literal>./run.sh ../config/stand-alone/clustered</literal>
这一方法同样适用于Windows批处理文件。</para>
</section>
<section>
<title>服务器端JVM参数的设置</title>
<para>在启动脚本<literal>run.sh</literal><literal>run.bat</literal>中设置了一些JVM参数
这些参数主要是调整Java 6的运行环境及拉圾回收的策略。我们建议采用并行拉圾回收的方法。
这种方法可以将拉圾回收所造成的延时进行平均分配,有效减少由于拉圾回收引起的长时间暂停的情况。</para>
<para>默认条件下HornetQ需要最大1GB的内存空间。通过<literal>-Xms</literal><literal>-Xmx</literal>可以调整Java程序内存的使用。</para>
<para>你可以向启动脚本中添加其它的参数或修改已有的参数,已满足你的需要。</para>
</section>
<section>
<title>服务器端的classpath</title>
<para>HornetQ在其classpath中寻找配置文件。</para>
<para>classpath被定义在<literal>run.sh</literal><literal>run.bat</literal>脚本中。在HornetQ的发布中启动脚本将非集群的配置文件目录加进了classpath中。该目录包括了一组配置文件可以让HornetQ以基本的非集群方式运行。它的具体位置是在HornetQ发布根目录下 config/stand-along/non-clustered/ 子目录。</para>
<para>在HornetQ的发布包中包括了一组标准的配置目录它们是</para>
<itemizedlist>
<listitem>
<para>非集群方式的独立服务器配置</para>
</listitem>
<listitem>
<para>集群方式的独立服务器配置</para>
</listitem>
<listitem>
<para>非集群方式运行于JBoss应用服务器</para>
</listitem>
<listitem>
<para>集群方式运行于JBoss应用服务器</para>
</listitem>
</itemizedlist>
<para>当然你可以创建自己定义的配置文件目录。要注意的是将你的目录加到classpath中以便HornetQ能正确找到并加载。</para>
</section>
<section id="using-server.library.path">
<title>Library Path</title>
<para>如果要在Linux上使用异步IO的日志<link linkend="aio-journal">Asynchronous IO Journal</link>
你需要在java选项中指定<literal>java.library.path</literal><literal>run.sh</literal>脚本可以自动完成这一步。</para>
<para>如果没有指定<literal>java.library.path</literal>JVM将使用<literal>LD_LIBRARY_PATH</literal>环境变量。</para>
</section>
<section>
<title>系统变量</title>
<para>HornetQ命令行可以接受系统变量来配置日志logging。有关logging配置的具体信息参见<xref linkend="logging"/></para>
</section>
<section id="using-server.configuration">
<title>配置文件</title>
<para>配置文件的路径定义在 <literal>run.sh</literal><literal>run.bat</literal> 脚本中的classpath里。该路径下可以包含以下文件</para>
<itemizedlist>
<listitem>
<para><literal>hornetq-beans.xml</literal> 如果是运行在JBoss应用服务器内则为 <literal
>hornetq-jboss-beans.xml</literal>。这是JBoss Microcontainer的bean配置文件。其中定义了HornetQ的
各种bean以及它们之间的依赖关系。HornetQ的bean都是一些POJO。是JBoss Microcontainer保证了这些bean的正确装载和运行。</para>
</listitem>
<listitem>
<para><literal>hornetq-configuration.xml</literal>。这个是HornetQ的主要的配置文件。
其中的所有参数在<xref linkend="configuration-index"/>中给出了解释. 在 <xref
linkend="usingserver.mainconfig"/> 也有更多的相关信息。</para>
</listitem>
<listitem>
<para><literal>hornetq-queues.xml</literal>。这个文件里包含了预定义的queue以及它们的配置包括安全设置。
这是一个可选的文件,里面所有的内容都可以放在 <literal>hornetq-configuration.xml</literal>文件中。
在默认的配置文件目录下并没有这个文件。HornetQ之所以提供这个文件是为了用户便于管理他们的queue。在classpath中
允许包含多个 <literal>hornetq-queues.xml</literal> 文件。所有的这些文件都会被加载。</para>
</listitem>
<listitem>
<para><literal>hornetq-users.xml</literal>。用户信息文件。HornetQ本身实现了一个基本的
安全管理器security manager它从这个文件内读取用户的安全信息如用户名密码和角色。
想了解更多关于安全的信息,参见 <xref linkend="security"/></para>
</listitem>
<listitem>
<para><literal>hornetq-jms.xml</literal>。这个文件包含有JMS对象。HornetQ的默认配置中包含有JMS服务
它从这个文件中读取JMS QueueTopic和ConnectionFactory并将它们部署到JNDI服务中。如果你不使用JMS
或者你不需要部署这些JMS对象那么你就不需要这个文件。有关JMS的使用详见<xref linkend="using-jms"
/></para>
</listitem>
<listitem>
<para><literal>logging.properties</literal> 这个文件用于配置logging
handlers。详见 <xref linkend="logging"/></para>
</listitem>
<listitem>
<para><literal>log4j.xml</literal>。 这是 Log4j handler的配置文件。</para>
</listitem>
</itemizedlist>
<note>
<para>如果在<literal>hornetq-configuration.xml</literal>文件中将<literal>file-deployment-enabled</literal> 参数
定义为false则HornetQ将不会加载其它的配置文件。这个参数的默认值是true。</para>
</note>
<para>所有配置文件中的参数都可以用系统变量来定义其值。以下用一个connector的配置来说明</para>
<programlisting>&lt;connector name="netty">
&lt;factory-class>org.apache.activemq.integration.transports.netty.NettyConnectorFactory
&lt;/factory-class>
&lt;param key="host" value="${hornetq.remoting.netty.host:localhost}" type="String"/>
&lt;param key="port" value="${hornetq.remoting.netty.port:5445}" type="Integer"/>
&lt;/connector></programlisting>
<para>在上面的配置中我们定义了两个系统变量 <literal
>hornetq.remoting.netty.host</literal><literal
>hornetq.remoting.netty.port</literal>。它们的值会被相应的系统变量的值(如果定义了的话)所替代。
如果没有定义这些系统变量,它们的默认值将分别为 localhost 及 5445。也可以不给出默认值但如果这样就
<emphasis>必须</emphasis>要定义相应的系统变量。</para>
</section>
<section id="server.microcontainer.configuration">
<title>JBoss Microcontainer Beans 文件</title>
<para>HornetQ的POJO对象是由<ulink url="http://www.jboss.org/jbossmc/"> JBoss Microcontainer
</ulink>进行加载和运行的。JBoss Microcontainer是一个轻量级的加载工具。</para>
<note>
<para>如果是在JBoss应用服务器内运行HornetQ同样需要一个bean的配置文件来将其部署到JBoss中。但是这与单独运行时的配置文件略有不同。
这是因为应用服务器内已经部署了一些服务如安全服务等。所以在HornetQ中这些服务就不需要再部署了。</para>
</note>
<para>让我们看一个HornetQ作为单独服务器时的一个配置文件例子</para>
<para>
<programlisting>&lt;?xml version="1.0" encoding="UTF-8"?&gt;
&lt;deployment xmlns="urn:jboss:bean-deployer:2.0"&gt;
&lt;bean name="Naming" class="org.jnp.server.NamingBeanImpl"/&gt;
&lt;!-- JNDI server. Disable this if you don't want JNDI --&gt;
&lt;bean name="JNDIServer" class="org.jnp.server.Main"&gt;
&lt;property name="namingInfo"&gt;
&lt;inject bean="Naming"/&gt;
&lt;/property&gt;
&lt;property name="port"&gt;1099&lt;/property&gt;
&lt;property name="bindAddress"&gt;localhost&lt;/property&gt;
&lt;property name="rmiPort"&gt;1098&lt;/property&gt;
&lt;property name="rmiBindAddress"&gt;localhost&lt;/property&gt;
&lt;/bean&gt;
&lt;!-- MBean server --&gt;
&lt;bean name="MBeanServer" class="javax.management.MBeanServer"&gt;
&lt;constructor factoryClass="java.lang.management.ManagementFactory"
factoryMethod="getPlatformMBeanServer"/&gt;
&lt;/bean&gt;
&lt;!-- The core configuration --&gt;
&lt;bean name="Configuration" class="org.apache.activemq.core.config.impl.FileConfiguration"&gt;
&lt;/bean&gt;
&lt;!-- The security manager --&gt;
&lt;bean name="HornetQSecurityManager"
class="org.apache.activemq.spi.core.security.HornetQSecurityManagerImpl"&gt;
&lt;start ignored="true"/&gt;
&lt;stop ignored="true"/&gt;
&lt;/bean&gt;
&lt;!-- The core server --&gt;
&lt;bean name="HornetQServer" class="org.apache.activemq.core.server.impl.HornetQServerImpl"&gt;
&lt;start ignored="true"/&gt;
&lt;stop ignored="true"/&gt;
&lt;constructor&gt;
&lt;parameter&gt;
&lt;inject bean="Configuration"/&gt;
&lt;/parameter&gt;
&lt;parameter&gt;
&lt;inject bean="MBeanServer"/&gt;
&lt;/parameter&gt;
&lt;parameter&gt;
&lt;inject bean="HornetQSecurityManager"/&gt;
&lt;/parameter&gt;
&lt;/constructor&gt;
&lt;/bean&gt;
&lt;!-- The JMS server --&gt;
&lt;bean name="JMSServerManager"
class="org.apache.activemq.jms.server.impl.JMSServerManagerImpl"&gt;
&lt;constructor&gt;
&lt;parameter&gt;
&lt;inject bean="HornetQServer"/&gt;
&lt;/parameter&gt;
&lt;/constructor&gt;
&lt;/bean&gt;
&lt;/deployment&gt;</programlisting>
</para>
<para>我们从上可以看出HornetQ的单独服务器以及核心服务器包括了一些POJO对象</para>
<itemizedlist>
<listitem>
<para>JNDIServer</para>
<para>很多客户端需要JNDI来获取JMS的对象因此我们提供了一个JNDI服务来满足它们。如果不需要JNDI可以在配置
文件中将它们注释掉。</para>
</listitem>
<listitem>
<para>MBeanServer</para>
<para>这个对象提供了JMX管理接口。它是一个MBean服务器可管理的对象可以注册到这个服务器上。
通常这就是一个JVM内部的默认的平台MBean服务器。如果不需要些服务可以在配置文件中将其注释或删除。</para>
</listitem>
<listitem>
<para>Configuration</para>
<para>这是HornetQ的Configuration对象。默认时它是一个FileConfiguration对象。它可以从文件系统中读取
配置信息。有些情况下如嵌入式HornetQ你可以将它定义为其它对象以便用其它方法获得配置信息。</para>
</listitem>
<listitem>
<para>Security Manager. 可配置的安全管理器。默认的安全管理器使用 <literal>hornetq-users.xml</literal> 文件中的配置信息。
它也可以配置为一个JAAS的安全管理器。当HornetQ运行于JBoss应用服务器中时它还可以配置为JBoss的安全管理器以达到更紧密的集成。
如果不需要安全管理,你也可以将它删除。</para>
</listitem>
<listitem>
<para>HornetQServer</para>
<para>这是HornetQ的核心服务对象几乎所有的核心功能都在这里。</para>
</listitem>
<listitem id="bean-jmsservermanager">
<para>JMSServerManager</para>
<para>这个对象将<literal>hornetq-jms.xml</literal>文件中定义的JMS的对象进行部署比如JMS Queues, Topics
以及ConnectionFactory。它还提供一套简单的管理接口以方便地对这些JMS对象进行管理。通常它只是将工作代理给
核心服务器。如果你不需要在服务器端进行JMS对象的部署与管理可以将它从配置中去掉。</para>
</listitem>
</itemizedlist>
</section>
<section id="server.microkernel.configuration">
<title>JBoss AS4 MBean 服务</title>
<note>
<para>本节只讨论在JBoss AS 4上配置HornetQ。其与JBoss Microcontainer的配置很相似。</para>
</note>
<para>
<programlisting>&lt;?xml version="1.0" encoding="UTF-8"?&gt;
&lt;server&gt;
&lt;mbean code="org.apache.activemq.service.HornetQFileConfigurationService"
name="org.apache.activemq:service=HornetQFileConfigurationService"&gt;
&lt;/mbean&gt;
&lt;mbean code="org.apache.activemq.service.JBossASSecurityManagerService"
name="org.apache.activemq:service=JBossASSecurityManagerService"&gt;
&lt;/mbean&gt;
&lt;mbean code="org.apache.activemq.service.HornetQStarterService"
name="org.apache.activemq:service=HornetQStarterService"&gt;
&lt;!--let's let the JMS Server start us--&gt;
&lt;attribute name="Start"&gt;false&lt;/attribute&gt;
&lt;depends optional-attribute-name="SecurityManagerService"
proxy-type="attribute"&gt;org.apache.activemq:service=JBossASSecurityManagerService&lt;/depends&gt;
&lt;depends optional-attribute-name="ConfigurationService"
proxy-type="attribute"&gt;org.apache.activemq:service=HornetQFileConfigurationService&lt;/depends&gt;
&lt;/mbean&gt;
&lt;mbean code="org.apache.activemq.service.HornetQJMSStarterService"
name="org.apache.activemq:service=HornetQJMSStarterService"&gt;
&lt;depends optional-attribute-name="HornetQServer"
proxy-type="attribute"&gt;org.apache.activemq:service=HornetQStarterService&lt;/depends&gt;
&lt;/mbean&gt;
&lt;/server&gt;
</programlisting>
</para>
<para>这个jboss-service.xml包含在hornetq-service.sar文件中它用来配置AS4中嵌入运行的HornetQ。
在这个配置文件中我们启动了以下几个服务:</para>
<itemizedlist>
<listitem>
<para>HornetQFileConfigurationService</para>
<para>这个MBean服务的任务是管理 <literal>FileConfiguration POJO</literal>的生命周期。</para>
</listitem>
<listitem>
<para>JBossASSecurityManagerService</para>
<para>这个MBean服务管理着 <literal>JBossASSecurityManager</literal> POJO的生命周期。</para>
</listitem>
<listitem>
<para>HornetQStarterService</para>
<para>这个MBean服务管理着<literal>HornetQServer</literal> POJO。它依赖于 JBossASSecurityManagerService 和
HornetQFileConfigurationService 这两个MBean。</para>
</listitem>
<listitem>
<para>HornetQJMSStarterService</para>
<para>这个MBean服务管理着 <literal>JMSServerManagerImpl</literal> POJO对象。如果不需要JMS可以去掉这个服务。</para>
</listitem>
<listitem>
<para>JMSServerManager</para>
<para>用于启动JMSServerManager。</para>
</listitem>
</itemizedlist>
</section>
<section id="usingserver.mainconfig">
<title>主配置文件</title>
<para>HornetQ 核心服务的配置保存在 <literal>hornetq-configuration.xml</literal>文件中。
         FileConfiguration bean 读取这个文件来对消息服务器进行配置。</para>
<para>HornetQ有很多的配置参数。采用默认的配置在绝大多数情况下可以很好的运行。事实上每一个参数都有默认的处理因此一个只包含有一个空
<literal>configuration</literal>的配置文件是一个有效的文件。对各个参数的解释贯穿于本手册。你还可参参照
<link linkend="configuration-index">这里</link>来查找你想看的参数。</para>
</section>
</chapter>