请设计协议,要求使用rabbitmq分发 设备信息的增删改查信息。并使用rabbitmq-c实现
时间: 2024-05-25 20:05:10 浏览: 101
基于SpringBoot+MyBatis+Redis+RabbitMQ 实现的秒杀系统.zip
好的,我会为您设计协议,并提供使用rabbitmq-c实现的代码示例。
1. 设备信息的增删改查协议设计
我们可以使用RabbitMQ的四种消息模型之一——发布/订阅模型来实现设备信息的增删改查协议。
具体而言,我们可以创建一个名为"device_info"的交换机,设备信息的增删改查操作分别对应四个路由键:"device_info.add"、"device_info.delete"、"device_info.update"、"device_info.query"。
当客户端需要进行增、删、改、查操作时,可以将对应的消息发送到交换机"device_info",并指定对应的路由键。服务器端的应用程序可以通过绑定队列到交换机,并指定路由键的方式来接收对应的消息。
2. 使用rabbitmq-c实现
以下是使用rabbitmq-c实现设备信息的增删改查协议的示例代码:
```c
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#include <amqp.h>
#include <amqp_tcp_socket.h>
int main(int argc, char const *const *argv)
{
const char* exchange = "device_info";
const char* routing_keys[] = {"device_info.add", "device_info.delete", "device_info.update", "device_info.query"};
const int num_routing_keys = sizeof(routing_keys) / sizeof(char*);
const char* message[] = {"Add device info", "Delete device info", "Update device info", "Query device info"};
const int num_messages = sizeof(message) / sizeof(char*);
const char* hostname = "localhost";
const int port = 5672;
const char* username = "guest";
const char* password = "guest";
const char* vhost = "/";
amqp_socket_t* socket = NULL;
amqp_connection_state_t conn;
amqp_rpc_reply_t reply;
conn = amqp_new_connection();
socket = amqp_tcp_socket_new(conn);
if (!socket) {
perror("Create TCP socket failed");
exit(1);
}
if (amqp_socket_open(socket, hostname, port)) {
perror("Open TCP socket failed");
exit(1);
}
reply = amqp_login(conn, vhost, 0, AMQP_DEFAULT_FRAME_SIZE, 0, AMQP_SASL_METHOD_PLAIN, username, password);
if (reply.reply_type != AMQP_RESPONSE_NORMAL) {
fprintf(stderr, "Login failed\n");
exit(1);
}
amqp_channel_open(conn, 1);
if (amqp_get_rpc_reply(conn).reply_type != AMQP_RESPONSE_NORMAL) {
fprintf(stderr, "Open channel failed\n");
exit(1);
}
amqp_exchange_declare(conn, 1, amqp_cstring_bytes(exchange), amqp_cstring_bytes("fanout"), 0, 0, 0, 0, amqp_empty_table);
for (int i = 0; i < num_routing_keys; ++i) {
amqp_queue_declare_ok_t* r = amqp_queue_declare(conn, 1, amqp_empty_bytes, 0, 0, 0, 1, amqp_empty_table);
amqp_bytes_t queue = amqp_bytes_malloc_dup(r->queue);
if (queue.bytes == NULL) {
fprintf(stderr, "Malloc queue name failed\n");
exit(1);
}
amqp_queue_bind(conn, 1, queue, amqp_cstring_bytes(exchange), amqp_cstring_bytes(routing_keys[i]), amqp_empty_table);
for (int j = 0; j < num_messages; ++j) {
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
amqp_basic_publish(conn, 1, amqp_cstring_bytes(exchange), amqp_cstring_bytes(routing_keys[i]), 0, 0, &props, amqp_cstring_bytes(message[j]));
}
}
amqp_channel_close(conn, 1, AMQP_REPLY_SUCCESS);
amqp_connection_close(conn, AMQP_REPLY_SUCCESS);
amqp_destroy_connection(conn);
return 0;
}
```
上述代码实现了客户端向交换机"device_info"发送四种类型的消息,分别对应设备信息的增、删、改、查操作。在实际应用中,服务器端的应用程序可以通过绑定队列到交换机,并指定路由键的方式来接收对应的消息,从而实现设备信息的增删改查操作。
希望本次回答对您有所帮助,如有疑问请随时提出。
阅读全文