此版本仍在开发中,尚未被视为稳定版本。对于最新的稳定版本,请使用 Spring AMQP 3.2.4spring-doc.cadn.net.cn

RabbitMQ REST API

启用管理插件后,RabbitMQ 服务器将公开一个 REST API 来监视和配置代理。 现在提供了 API 的 Java 绑定。 这com.rabbitmq.http.client.Client是一个标准的、即时的,因此是阻塞的 API。 它基于 Spring Web 模块及其RestTemplate实现。 另一方面,com.rabbitmq.http.client.ReactorNettyClient是基于 Reactor Netty 项目的响应式、非阻塞实现。spring-doc.cadn.net.cn

此外,管理 REST API 可以与任何 HTTP 客户端一起使用。 下一个示例演示如何使用 WebClient 获取队列信息:spring-doc.cadn.net.cn

	public Map<String, Object> queueInfo(String queueName) throws URISyntaxException {
		WebClient client = createClient("admin", "admin");
		URI uri = queueUri(queueName);
		return client.get()
				.uri(uri)
				.accept(MediaType.APPLICATION_JSON)
				.retrieve()
				.bodyToMono(new ParameterizedTypeReference<Map<String, Object>>() {
				})
				.block(Duration.ofSeconds(10));
	}

	private URI queueUri(String queue) throws URISyntaxException {
		URI uri = new URI("http://localhost:15672/api/")
				.resolve("/api/queues/" + UriUtils.encodePathSegment("/", StandardCharsets.UTF_8) + "/" + queue);
		return uri;
	}

	private WebClient createClient(String adminUser, String adminPassword) {
		return WebClient.builder()
				.filter(ExchangeFilterFunctions.basicAuthentication(adminUser, adminPassword))
				.build();
	}