永続的な組み込みブローカーを持つ同じマシンで、この 1 つのサービスの複数のインスタンス (個別の JVM) を開始する必要があります。すべての構成ファイルは事前に生成されており、サービスが開始される前にコンパイル時に変数置換が行われます。AMQ データ ディレクトリと KahaDB のロックを取得しようとしているいくつかのインスタンスで問題が発生しています。明らかに、最初のインスタンスはロックを正常に取得し、残りのインスタンスは失敗し続けています。
次のように設定する必要があります。
. . .
<amq:broker dataDirectory="${activemq.directory}/data" id="broker" persistent="true" useJmx="false" >
. . .
PropertyPlaceholderConfigurer を試してみましたが、理解したとおり、Spring 構成で指定されたファイルからプロパティをロードし、起動時にはすでに遅すぎます。Spring Expression Language を使用しようとしているので、最終的には次のようになります。
<?xml version="1.0" encoding="UTF-8"?>
<beans xmlns="http://www.springframework.org/schema/beans"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xmlns:p="http://www.springframework.org/schema/p"
xmlns:context="http://www.springframework.org/schema/context"
xmlns:jms="http://www.springframework.org/schema/jms"
xmlns:amq="http://activemq.apache.org/schema/core"
xsi:schemaLocation="http://www.springframework.org/schema/beans
http://www.springframework.org/schema/beans/spring-beans.xsd
http://www.springframework.org/schema/context
http://www.springframework.org/schema/beans/spring-beans-3.0.xsd
http://www.springframework.org/schema/jms
http://www.springframework.org/schema/jms/spring-jms-3.0.xsd
http://activemq.apache.org/schema/core
http://activemq.apache.org/schema/core/activemq-core-5.5.0.xsd">
<!-- Embedded ActiveMQ Broker -->
<amq:broker dataDirectory="#{systemProperties['activemq.directory']}/data" id="broker" persistent="true" useJmx="false" >
...
コマンドラインで渡します
-Dactivemq.directory=<my-directory>
私が見るログで
nested exception is org.springframework.beans.factory.NoSuchBeanDefinitionException: No bean named '{systemProperties['activemq.directory']}/data' is defined
AMQ と Spring3 SpEL で何か不足しているように見えますか? 私が行方不明かもしれないと同じ考えをする他の解決策はありますか?