我有Jetty hightide 8.1.8.v20121106正在运行并使用jquery / javascript部署了一个小型webapp来收听JMS主题,当收到消息时它会在页面上显示它。我有一个将连接到JMS主题并发布消息的Java应用程序,我希望Java应用程序发布的那些消息由Jetty上的webapp使用。
当javascript webapp发布消息或侦听消息时,Jetty未连接到tcp:// localhost:61616。日志显示Jetty始终连接到vm:// localhost。有没有办法让Jetty使用我的ActiveMQ服务器而不是自己的嵌入式服务器?感谢帮助。
下面的配置文件:
码头-plus.xml
<New id="cf" class="org.eclipse.jetty.plus.jndi.Resource">
<Arg>jms/connectionFactory</Arg>
<Arg>
<New class="org.apache.activemq.ActiveMQConnectionFactory">
<Arg>tcp://localhost:61616</Arg>
</New>
</Arg>
</New>
<New id="interestingTopic" class="org.eclipse.jetty.plus.jndi.Resource">
<Arg>jms/interestingTopic</Arg>
<Arg>
<New class="org.apache.activemq.command.ActiveMQTopic">
<Arg>my.test</Arg>
</New>
</Arg>
</New>
webapp的web.xml
<web-app>
<context-param>
<param-name>org.apache.activemq.brokerURL</param-name>
<param-value>tcp://localhost:61616</param-value>
<description>The URL of the Message Broker to connect to</description>
</context-param>
<context-param>
<param-name>org.apache.activemq.embeddedBroker</param-name>
<param-value>true</param-value>
<description>Whether we should include an embedded broker or not</description>
</context-param>
<filter>
<filter-name>session</filter-name>
<filter-class>org.apache.activemq.web.SessionFilter</filter-class>
<!-- <filter-class>org.eclipse.jetty.continuation.ContinuationFilter</filter-class> -->
</filter>
<filter-mapping>
<filter-name>session</filter-name>
<url-pattern>/*</url-pattern>
</filter-mapping>
<listener>
<listener-class>org.apache.activemq.web.SessionListener</listener-class>
</listener>
<servlet>
<servlet-name>AjaxServlet</servlet-name>
<servlet-class>org.apache.activemq.web.AjaxServlet</servlet-class>
<load-on-startup>1</load-on-startup>
</servlet>
<servlet>
<servlet-name>MessageServlet</servlet-name>
<servlet-class>org.apache.activemq.web.MessageServlet</servlet-class>
<load-on-startup>1</load-on-startup>
</servlet>
<servlet-mapping>
<servlet-name>AjaxServlet</servlet-name>
<url-pattern>/amq/*</url-pattern>
</servlet-mapping>
<servlet-mapping>
<servlet-name>MessageServlet</servlet-name>
<url-pattern>/message/*</url-pattern>
</servlet-mapping>
<!-- Default page to serve -->
<welcome-file-list>
<welcome-file>index.html</welcome-file>
</welcome-file-list>
<resource-env-ref>
<resource-env-ref-name>jms/interestingTopic</resource-env-ref-name>
<resource-env-ref-type>javax.jms.Topic</resource-env-ref-type>
</resource-env-ref>
<resource-ref>
<description>Connection Factory</description>
<res-ref-name>jms/connectionFactory</res-ref-name>
<res-type>javax.jms.ConnectionFactory</res-type>
<res-auth>Container</res-auth>
</resource-ref>
</web-app>
我的Java脚本代码,用于收听主题
window.onload = function() {
org.activemq.Amq.init({ uri: 'amq', logging: true, timeout: 45, clientId:('geo_1') });
};
var amq = org.activemq.Amq;
var msgTopic = 'topic://my.test';
var clientId = 'geo_1';
function addTopicListener() {
var myHandler = {
rcvMessage: function(message) {
//<message type="zmg">test test</message>
var type = message.getAttribute('type');
switch (type) {
case 'zmsg':
{
var text = message.childNodes[0].data;
document.getElementById('zmsg_container').innerHTML += ' | '+text;
break;
}
}
}
};
amq.addListener('myHandler', msgTopic, myHandler.rcvMessage);
};
function delTopicListener() {
amq.removeListener('myHandler', msgTopic);
}
最后我的Java应用程序中的代码用于发布
private void init() throws NamingException {
Properties props = new Properties();
props.setProperty(Context.INITIAL_CONTEXT_FACTORY,"org.apache.activemq.jndi.ActiveMQInitialContextFactory");
props.setProperty(Context.PROVIDER_URL,"tcp://localhost:61616");
props.setProperty("topic.test", "my.test");
ctx = new InitialContext(props);
System.out.println("JMS Context Initialized");
}
private void connect() throws NamingException, JMSException {
connectionFactory = (TopicConnectionFactory)ctx.lookup("ConnectionFactory");
conn = connectionFactory.createTopicConnection();
myTopic = (Topic)ctx.lookup("test");
session = conn.createTopicSession(false, TopicSession.AUTO_ACKNOWLEDGE);
publisher = session.createPublisher(myTopic);
System.out.println("JMS Connection started");
}
答案 0 :(得分:1)
从字面上搜索互联网并浏览许多有关配置Jetty和ActiveMQ的网站;我终于遇到了一个网站,该网站讨论了使用activemq聚类jetty并让jetty使用activemq(http://java.dzone.com/articles/activemq-configuring-multiple)的web控制台。该网站确实有所帮助。
所以我在Jetty中错过了额外的XML配置部分。使用上面的XML配置,我必须附加以下内容:
<New id="url" class="org.eclipse.jetty.plus.jndi.Resource">
<Arg>jmx/url</Arg>
<Arg>
<New class="java.lang.String">
<Arg>service:jmx:rmi:///jndi/rmi://localhost:1099/jmxrmi,service:jmx:rmi:///jndi/rmi://localhost:1299/jmxrmi</Arg>
</New>
</Arg>
</New>
之后我开始使用Jetty和ActiveMQ,确实有足够的jetty连接到ActiveMQ而没有像以前那样创建自己的vm:// localhost连接。
感谢那些帮助过的人,让我专注于我的问题。
答案 1 :(得分:0)
你的java代码中的这一行将导致在本地VM中创建一个ActiveMQ代理实例(这是一把双刃剑......):
props.setProperty(Context.PROVIDER_URL,"vm://localhost?broker.persistent=false");
如果您在 myamqhost 上运行了另一个ActiveMQ代理,则将该行修改为类似的内容(假设代理正在侦听端口61616):
props.setProperty(Context.PROVIDER_URL,"tcp://myamqhost:61616");
您可能还想查看ActiveMQ Ajax Client。