消息中间件学习笔记--ActiveMQ(二、队列模式)

import javax.swing.JOptionPane;

import cn.hutool.core.util.NetUtil;

public class ActiveMQUtil {

public static void checkServer() {

if(NetUtil.isUsableLocalPort(8161)) {

JOptionPane.showMessageDialog(null, "ActiveMQ 服务器未启动 ");

System.exit(1);

}

}

}

生产者类

TestProductor:

package edu.hpu.queue;

import javax.jms.ConnectionFactory;

import javax.jms.Destination;

import javax.jms.JMSException;

import javax.jms.MessageProducer;

import javax.jms.Session;

import javax.jms.TextMessage;

import javax.jms.Connection;

import org.apache.activemq.ActiveMQConnectionFactory;

import org.apache.activemq.transport.stomp.Stomp.Headers.Connect;

import edu.hpu.util.ActiveMQUtil;

public class TestProducter {

//服务地址,默认端口号61616

private static final String url=“tcp://127.0.0.1:61616”;

//这次发送的消息名称

private static final String topicName=“queue_style”;

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

//0、先判断是启动了ActiveMQ服务器

ActiveMQUtil.checkServer();

//1、创建ConnectionFactory,绑定地址

ConnectionFactory connectionFactory=new ActiveMQConnectionFactory(url);

//2、创建Connection

Connection connection=connectionFactory.createConnection();

//3、启动连接

connection.start();

//4、创建会话

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

//5、创建一个目标(队列类型)

Destination destination=session.createQueue(topicName);

//6、创建一个生产者

MessageProducer producer=session.createProducer(destination);

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

//7、创建消息

TextMessage textMessage=session.createTextMessage(“队列消息–”+i);

//8、发送消息

producer.send(textMessage);

System.out.println(“生产者发送消息–”+textMessage.getText());

}

//9、关闭连接

connection.close();

}

}

消费者类

TestConsumer:

package edu.hpu.queue;

import javax.jms.Connection;

import javax.jms.ConnectionFactory;

import javax.jms.Destination;

import javax.jms.JMSException;

import javax.jms.Message;

import javax.jms.MessageConsumer;

import javax.jms.MessageListener;

import javax.jms.Session;

import javax.jms.TextMessage;

import org.apache.activemq.ActiveMQConnectionFactory;

import cn.hutool.core.util.RandomUtil;

import edu.hpu.util.ActiveMQUtil;

/*

  • @订阅者

*/

public class TestConsumer {

//服务地址,端口默认61616

private static final String url=“tcp://127.0.0.1:61616”;

//这次消费的消息名称

private static final String topicName=“queue_style”;

//消费者可能会有多个,为了区分不同的消费者,为其创建随机名称

private static final String consumerName=“consumer-” + RandomUtil.randomString(5);

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

//0、先判断端口是否启动了ActiveMQ服务

ActiveMQUtil.checkServer();

System.out.printf(“%s 消费者启动了。 %n”, consumerName);

//1.创建ConnectiongFactory,绑定地址

ConnectionFactory factory=new ActiveMQConnectionFactory(url);

//2.创建Connection

Connection connection= factory.createConnection();

//3.启动连接

connection.start();

//4.创建会话

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

//5.创建一个目标 (队列类型)

Destination destination=session.createQueue(topicName);

//6.创建一个消费者

MessageConsumer consumer=session.createConsumer(destination);

//7、创建一个监听器

consumer.setMessageListener(new MessageListener() {

public void onMessage(Message arg0) {

// TODO Auto-generated method stub

TextMessage textMessage=(TextMessage)arg0;

try {

System.out.println(consumerName +" 接收消息:"+textMessage.getText());

} catch (JMSException e) {

e.printStackTrace();

}

}

});

}

}

启动

启动消费者类两次,产生两个消费者,启动生产者类,产生一个生产者,这个生产者会生产100条消息,而这两个消费者会分食这100条消息。

在这里插入图片描述

在这里插入图片描述

在这里插入图片描述

Ending

Tip:由于文章篇幅有限制,下面还有20个关于MySQL的问题,我都复盘整理成一份pdf文档了,后面的内容我就把剩下的问题的目录展示给大家看一下

如果觉得有帮助不妨【转发+点赞+关注】支持我,后续会为大家带来更多的技术类文章以及学习类文章!(阿里对MySQL底层实现以及索引实现问的很多)

吃透后这份pdf,你同样可以跟面试官侃侃而谈MySQL。其实像阿里p7岗位的需求也没那么难(但也不简单),扎实的Java基础+无短板知识面+对某几个开源技术有深度学习+阅读过源码+算法刷题,这一套下来p7岗差不多没什么问题,还是希望大家都能拿到高薪offer吧。

如果觉得有帮助不妨【转发+点赞+关注】支持我,后续会为大家带来更多的技术类文章以及学习类文章!(阿里对MySQL底层实现以及索引实现问的很多)

[外链图片转存中…(img-ySDsc4Aw-1718927754603)]

[外链图片转存中…(img-3eCC3BhH-1718927754604)]

吃透后这份pdf,你同样可以跟面试官侃侃而谈MySQL。其实像阿里p7岗位的需求也没那么难(但也不简单),扎实的Java基础+无短板知识面+对某几个开源技术有深度学习+阅读过源码+算法刷题,这一套下来p7岗差不多没什么问题,还是希望大家都能拿到高薪offer吧。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值