JavaEE-面试-ActiveMq面试回答思路

是什么?

消息中间件。可以在分布式系统的不同服务之间进行消息的发送接收

它的出现解决什么问题?

可以让系统解耦
比如,使用消息中间件,某一个服务,可能依赖了其他好几个服务。比如课程里面的运营商后台依赖了4个服务,那不用mq就和4个服务耦合,用了mq,就只和1个mq耦合。参考下图:

 

同类型技术有哪些,如何选择?

RabbitMQ,Kafka ,ZeroMQ,MetaMQ,RocketMQ

1. 对比

关于消息队列的使用----ActiveMQ,RabbitMQ,ZeroMQ,Kafka,MetaMQ,RocketMQ
MQ选型对比RabbitMQ RocketMQ ActiveMQ Kafka
Kafka、RabbitMQ、RocketMQ消息中间件的对比—— 消息发送性能-转自阿里中间件
开源软件成熟度评测报告-分布式消息中间件

2. 结论

除了知道ActiveMQ,有必要知道Kafka的使用。需要Kafka资料的同学单独联系我。

大概介绍?

1. 1个标准

Jms标准,JMS(Java Messaging Service)是Java官方定义的技术规范
JMS 定义了五种不同的消息:

消息类型消息描述备注
TextMessage字符串常用
MapMessage值对 
ObjectMessage序列化的 Java 对象 
BytesMessage字节的数据流 
StreamMessage原始值的数据流 

2. 两个角色

Producer(生产者):发消息
Consumer(消费者):收消息

3. 两种消息模式

一对一消息(私聊),Queue消息,同时一个收。

 

一对多消息(群发),Topic消息,同时可以多个收。

 

具体使用?

1. 安装mq服务器

简单,就一个tar包。

2. 客户端使用spring-jms

通过maven添加jar包。
创建applicationContext-jms-producer-queue.xml,配置connectionFactory消息类型jmsTemplate(发消息)

创建applicationContext-jms-consumer-queue.xml,配置connectionFactory消息类型messageListener(收消息)

发送:

接收:

实际项目应用场景?

最重要,告知面试官实际使用情况

删除商品-》发送消息-》接收消息-》删除索引。
商品状态更新-》发送消息-》接收消息-》导入索引库。

拓展说说?

消息会不会丢?
消息丢了怎么办?
消息队列的其他特性:异步处理、数据同步、流量削峰、缓冲、限流等。

  • 2
    点赞
  • 18
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值