rabbitmq 생산자 정보 확인 메커니즘
20984 단어 rabbitmq
rabbitmq 생산자 정보 확인 메커니즘
문제 설명
생산자가rabbitmq 서버에 메시지를 보낼 때 메시지가 서버에 도착했습니까?생산자가 보낸 메시지가 서버에 신뢰할 수 있도록 하기 위해 rabbitmq는 두 가지 방식을 제공했다.
publisher confirm
을 통해 실현사무 메커니즘
rabbitmq와 사무 관련 방법:
channel.txSelect()
: 현재 채널을 사무 모드로 설정channel.txCommit()
: 트랜잭션 제출 용도channel.txRollback()
: 롤백 트랜잭션에 사용예:
public class TransactionSender {
private static final String ex_name = "ex_tx";
private static final String q_name = "q_tx";
private static final String rt_name = "rt_tx";
public static void main(String[] args) throws IOException, TimeoutException {
ConnectionFactory factory = new ConnectionFactory();
factory.setHost("localhost");
Connection connection = factory.newConnection();
Channel channel = connection.createChannel();
channel.exchangeDeclare(ex_name, BuiltinExchangeType.DIRECT);
channel.queueDeclare(q_name, false, false, false, null);
channel.queueBind(q_name, ex_name, rt_name);
channel.txSelect();
try {
channel.basicPublish(ex_name, rt_name, null, "hello".getBytes());
// RuntimeException
int a = 1/0;
channel.txCommit();
} catch (IOException e) {
e.printStackTrace();
channel.txRollback();
}
}
}
웹 관리자를 통해 알 수 있듯이 메시지가 대응하는 대기열에 보내지지 않았습니다
발송자 확인 메커니즘
송신자 확인 메커니즘은 동기화와 비동기로 나뉜다
원리
생산자는 채널을
confirm
모드로 설정하고 채널이 confirm
모드에 들어가면 이 채널에 발표된 모든 메시지는 유일한 id(1부터), 메시지가 일치하는 대기열에 배달되면rabbitmq는 확인Basic.Ack
과deliverTag
(메시지 id)을 생산자에게 보냅니다.만약 메시지와 대기열이 지구화된다면 메시지는 지구화 후에 발송될 것이다.rabbitmq는 리셋deliverTag
외에도 multiple
파라미터가 있어 이 번호 이전의 모든 메시지가 처리되었다는 것을 나타낸다.모든 소식은 Ack
또는 Nack
한 번, 피Ack
및 피Nack
동기화 확인
동기화 확인:
public class SyncConfirmSender {
private static final String ex_name = "ex_confirm";
private static final String q_name = "q_confirm";
private static final String rt_name = "rt_confirm";
public static void main(String[] args) throws IOException, TimeoutException,
InterruptedException {
ConnectionFactory factory = new ConnectionFactory();
factory.setHost("localhost");
Connection connection = factory.newConnection();
Channel channel = connection.createChannel();
channel.exchangeDeclare(ex_name, BuiltinExchangeType.DIRECT);
channel.queueDeclare(q_name, false, false, false, null);
channel.queueBind(q_name, ex_name, rt_name);
//
channel.confirmSelect();
channel.basicPublish(ex_name, rt_name, null, "hello".getBytes());
//
if (!channel.waitForConfirms()){
System.out.println(" ...");
}else {
System.out.println(" ...");
}
}
}
비동기식 확인
비동기식 확인:
public class SyncConfirmSender {
private static final String ex_name = "ex_confirm";
private static final String q_name = "q_confirm";
private static final String rt_name = "rt_confirm";
public static void main(String[] args) throws IOException, TimeoutException,
InterruptedException {
ConnectionFactory factory = new ConnectionFactory();
factory.setHost("localhost");
Connection connection = factory.newConnection();
Channel channel = connection.createChannel();
channel.exchangeDeclare(ex_name, BuiltinExchangeType.DIRECT);
channel.queueDeclare(q_name, false, false, false, null);
channel.queueBind(q_name, ex_name, rt_name);
channel.confirmSelect();
//
channel.addConfirmListener(new ConfirmListener() {
@Override
public void handleAck(long deliveryTag, boolean multiple) throws IOException {
System.out.println("Ack: tag no: "+ deliveryTag+ " multiple: "+ multiple);
}
@Override
public void handleNack(long deliveryTag, boolean multiple) throws IOException {
System.out.println("Nack: tag no: "+ deliveryTag+ " multiple: "+ multiple);
}
});
channel.basicPublish(ex_name, rt_name, null, "hello".getBytes());
}
}
이 내용에 흥미가 있습니까?
현재 기사가 여러분의 문제를 해결하지 못하는 경우 AI 엔진은 머신러닝 분석(스마트 모델이 방금 만들어져 부정확한 경우가 있을 수 있음)을 통해 가장 유사한 기사를 추천합니다:
RabbitMQ를 사용하여 다음 주차장 시뮬레이션을 비동기식으로 만들려면 어떻게 해야 합니까?Java의 동시성에 대한 다양한 접근 방식을 배우고 이해하려고 합니다. 저는 주차장 시뮬레이션의 직렬화된 구현을 가지고 있습니다. 프로그램이 대신 Rabbitmq를 사용하도록 만들고 싶습니다. 어떻게 해야 합니까? ...
텍스트를 자유롭게 공유하거나 복사할 수 있습니다.하지만 이 문서의 URL은 참조 URL로 남겨 두십시오.
CC BY-SA 2.5, CC BY-SA 3.0 및 CC BY-SA 4.0에 따라 라이센스가 부여됩니다.