activemq持久订阅工作原理

总结

无论是哪家公司,都很重视高并发高可用的技术,重视基础,重视JVM。面试是一个双向选择的过程,不要抱着畏惧的心态去面试,不利于自己的发挥。同时看中的应该不止薪资,还要看你是不是真的喜欢这家公司,是不是能真的得到锻炼。其实我写了这么多,只是我自己的总结,并不一定适用于所有人,相信经过一些面试,大家都会有这些感触。

最后我整理了一些面试真题资料,技术知识点剖析教程,还有和广大同仁一起交流学习共同进步,还有一些职业经验的分享。

面试了阿里,滴滴,网易,蚂蚁,最终有幸去了网易【面试题分享】

本文已被CODING开源项目:【一线大厂Java面试题解析+核心总结学习笔记+最新讲解视频+实战项目源码】收录

需要这份系统化的资料的朋友,可以点击这里获取

DurableTopicSubscription sub = durableSubscriptions.get(key);**

if (sub != null) {

if (sub.isActive()) {

throw new JMSException("Durable consumer is in use for client: " + clientId + " and subscriptionName: " + subscriptionName);

}

// 看下该订阅者的消息筛选项是否变化

if (hasDurableSubChanged(info, sub.getConsumerInfo())) {

// 如果变化了那么首先移除该订阅者对应的DurableTopicSubscription,然后再追加最新创建的DurableTopicSubscription

durableSubscriptions.remove(key);

destinationsLock.readLock().lock();

try {

for (Destination dest : destinations.values()) {

//Account for virtual destinations

if (dest instanceof Topic){

Topic topic = (Topic)dest;

topic.deleteSubscription(context, key);

}

}

} finally {

destinationsLock.readLock().unlock();

}

**super.removeConsumer(context, sub.getConsumerInfo());

super.addConsumer(context, info);

sub = durableSubscriptions.get(key);**

} else {

// 如果消息筛选项没有变化,那么直接将刚恢复连接的订阅者id与之前的DurableTopicSubscription 关联起来

if (sub.getConsumerInfo().getConsumerId() != null) {

subscriptions.remove(sub.getConsumerInfo().getConsumerId());

}

subscriptions.put(info.getConsumerId(), sub);

}

} else {

super.addConsumer(context, info);

sub = durableSubscriptions.get(key);

if (sub == null) {

throw new JMSException("Cannot use the same consumerId: " + info.getConsumerId() + " for two different durable subscriptions clientID: " + key.getClientId()

+ " subscriberName: " + key.getSubscriptionName());

}

}

sub.activate(usageManager, context, info, broker);

return sub;

} else {

return super.addConsumer(context, info);

}

}

上面代码是订阅者连接到消息提供者时的处理代码,下面看下更核心的持久订阅与消息提供者断开连接时的处理:

@Override

public void removeConsumer(ConnectionContext context, ConsumerInfo info) throws Exception {

if (info.isDurable()) {

SubscriptionKey key = new SubscriptionKey(context.getClientId(), info.getSubscriptionName());

DurableTopicSubscription sub = durableSubscriptions.get(key);

if (sub != null) {

sub.deactivate(keepDurableSubsActive);

}

} else {

super.removeConsumer(context, info);

}

}

最后

金三银四马上就到了,希望大家能好好学习一下这些技术点

学习视频:

大厂面试真题:

本文已被CODING开源项目:【一线大厂Java面试题解析+核心总结学习笔记+最新讲解视频+实战项目源码】收录

需要这份系统化的资料的朋友,可以点击这里获取

源项目:【一线大厂Java面试题解析+核心总结学习笔记+最新讲解视频+实战项目源码】](https://bbs.csdn.net/topics/618154847)收录**

需要这份系统化的资料的朋友,可以点击这里获取

  • 22
    点赞
  • 21
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值