7

インターネットをいろいろいじった結果、ActiveMQ (Artemis) を備えた WildFly 10 で JMS を使用してリモート メッセージ キューにプッシュするためのサンプル構成が見つからないことに驚きました。さらに悪いことstandalone-full.xmlに、スキーマに縛られていないので (なぜ???)、最終的に GitHubでその XSD を見つけたとき、各ノード/属性が何を意味し、どの値を何に入れることができるかを示すドキュメントは含まれていません。

以下は、standalone-full.xml からの元の構成です。

    <subsystem xmlns="urn:jboss:domain:messaging-activemq:1.0">
      <server name="default">
        <security-setting name="#">
          <role name="guest" delete-non-durable-queue="true" create-non-durable-queue="true" consume="true" send="true"/>
        </security-setting>
        <address-setting name="#" message-counter-history-day-limit="10" page-size-bytes="2097152" max-size-bytes="10485760" expiry-address="jms.queue.ExpiryQueue" dead-letter-address="jms.queue.DLQ"/>
        <http-connector name="http-connector" endpoint="http-acceptor" socket-binding="http"/>
        <http-connector name="http-connector-throughput" endpoint="http-acceptor-throughput" socket-binding="http">
          <param name="batch-delay" value="50"/>
        </http-connector>
        <in-vm-connector name="in-vm" server-id="0"/>
        <http-acceptor name="http-acceptor" http-listener="default"/>
        <http-acceptor name="http-acceptor-throughput" http-listener="default">
          <param name="batch-delay" value="50"/>
          <param name="direct-deliver" value="false"/>
        </http-acceptor>
        <in-vm-acceptor name="in-vm" server-id="0"/>
        <jms-queue name="ExpiryQueue" entries="java:/jms/queue/ExpiryQueue"/>
        <jms-queue name="DLQ" entries="java:/jms/queue/DLQ"/>
        <connection-factory name="InVmConnectionFactory" entries="java:/ConnectionFactory" connectors="in-vm"/>
        <connection-factory name="RemoteConnectionFactory" entries="java:jboss/exported/jms/RemoteConnectionFactory" connectors="http-connector"/>
        <pooled-connection-factory name="activemq-ra" transaction="xa" entries="java:/JmsXA java:jboss/DefaultJMSConnectionFactory" connectors="in-vm"/>
      </server>
    </subsystem>

以下は、WildFly のローカル Artemis インスタンスにメッセージを投稿できる CDI キュー クライアントです。

@ApplicationScoped
public class QueueClient {

  private static final Gson GSON = new Gson();

  @Resource(mappedName = "java:jboss/DefaultJMSConnectionFactory")
  private ConnectionFactory connectionFactory;

  public void sendMessage(String destinationName, Object message) throws JMSException {
    try (Connection conn = connectionFactory.createConnection();
        Session session = conn.createSession(false, Session.AUTO_ACKNOWLEDGE)) {

      Queue queue = session.createQueue(destinationName);
      final Message consignment = session.createMessage();
      consignment.setStringProperty("MEDIA_TYPE", "application/json");
      consignment.setStringProperty("BODY", GSON.toJson(message));
      session.createProducer(queue).send(consignment);
    }
  }
}

私の目標:リモートのActiveMQ インスタンスにメッセージを投稿します。

私が持っているもの: server urltopic nameusernameおよびpassword

私の質問:この目標を達成するために構成を変更するにはどうすればよいですか?

別の質問: 上記の質問に答えられない場合、他にどのようにすればこの目標を達成できますか?

ありがとう!

4

2 に答える 2

0

私は今週、非常によく似た問題に苦しんでいます。私のアーキテクチャのため、役に立つと思われる別のアプローチを選択しました。

ローカルの Artemis Broker へのメッセージの送信を続行しますが、Artemis Broker とリモートの ActiveMQ Broker の間に JMS ブリッジを構成します。

このアプローチはまだ頭の痛い問題を引き起こしましたが、最終的にはうまく機能するようになりました. 詳細:

WildFly 10 Artemis と ActiveMQ 5.14 間の JMS ブリッジ (ONCE_AND_ONLY_ONCE サービス品質)

于 2016-09-15T12:03:58.697 に答える