DefaultMessageListenerContainer消息应答方式

29 篇文章 0 订阅

JMS标准支持的消息应答模式有下面几种:

AUTO_ACKNOWLEDGE:自动应答,默认的应答方式

CLIENT_ACKNOWLEDGE:客户端应答,应答由应用程序在接收到消息后触发

DUPS_OK_ACKNOWLEDGE:尽量不要使用,如果使用这种方式,应用程序需要考虑处理消息重复问题

SESSION_TRANSACTED:事务应答

使用MessageConsumer来接收消息时不管是AUTO_ACKNOWLEDGE还是CLIENT_ACKNOWLEDGE,只要发生了异常,消息都会进行jms.redeliveryPolicy.maximumRedeliveries配置数量的消息重发重试,如果消息无法发送则会送到Dead-Letter队列中,但是DefaultMessageListenerContainer在这方面的处理却与标准的应答不相同,使用DefaultMessageListenerContainer来接收消息时,如果采用AUTO_ACKNOWLEDGE的应答方式,那么消息不会重发,笔者建议使用CLIENT_ACKNOWLEDGE这种模式,这种模式发生异常时则会进行消息重发,而且无需应用程序应答消息,因为DefaultMessageListenerContainer已经替我们完成了消息的应答,下面是相关代码:

    AbstractMessageListenerContainer类

protected void commitIfNecessary(Session session, Message message) throws JMSException {
        // Commit session or acknowledge message.
        if (session.getTransacted()) {
            // Commit necessary - but avoid commit call within a JTA transaction.
            if (isSessionLocallyTransacted(session)) {
                // Transacted session created by this container -> commit.
                JmsUtils.commitIfNecessary(session);
            }
        }
        else if (message != null && isClientAcknowledge(session)) {
            message.acknowledge();
        }
    }

JmsAccessor类

    protected boolean isClientAcknowledge(Session session) throws JMSException {
        return (session.getAcknowledgeMode() == Session.CLIENT_ACKNOWLEDGE);
    }

从上面代码可以看出,DefaultMessageListenerContainer会对CLIENT_ACKNOWLEDGE应答模式自动确认

  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
抱歉,我是一名语言模型AI,不具备编写代码的能力。但我可以为你提供一些基于MATLAB的数字调制演示系统的参考代码,希望对你有所帮助: 1. ASK调制 % 定义基本参数 fc = 10; % 载波频率 fs = 100; % 采样频率 Ts = 1/fs; % 采样时间 % 定义信息序列 bit_rate = 5; % 信息速率 bit_length = fs/bit_rate; % 信息位长 info = randi([0 1],1,bit_length); % 随机生成0/1信息序列 % ASK调制 carrier = sin(2*pi*fc*(0:Ts:bit_length*Ts-Ts)); % 生成载波信号 ask_signal = carrier.*(2*info-1); % ASK调制 % 绘制波形图 t = 0:Ts:bit_length*Ts-Ts; subplot(3,1,1); plot(t,info); title('信息序列'); subplot(3,1,2); plot(t,carrier); title('载波信号'); subplot(3,1,3); plot(t,ask_signal); title('ASK调制信号'); 2. FSK调制 % 定义基本参数 fc1 = 10; % 第一个载波频率 fc2 = 20; % 第二个载波频率 fs = 100; % 采样频率 Ts = 1/fs; % 采样时间 % 定义信息序列 bit_rate = 5; % 信息速率 bit_length = fs/bit_rate; % 信息位长 info = randi([0 1],1,bit_length); % 随机生成0/1信息序列 % FSK调制 fsk_signal = []; for i=1:bit_length if info(i)==0 temp = sin(2*pi*fc1*(i-1)*Ts:Ts:2*pi*fc1*i*Ts-Ts); else temp = sin(2*pi*fc2*(i-1)*Ts:Ts:2*pi*fc2*i*Ts-Ts); end fsk_signal = [fsk_signal temp]; end % 绘制波形图 t = 0:Ts:bit_length*Ts*2-bit_length*Ts; subplot(3,1,1); plot(t,info); title('信息序列'); subplot(3,1,2); plot(t(1:bit_length*fs/bit_rate),fsk_signal(1:bit_length*fs/bit_rate)); title('FSK调制信号'); subplot(3,1,3); spectrogram(fsk_signal,[],[],[],fs,'yaxis'); title('FSK调制信号频谱图'); 3. PSK调制 % 定义基本参数 fc = 10; % 载波频率 fs = 100; % 采样频率 Ts = 1/fs; % 采样时间 % 定义信息序列 bit_rate = 5; % 信息速率 bit_length = fs/bit_rate; % 信息位长 info = randi([0 1],1,bit_length); % 随机生成0/1信息序列 % PSK调制 psk_signal = []; for i=1:bit_length if info(i)==0 temp = sin(2*pi*fc*(i-1)*Ts:Ts:2*pi*fc*i*Ts-Ts); else temp = sin(2*pi*fc*(i-1)*Ts:Ts:2*pi*fc*i*Ts-Ts+pi); end psk_signal = [psk_signal temp]; end % 绘制波形图 t = 0:Ts:bit_length*Ts*2-bit_length*Ts; subplot(3,1,1); plot(t,info); title('信息序列'); subplot(3,1,2); plot(t(1:bit_length*fs/bit_rate),psk_signal(1:bit_length*fs/bit_rate)); title('PSK调制信号'); subplot(3,1,3); spectrogram(psk_signal,[],[],[],fs,'yaxis'); title('PSK调制信号频谱图'); 以上是一些简单的数字调制演示系统的代码,你可以根据自己的需求进行修改和完善。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值