设计思路
利用消息队列的特性进行消息投递,假设客户端 A 要与客户端 B 进行通信。
客户端 A :创建队列 A-B ,发送的消息推送到 A-B 队列, 绑定 B-A 队列,接收 B-A 队列推送给客户端的消息。
客户端 B :创建队列 B-A ,发送的消息推送到 B-A 队列, 绑定 A-B 队列,接收 A-B 队列推送给客户端的消息。
如果其中某个客户端主动退出或者异常中断时,销毁队列 A-B 以及队列 B-A(是否销毁视实际应用场景来定)。
实现
创建RabbitMQ 工具类,用以获取连接及销毁队列。
import com.rabbitmq.client.Channel;
import com.rabbitmq.client.Connection;
import com.rabbitmq.client.ConnectionFactory;
import java.io.IOException;
import java.util.concurrent.TimeoutException;
public class ClientUtils {
private static ConnectionFactory DEFAULT_FACTORY_INSTANCE = null;
static {
DEFAULT_FACTORY_INSTANCE = new ConnectionFactory();
DEFAULT_FACTORY_INSTANCE.setHost("127.0.0.1");
DEFAULT_FACTORY_INSTANCE.setUsername("user");
DEFAULT_FACTORY_INSTANCE.setPassword("123456");
DEFAULT_FACTORY_INSTANCE.setVirtualHost("testVirtualHost");
}
public static Connection getConnection() throws IOException, TimeoutException {
return DEFAULT_FACTORY_INSTANCE.newConnection();
}
public static void queueDelete(Channel channel, String queue) throws IOException {

最低0.47元/天 解锁文章
4220

被折叠的 条评论
为什么被折叠?



