1.4. 修改代理配置文件
如果您有多个共享通用配置设置的代理,您可以在单独的文件中定义通用配置,然后将这些文件包括在每个代理的 broker.xml
配置文件中。
您可以在代理间共享的最常见配置设置包括:
- 地址
- 地址设置
- 安全设置
流程
为您想共享的每个
broker.xml
部分创建单独的 XML 文件。每个 XML 文件只能包含来自
broker.xml
的单个部分(例如,地址或地址设置,但不能同时包含两者)。顶级元素还必须定义 element 命名空间(xmlns="urn:activemq:core"
)。本例演示了
my-security-settings.xml
中定义的安全设置配置:my-security-settings.xml
<security-settings xmlns="urn:activemq:core"> <security-setting match="a1"> <permission type="createNonDurableQueue" roles="a1.1"/> </security-setting> <security-setting match="a2"> <permission type="deleteNonDurableQueue" roles="a2.1"/> </security-setting> </security-settings>
-
为每个应使用通用配置设置的代理打开 &
lt;broker_instance_dir> /etc/broker.xml
配置文件。 对于您打开的每个
broker.xml
文件,请执行以下操作:在
broker.xml
开头的 <configuration
> 元素中验证是否显示以下行:xmlns:xi="http://www.w3.org/2001/XInclude"
为每个包含共享配置设置的 XML 文件添加 XML。
这个示例包括
my-security-settings.xml
文件。broker.xml
<configuration ...> <core ...> ... <xi:include href="/opt/my-broker-config/my-security-settings.xml"/> ... </core> </configuration>
如果需要,验证
broker.xml
,以验证 XML 是否对 schema 有效。您可以使用任何 XML 验证程序。这个示例使用
xmllint
对artemis-server.xsl
模式验证broker.xml
。$ xmllint --noout --xinclude --schema /opt/redhat/amq-broker/amq-broker-7.2.0/schema/artemis-server.xsd /var/opt/amq-broker/mybroker/etc/broker.xml /var/opt/amq-broker/mybroker/etc/broker.xml validates
其他资源
- 有关 XML 包含(XIncludes)的详情,请参考 https://www.w3.org/TR/xinclude/。
1.4.1. 重新加载模块配置文件
当代理定期检查配置更改(根据 config-file-refresh-period
指定的频率),它不会自动检测通过 xi:include
在 broker.xml
配置文件中包含的配置文件的变化。例如,如果 broker.xml
包含 my-address-settings.xml
,并且您对 my-address-settings.xml
进行配置更改,则代理不会自动检测 my-address-settings.xml
中的更改并重新载入配置。
要强制 重新加载 broker.xml
配置文件以及其中包含的任何修改的配置文件,您必须确保 broker.xml
配置文件的"last modified"时间戳已改变。您可以使用标准 Linux touch
命令更新 broker.xml
的最后修改时间戳,而无需进行任何更改。例如:
$ touch -m <broker_instance_dir>/etc/broker.xml
或者您可以使用管理 API 来强制重新加载代理。可以使用 ActiveMQServerControl
上的管理操作 reloadConfigurationFile()
来重新加载配置文件(使用 ObjectName
org.apache.activemq.artemis:broker="BROKER_NAME"
或 resource name server
)
其他资源
- 要了解如何使用管理 API,请参阅在管理 AMQ Broker 中使用 Management API