java怎么连接activemq集群_java怎么连接并访问activemq

1、下载安装ActiveMQ

下载可以去官网下载:http://activemq.apache.org/download.html。我们这里使用windows测试,所以下载windows版本即可。

2、启动ActiveMQ

下载zip文件后直接解压,解压后我们比较关注的是bin和conf目录。

bin存放的是脚本文件

conf存放的是基本配置文件

data存放的是日志文件

docs存放的是说明文档

examples存放的是简单的实例

lib存放的是activemq所需jar包

webapps用于存放项目的目录

启动ActiveMQ非常的简单。进入bin目录

双击“activemq.bat”就启动运行了。因为ActiveMQ是用Java编写的,所以必须确保电脑已经安装了JDK。

双击运行之后就可以在浏览器里面输入:http://localhost:8161/admin。就能够进入ActiveMQ的后台页面了。帐号密码默认都是:admin

Java程序连接端口:61616

修改61616端口,可以修改文件conf>activemq.xml

修改登录名和密码,可以修改文件conf>jetty-realm.properties

3、创建一个ActiveMQ工程

这里还是先放一张图:

ad8ae04d4ad4a7df6b3196e571711f0c.png

根据这张图我们实现了一个队列Queue的代码如下

1.pom.xml

org.apache.activemq

activemq-core

5.7.0

2.消费者代码

package cn.duanjt;

import java.io.IOException;

import javax.jms.Connection;

import javax.jms.ConnectionFactory;

import javax.jms.JMSException;

import javax.jms.Message;

import javax.jms.MessageConsumer;

import javax.jms.MessageListener;

import javax.jms.Queue;

import javax.jms.Session;

import javax.jms.TextMessage;

import org.apache.activemq.ActiveMQConnection;

import org.apache.activemq.ActiveMQConnectionFactory;

import org.apache.activemq.ActiveMQSession;

/**

* 消费者

* @author 段江涛

* @date 2018-11-23

*/

public class Consumer {

// 全部使用缺省值

private static String USERNAME = ActiveMQConnection.DEFAULT_USER;

private static String PASSWORD = ActiveMQConnection.DEFAULT_PASSWORD;

private static String BROKER = ActiveMQConnection.DEFAULT_BROKER_URL;

public static void main(String[] args) throws IOException {

ConnectionFactory factory;

Connection connection = null;

Session session;

Queue queue;

Message message;

MessageConsumer consumer;

try {

factory = new ActiveMQConnectionFactory(USERNAME, PASSWORD, BROKER);

connection = factory.createConnection();

connection.start();

session = connection.createSession(false, ActiveMQSession.AUTO_ACKNOWLEDGE);

queue = session.createQueue("zd-duanjt");

consumer = session.createConsumer(queue);

//注释部分为同步方式

/*while (true) {

message = consumer.receive();

TextMessage tmsg = (TextMessage) message;

System.out.println("接收到数据:" + tmsg.getText());

}*/

//下面是异步方式,通过注册监听

consumer.setMessageListener(new MessageListener() {

@Override

public void onMessage(Message message) {

TextMessage tmsg = (TextMessage) message;

try {

System.out.println("接收到数据:" + tmsg.getText());

} catch (JMSException e) {

// TODO Auto-generated catch block

e.printStackTrace();

}

}

});

} catch (Exception e) {

e.printStackTrace();

} finally{

// 之前在这里把连接关闭了,导致一直无法消费数据,注意,这里千万不要关闭连接

}

}

}

3.生产者代码

package cn.duanjt;

import javax.jms.Connection;

import javax.jms.ConnectionFactory;

import javax.jms.JMSException;

import javax.jms.Message;

import javax.jms.MessageProducer;

import javax.jms.Queue;

import javax.jms.Session;

import org.apache.activemq.ActiveMQConnection;

import org.apache.activemq.ActiveMQConnectionFactory;

import org.apache.activemq.ActiveMQSession;

/**

* 生产者产生数据

* @author 段江涛

* @date 2018-11-23

*/

public class Productor {

// 全部使用缺省值

private static String USERNAME = ActiveMQConnection.DEFAULT_USER;

private static String PASSWORD = ActiveMQConnection.DEFAULT_PASSWORD;

private static String BROKER = ActiveMQConnection.DEFAULT_BROKER_URL;

public static void main(String[] args) throws JMSException {

ConnectionFactory factory = new ActiveMQConnectionFactory(USERNAME, PASSWORD, BROKER);

Connection connection = factory.createConnection();

connection.start();

Session session = connection.createSession(false, ActiveMQSession.AUTO_ACKNOWLEDGE);

Queue queue = session.createQueue("zd-duanjt");

MessageProducer productor = session.createProducer(queue);

for (int i = 0; i < 3; i++) {

String msg = "Hello world:" + i;

Message message = session.createTextMessage(msg);

productor.send(message);

System.out.println("发送数据:" + msg);

}

connection.close();

}

}

重点说明:

1.Queue queue = session.createQueue("zd-duanjt");表示创建一个队列,我们也可以创建一个Topic,Topic topic=session.createTopic("zd-topic");

2.注意这里面的JMS相关的类都在包javax.jms.*下

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持聚米学院。

  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
好的,您想了解关于ActiveMQ集群Java实现方案,是吗?那我可以给您一些简单的介绍和建议。 首先,ActiveMQ是一个流行的开源消息中间件,它支持多种协议和消息格式,可以在分布式环境下运行。要实现ActiveMQ集群,有不同的方案和配置可以选择,这里提供一个简单的示例。 在Java中,可以使用ActiveMQJava客户端库来连接和发送消息到ActiveMQ Broker,也可以使用Spring Framework提供的ActiveMQ支持来实现更方便的集成和配置。 以下是一个基本的ActiveMQ集群配置示例: 1. 首先,在每个机器上安装ActiveMQ Broker,并确保它们都在同一个网络中,并且可以相互访问。 2. 在每个机器上,创建一个ActiveMQ Broker实例。可以使用命令行或XML配置文件进行配置。例如,使用XML配置文件,可以指定Broker的名称、IP地址、端口等参数。 3. 启动每个Broker实例,并确保它们都处于运行状态。可以使用命令行或Java代码启动。 4. 配置Broker之间的网络连接。可以使用静态或动态发现方式进行。静态发现需要手动配置每个Broker的网络连接信息,而动态发现可以使用ActiveMQ提供的多种发现方式,如多播、JMX等。例如,可以在每个Broker的XML配置文件中指定其他Broker的网络地址。 5. 创建一个ActiveMQ连接工厂并配置为使用负载均衡模式。可以使用Spring Framework提供的ActiveMQConnectionFactory或自己实现。例如,可以使用RoundRobin方式轮流连接不同的Broker实例。 6. 使用ActiveMQ连接工厂创建一个JMS连接,并从中创建一个JMS会话。可以使用Spring Framework提供的JmsTemplate或自己实现。例如,可以使用JmsTemplate发送和接收JMS消息。 7. 测试集群功能。可以尝试在不同的Broker实例上发送和接收消息,并检查它们是否能够正确地被路由和处理。 以上是一个简单的ActiveMQ集群配置示例,仅供参考。实际上,根据不同的需求和场景,可能需要更复杂的配置和实现方式。建议在实际应用中,根据具体情况选择最适合的方案。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值