rabbitmq-c 程序实现客户端服务端

安装mq

https://blog.csdn.net/zl_momomo/article/details/82986368

需要安裝rabbitmq-server

开启rabbitmq服务
systemctl start rabbitmq-server
systemctl enable rabbitmq-server.

客户端 amqp_sendstring.c

include <stdint.h>
#include <stdio.h>
#include <stdlib.h>
#include <string.h>

#include <amqp.h>
// #include <rabbitmq-c/tcp_socket.h>

// #include "utils.h"

int main(int argc, char const* const* argv)
{
    char const*             hostname;
    int                     port;
    char const*             exchange;
    char const*             routingkey;
    char const*             messagebody;
    amqp_socket_t*          socket = NULL;
    amqp_connection_state_t conn;
    amqp_rpc_reply_t        rpc_reply;

    hostname = "localhost";
    port = 5672;
    exchange = "amq.topic";
    routingkey = "test";
    messagebody = argv[1];

    conn = amqp_new_connection();

    if (NULL == (socket = amqp_tcp_socket_new(conn)))
    {
        printf("creating TCP socket\n");
    }

    if (AMQP_STATUS_OK != amqp_socket_open(socket, hostname, port))
    {
        printf("opening TCP socket\n");
    }

    rpc_reply = amqp_login(conn, "/", 0, AMQP_DEFAULT_FRAME_SIZE, AMQP_DEFAULT_HEARTBEAT, AMQP_SASL_METHOD_PLAIN, "guest", "guest");
    if (AMQP_RESPONSE_NORMAL != rpc_reply.reply_type)
        printf("xxxxxxxx\n");

    // die_on_amqp_error(amqp_login(conn, "/", 0, 131072, 0, AMQP_SASL_METHOD_PLAIN, "guest", "guest"), "Logging in");
    if (NULL == amqp_channel_open(conn, 1))
        printf("xxxxxxxx2\n");

    rpc_reply = amqp_get_rpc_reply(conn);
    if (AMQP_RESPONSE_NORMAL != rpc_reply.reply_type)
        printf("Opening channel\n");
    else
    {
        amqp_basic_properties_t props;
        props._flags = AMQP_BASIC_CONTENT_TYPE_FLAG | AMQP_BASIC_DELIVERY_MODE_FLAG;
        props.content_type = amqp_cstring_bytes("text/plain");
        props.delivery_mode = 2; /* persistent delivery mode */
        if (0 != amqp_basic_publish(conn, 1, amqp_cstring_bytes(exchange), amqp_cstring_bytes(routingkey), 0, 0, &props, amqp_cstring_bytes(messagebody)))
            printf("Publishing\n");
    }

    rpc_reply = amqp_channel_close(conn, 1, AMQP_REPLY_SUCCESS);
    if (AMQP_RESPONSE_NORMAL != rpc_reply.reply_type)
        printf("Closing channel\n");
    rpc_reply = amqp_connection_close(conn, AMQP_REPLY_SUCCESS);
    if (AMQP_RESPONSE_NORMAL != rpc_reply.reply_type)
        printf("Closing connection");
    amqp_destroy_connection(conn);
    return 0;
}

服务端 amqp_listen.c

#include <stdint.h>
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#include <amqp.h>

int main(int argc, char const* const* argv)
{
    char const*             hostname;
    int                     port, status;
    char const*             exchange;
    char const*             bindingkey;
    amqp_socket_t*          socket = NULL;
    amqp_connection_state_t conn;
    amqp_rpc_reply_t        rpc_reply;

    amqp_bytes_t queuename;

    hostname = "localhost";
    port = 5672;
    exchange = "amq.topic";
    bindingkey = "test";

    conn = amqp_new_connection();

    socket = amqp_tcp_socket_new(conn);
    if (!socket)
    {
        printf("creating TCP socket\n");
    }

    if (AMQP_STATUS_OK != amqp_socket_open(socket, hostname, port))
    {
        printf("opening TCP socket\n");
    }

    rpc_reply = amqp_login(conn, "/", 0, AMQP_DEFAULT_FRAME_SIZE, AMQP_DEFAULT_HEARTBEAT, AMQP_SASL_METHOD_PLAIN, "guest", "guest");
    if (AMQP_RESPONSE_NORMAL != rpc_reply.reply_type)
        printf("xxxxxxxx\n");

    if (NULL == amqp_channel_open(conn, 1))
        printf("xxxxxxxx2\n");

    // die_on_amqp_error(amqp_login(conn, "/", 0, 131072, 0, AMQP_SASL_METHOD_PLAIN,
    //                              "guest", "guest"),
    //                   "Logging in");
    // amqp_channel_open(conn, 1);
    // die_on_amqp_error(amqp_get_rpc_reply(conn), "Opening channel");
    rpc_reply = amqp_get_rpc_reply(conn);
    if (AMQP_RESPONSE_NORMAL != rpc_reply.reply_type)
        printf("Opening channel\n");
    else
    {
        amqp_queue_declare_ok_t* r = amqp_queue_declare(conn, 1, amqp_empty_bytes, 0, 0, 0, 1, amqp_empty_table);
        // die_on_amqp_error(amqp_get_rpc_reply(conn), "Declaring queue");
        rpc_reply = amqp_get_rpc_reply(conn);
        if (AMQP_RESPONSE_NORMAL != rpc_reply.reply_type)
            printf("Declaring queue\n");
        queuename = amqp_bytes_malloc_dup(r->queue);
        if (queuename.bytes == NULL)
        {
            fprintf(stderr, "Out of memory while copying queue name");
            return 1;
        }
    }

    amqp_queue_bind(conn, 1, queuename, amqp_cstring_bytes(exchange), amqp_cstring_bytes(bindingkey), amqp_empty_table);
    // die_on_amqp_error(amqp_get_rpc_reply(conn), "Binding queue");
    rpc_reply = amqp_get_rpc_reply(conn);
    if (AMQP_RESPONSE_NORMAL != rpc_reply.reply_type)
        printf("Binding queue\n");

    amqp_basic_consume(conn, 1, queuename, amqp_empty_bytes, 0, 1, 0, amqp_empty_table);
    // die_on_amqp_error(amqp_get_rpc_reply(conn), "Consuming");
    rpc_reply = amqp_get_rpc_reply(conn);
    if (AMQP_RESPONSE_NORMAL != rpc_reply.reply_type)
        printf("Consuming\n");
    else
    {
        for (;;)
        {
            amqp_rpc_reply_t res;
            amqp_envelope_t  envelope;

            amqp_maybe_release_buffers(conn);

            res = amqp_consume_message(conn, &envelope, NULL, 0);

            if (AMQP_RESPONSE_NORMAL != res.reply_type)
            {
                break;
            }

            // printf("Delivery %u, exchange %.*s routingkey %.*s\n",
            //        (unsigned)envelope.delivery_tag, (int)envelope.exchange.len,
            //        (char*)envelope.exchange.bytes, (int)envelope.routing_key.len,
            //        (char*)envelope.routing_key.bytes);

            // if (envelope.message.properties._flags & AMQP_BASIC_CONTENT_TYPE_FLAG)
            // {
            //     printf("Content-type: %.*s\n",
            //            (int)envelope.message.properties.content_type.len,
            //            (char*)envelope.message.properties.content_type.bytes);
            // }
            printf("----\n");
            printf("===%s\n\n", envelope.message.body.bytes);
            // amqp_dump(envelope.message.body.bytes, envelope.message.body.len);

            amqp_destroy_envelope(&envelope);
        }
    }

    amqp_bytes_free(queuename);
    rpc_reply = amqp_channel_close(conn, 1, AMQP_REPLY_SUCCESS);
    if (AMQP_RESPONSE_NORMAL != rpc_reply.reply_type)
        printf("Closing channel\n");
    rpc_reply = amqp_connection_close(conn, AMQP_REPLY_SUCCESS);
    if (AMQP_RESPONSE_NORMAL != rpc_reply.reply_type)
        printf("Closing connection");
    amqp_destroy_connection(conn);

    return 0;
}

编译:

gcc amqp_listen.c utils.c -lrabbitmq -o s			
gcc amqp_sendstring.c utils.c -lrabbitmq -o c

测试:
在这里插入图片描述

  • 3
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
实现 Spring Boot、RabbitMQ 和 WebSocket 结合的方式主要有以下几个步骤: 1. 创建 Spring Boot 项目,添加 RabbitMQ 和 WebSocket 的相关依赖。 2. 创建 RabbitMQ 队列和交换机,用于发送消息。 3. 创建 WebSocket 配置类,配置 WebSocket 的相关参数。 4. 创建 WebSocket 处理器类,处理 WebSocket 的连接、消息发送等操作。 5. 创建 RabbitMQ 消息监听器类,监听 RabbitMQ 队列中的消息,将消息发送给 WebSocket 处理器。 下面是具体的实现步骤: 1. 创建 Spring Boot 项目,添加 RabbitMQ 和 WebSocket 的相关依赖。 在 pom.xml 中添加以下依赖: ```xml <dependencies> <!-- RabbitMQ 相关依赖 --> <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-amqp</artifactId> </dependency> <!-- WebSocket 相关依赖 --> <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-websocket</artifactId> </dependency> </dependencies> ``` 2. 创建 RabbitMQ 队列和交换机,用于发送消息。 在 RabbitMQ 中创建一个交换机和一个队列,然后将队列绑定到交换机上。这里我们使用 RabbitMQ 的默认交换机和队列。 ```java @Configuration public class RabbitMQConfig { @Bean public Queue queue() { return new Queue("websocket"); } @Bean public DirectExchange exchange() { return new DirectExchange(""); } @Bean public Binding binding(Queue queue, DirectExchange exchange) { return BindingBuilder.bind(queue).to(exchange).with("websocket"); } } ``` 3. 创建 WebSocket 配置类,配置 WebSocket 的相关参数。 ```java @Configuration @EnableWebSocketMessageBroker public class WebSocketConfig implements WebSocketMessageBrokerConfigurer { @Override public void configureMessageBroker(MessageBrokerRegistry registry) { registry.enableSimpleBroker("/topic"); registry.setApplicationDestinationPrefixes("/app"); } @Override public void registerStompEndpoints(StompEndpointRegistry registry) { registry.addEndpoint("/websocket").setAllowedOrigins("*").withSockJS(); } } ``` 4. 创建 WebSocket 处理器类,处理 WebSocket 的连接、消息发送等操作。 ```java @Component public class WebSocketHandler implements WebSocketHandler { private static final Logger logger = LoggerFactory.getLogger(WebSocketHandler.class); private SimpMessagingTemplate messagingTemplate; @Autowired public WebSocketHandler(SimpMessagingTemplate messagingTemplate) { this.messagingTemplate = messagingTemplate; } @Override public void afterConnectionEstablished(WebSocketSession session) throws Exception { logger.info("WebSocket connected: {}", session.getId()); } @Override public void handleMessage(WebSocketSession session, WebSocketMessage<?> message) throws Exception { logger.info("WebSocket received message: {}", message.getPayload()); } @Override public void handleTransportError(WebSocketSession session, Throwable exception) throws Exception { logger.error("WebSocket transport error: {}", exception.getMessage()); } @Override public void afterConnectionClosed(WebSocketSession session, CloseStatus closeStatus) throws Exception { logger.info("WebSocket disconnected: {}", session.getId()); } @Override public boolean supportsPartialMessages() { return false; } public void sendMessage(String message) { messagingTemplate.convertAndSend("/topic/messages", message); } } ``` 5. 创建 RabbitMQ 消息监听器类,监听 RabbitMQ 队列中的消息,将消息发送给 WebSocket 处理器。 ```java @Component public class RabbitMQListener { private static final Logger logger = LoggerFactory.getLogger(RabbitMQListener.class); private WebSocketHandler webSocketHandler; @Autowired public RabbitMQListener(WebSocketHandler webSocketHandler) { this.webSocketHandler = webSocketHandler; } @RabbitListener(queues = "websocket") public void handleMessage(String message) { logger.info("RabbitMQ received message: {}", message); webSocketHandler.sendMessage(message); } } ``` 至此,Spring Boot、RabbitMQ 和 WebSocket 结合的实现就完成了。我们可以通过 RabbitMQ 发送消息到队列,然后监听器会将消息发送给 WebSocket 处理器,处理器再将消息发送给 WebSocket 客户端

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值