rabbitmq 메시지 확인 메커니즘(사물+confim)
3617 단어 rabbitmq
문제: 생산자가 메시지를 보낸 후에 메시지가rabbitmq 서버에 도착했습니까?
두 가지 방식: AMQP는 사물 메커니즘을 실현했다.confirm 모드
사무 메커니즘
txselect txCommit txRollback txselect: 사용자가 현재 채널을transation 모드로 설정합니다.xxcommit: 사무를 제출합니다.txRollback: 트랜잭션 롤백.Channel channel = connection.createChannel();
channel.queueDeclare(QUEUE_NAME,false,false,false,null);
String msgString ="HELLO TX MESSAGE";
try{
channel.txSelect():
channel.basicPublish(EXCHANGE_NAME,ROUTING_NAME,null,msgString.getBates());
channel.txCommit();
}catch(Exception e){
channel.txRollback();
}
Cnfirm 모드
생산단 confim 모델의 실현 원리:
생산자는 채널을confim모드로 설정합니다. 채널이confim모드에 들어가면 이 채널에 발표된 모든 메시지는 유일한 ID(1부터)로 파견됩니다. 메시지가 모든 일치하는 대기열에 배달되면 브로커는 생산자에게 확인(메시지의 유일한 ID 포함)을 보냅니다. 이로써 생산자는 메시지가 목적의 대기열에 정확하게 도착했다는 것을 알 수 있습니다. 만약에 메시지와 대기열이 오래 지속될 수 있다면,그러면 확인 메시지가 디스크에 기록되어 전송됩니다.브로커가 생산자에게 보내는 확인 메시지에deliver-tag역은 확인 메시지의 시퀀스 번호를 포함하고 있으며, 브로커는basic로 설정할 수 있습니다.ask의multiple역은 이 시퀀스 번호 이전의 모든 메시지가 처리되었음을 나타냅니다.
confim 모드의 가장 큰 장점은 비동기적이라는 것이다.
confim 모드 열기channel.confimSelect();
프로그래밍 모드:
Channel channel = connection.createChannel();
channel.queueDeclare(QUEUE_NAME,false,false,false,null);
String msgString ="HELLO TX MESSAGE";
try{
channel.txSelect():
channel.basicPublish(EXCHANGE_NAME,ROUTING_NAME,null,msgString.getBates());
channel.txCommit();
}catch(Exception e){
channel.txRollback();
}
생산단 confim 모델의 실현 원리:
생산자는 채널을confim모드로 설정합니다. 채널이confim모드에 들어가면 이 채널에 발표된 모든 메시지는 유일한 ID(1부터)로 파견됩니다. 메시지가 모든 일치하는 대기열에 배달되면 브로커는 생산자에게 확인(메시지의 유일한 ID 포함)을 보냅니다. 이로써 생산자는 메시지가 목적의 대기열에 정확하게 도착했다는 것을 알 수 있습니다. 만약에 메시지와 대기열이 오래 지속될 수 있다면,그러면 확인 메시지가 디스크에 기록되어 전송됩니다.브로커가 생산자에게 보내는 확인 메시지에deliver-tag역은 확인 메시지의 시퀀스 번호를 포함하고 있으며, 브로커는basic로 설정할 수 있습니다.ask의multiple역은 이 시퀀스 번호 이전의 모든 메시지가 처리되었음을 나타냅니다.
confim 모드의 가장 큰 장점은 비동기적이라는 것이다.
confim 모드 열기
channel.confimSelect();
프로그래밍 모드:
이 내용에 흥미가 있습니까?
현재 기사가 여러분의 문제를 해결하지 못하는 경우 AI 엔진은 머신러닝 분석(스마트 모델이 방금 만들어져 부정확한 경우가 있을 수 있음)을 통해 가장 유사한 기사를 추천합니다:
RabbitMQ를 사용하여 다음 주차장 시뮬레이션을 비동기식으로 만들려면 어떻게 해야 합니까?Java의 동시성에 대한 다양한 접근 방식을 배우고 이해하려고 합니다. 저는 주차장 시뮬레이션의 직렬화된 구현을 가지고 있습니다. 프로그램이 대신 Rabbitmq를 사용하도록 만들고 싶습니다. 어떻게 해야 합니까? ...
텍스트를 자유롭게 공유하거나 복사할 수 있습니다.하지만 이 문서의 URL은 참조 URL로 남겨 두십시오.
CC BY-SA 2.5, CC BY-SA 3.0 및 CC BY-SA 4.0에 따라 라이센스가 부여됩니다.