<>消息队列

本文详细介绍了使用消息队列进行进程间通信的过程,包括创建、发送和接收消息的步骤,并通过示例代码演示了实现过程。
 

/*msgque.c*/
#include <sys/types.h>
#include <sys/ipc.h>
#include <sys/msg.h>
#include <stdio.h>
#include <stdlib.h>
#include <unistd.h>
#include <string.h>
#define  BUFSZ  512

struct message
{
 long msg_type;
 char msg_text[BUFSZ];
};

int main()
{
 int qid;
 key_t key;
 int len;
 struct message msg;
 
 /*根据不同的路径和关键表示产生标准的key*/
 if ((key = ftok(".", 'a')) == -1)
 {
  perror("ftok");
  exit(1);
 }
 
 /*创建消息队列*/
 if ((qid = msgget(key,IPC_CREAT|0666)) == -1)
 {
  perror("msgget");
  exit(1);
 }
 
 printf("Opened queue %d\n",qid);
 puts("Please enter the message to queue:");
 
 if ((fgets((&msg)->msg_text, BUFSZ, stdin)) == NULL)
 {
  puts("no message");
  exit(1);
 }
 
 msg.msg_type = getpid();
 len = strlen(msg.msg_text);
 
 /*添加消息到消息队列*/
 if ((msgsnd(qid, &msg, len, 0)) < 0)
 {
  perror("message posted");
  exit(1);
 }
 
 /*读取消息队列*/
 if (msgrcv(qid, &msg, BUFSZ, getpid(), 0) < 0)
 {
  perror("msgrcv");
  exit(1);
 }
 
 printf("message is:%s\n",(&msg)->msg_text);
 
 /*从系统内核中移走消息队列 */
 if ((msgctl(qid, IPC_RMID, NULL)) < 0)
 {
  perror("msgctl");
  exit(1);
 }
 
 exit(0);
}

执行:


lsb@ubuntu:~/gx/wangluo$ ./msgque
Opened queue 0
Please enter the message to queue:
12
结果:

message is:12

 ********************************

********************************

消息队列通信-写端


/* msgsnd.c */

#include <sys/types.h>
#include <sys/ipc.h>
#include <sys/msg.h>
#include <stdio.h>
#include <stdlib.h>
#include <unistd.h>
#include <string.h>
#define  BUFFER_SIZE  512

struct message
{
 long msg_type;
 char msg_text[BUFFER_SIZE];
};

int main()
{
 int qid;
 key_t key;
 struct message msg;
 
 /*根据不同的路径和关键表示产生标准的key*/
 if ((key = ftok(".", 'a')) == -1)
 {
  perror("ftok");
  exit(1);
 }
 
 /*创建消息队列*/
 if ((qid = msgget(key, IPC_CREAT|0666)) == -1)
 {
  perror("msgget");
  exit(1);
 }
 printf("Open queue %d\n",qid);
 
 while(1)
 {
  printf("Enter some message to the queue(enter 'quit' to exit):");
  if ((fgets(msg.msg_text, BUFFER_SIZE, stdin)) == NULL)
  {
   puts("no message");
   exit(1);
  }
  
  msg.msg_type = getpid();
  
  /*添加消息到消息队列*/
  if ((msgsnd(qid, &msg, strlen(msg.msg_text), 0)) < 0)
  {
   perror("message posted");
   exit(1);
  }
  
  if (strncmp(msg.msg_text, "quit", 4) == 0)
  {
   break;
  }
 }
 
 exit(0);
}

执行:

lsb@ubuntu:~/gx/wangluo$ ./msgsnd
Open queue 32768
Enter some message to the queue(enter 'quit' to exit):ni hao
Enter some message to the queue(enter 'quit' to exit): 等待写的内容

Enter some message to the queue(enter 'quit' to exit):ni xian zai zai na li
Enter some message to the queue(enter 'quit' to exit):
----------------------------------

消息队列通信-读端,现实写过来的信息


/* msgrcv.c */

#include <sys/types.h>
#include <sys/ipc.h>
#include <sys/msg.h>
#include <stdio.h>
#include <stdlib.h>
#include <unistd.h>
#include <string.h>
#define  BUFFER_SIZE  512

struct message
{
 long msg_type;
 char msg_text[BUFFER_SIZE];
};

int main()
{
 int qid;
 key_t key;
 struct message msg;
 
 /*根据不同的路径和关键表示产生标准的key*/
 if ((key = ftok(".", 'a')) == -1)
 {
  perror("ftok");
  exit(1);
 }
 
 /*创建消息队列*/
 if ((qid = msgget(key, IPC_CREAT|0666)) == -1)
 {
  perror("msgget");
  exit(1);
 }
 printf("Open queue %d\n", qid);
 
 do
 {
  /*读取消息队列*/
  memset(msg.msg_text, 0, BUFFER_SIZE);
  if (msgrcv(qid, (void*)&msg, BUFFER_SIZE, 0, 0) < 0)
  {
   perror("msgrcv");
   exit(1);
  }
  printf("The message from process %ld : %s", msg.msg_type, msg.msg_text);  
  
 } while(strncmp(msg.msg_text, "quit", 4));
 
 
 /*从系统内核中移走消息队列 */
 if ((msgctl(qid, IPC_RMID, NULL)) < 0)
 {
  perror("msgctl");
  exit(1);
 }
 
 exit(0);
}

 执行:

lsb@ubuntu:~/gx/wangluo$ ./msgrcv
Open queue 32768
The message from process 4651 : ni hao
The message from process 4651 : ni xian zai zai na li


 

 

渲染 Mermaid 流程图代码有多种方式,以下为你介绍常见的几种: ### 使用 Mermaid Live Editor Mermaid Live Editor 是官方提供的在线可视化编辑工具,可直接在网页上编写和渲染 Mermaid 代码。 1. 打开 [Mermaid Live Editor](https://mermaid.live/)。 2. 将给定的 Mermaid 代码复制到左侧的编辑框中: ```mermaid flowchart TD subgraph External Network [外部网络/用户端] User[用户/运维人员<br>(浏览器、CLI)] Internet[互联网] end subgraph Management Network [管理网络(172.30.14.0/24)] VIP[虚拟IP(VIP)<br>172.30.14.100] subgraph Control Plane [控制节点集群] C1[controller01<br>172.30.14.10] C2[controller02<br>172.30.14.11] end Ansible[Ansible部署节点<br>server: 192.168.0.20] subgraph Data Storage [共享数据层] DB[(MariaDB<br>Galera Cluster)] MQ[(RabbitMQ<br>镜像队列)] end end subgraph Data / External Network [数据/外部网络] subgraph Compute Nodes [计算节点集群] Compute1[compute01<br>172.30.14.12] Compute2[compute02<br>172.30.14.13] NovaNova[Nova-Compute<br>Neutron-Agent] end end User -->|1. 所有API/界面请求| VIP VIP -->|2. 负载均衡流量| Control Plane C1 <-->|3. 数据库集群同步| DB C2 <-->|3. 数据库集群同步| DB C1 <-->|4. 消息队列通信| MQ C2 <-->|4. 消息队列通信| MQ Control Plane <-.->|5. 发送部署指令<br>推送配置| Ansible Control Plane <-->|6. 下发调度指令<br>接收状态信息| Compute Nodes ``` 3. 右侧窗口会实时渲染出对应的流程图。 ### 在 Markdown 文件中渲染 如果你使用的 Markdown 编辑器支持 Mermaid 渲染(如 Typora、VS Code 等),可以直接将代码嵌入 Markdown 文件中。 1. 在 Markdown 文件中,使用三个反引号(```)开头,并指定为 mermaid,接着粘贴 Mermaid 代码,最后再用三个反引号结尾。示例如下: ```mermaid flowchart TD subgraph External Network [外部网络/用户端] User[用户/运维人员<br>(浏览器、CLI)] Internet[互联网] end subgraph Management Network [管理网络(172.30.14.0/24)] VIP[虚拟IP(VIP)<br>172.30.14.100] subgraph Control Plane [控制节点集群] C1[controller01<br>172.30.14.10] C2[controller02<br>172.30.14.11] end Ansible[Ansible部署节点<br>server: 192.168.0.20] subgraph Data Storage [共享数据层] DB[(MariaDB<br>Galera Cluster)] MQ[(RabbitMQ<br>镜像队列)] end end subgraph Data / External Network [数据/外部网络] subgraph Compute Nodes [计算节点集群] Compute1[compute01<br>172.30.14.12] Compute2[compute02<br>172.30.14.13] NovaNova[Nova-Compute<br>Neutron-Agent] end end User -->|1. 所有API/界面请求| VIP VIP -->|2. 负载均衡流量| Control Plane C1 <-->|3. 数据库集群同步| DB C2 <-->|3. 数据库集群同步| DB C1 <-->|4. 消息队列通信| MQ C2 <-->|4. 消息队列通信| MQ Control Plane <-.->|5. 发送部署指令<br>推送配置| Ansible Control Plane <-->|6. 下发调度指令<br>接收状态信息| Compute Nodes ``` 2. 保存 Markdown 文件,在支持 Mermaid 渲染的编辑器中打开,即可看到渲染后的流程图。 ### 在网页中渲染 若要在网页中渲染 Mermaid 流程图,需引入 Mermaid 的 JavaScript 库。 1. 创建一个 HTML 文件,示例代码如下: ```html <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <meta name="viewport" content="width=device-width, initial-scale=1.0"> <title>Mermaid Flowchart</title> <script src="https://cdn.jsdelivr.net/npm/mermaid@10/dist/mermaid.min.js"></script> <script> mermaid.initialize({ startOnLoad: true }); </script> </head> <body> <div class="mermaid"> flowchart TD subgraph External Network [外部网络/用户端] User[用户/运维人员<br>(浏览器、CLI)] Internet[互联网] end subgraph Management Network [管理网络(172.30.14.0/24)] VIP[虚拟IP(VIP)<br>172.30.14.100] subgraph Control Plane [控制节点集群] C1[controller01<br>172.30.14.10] C2[controller02<br>172.30.14.11] end Ansible[Ansible部署节点<br>server: 192.168.0.20] subgraph Data Storage [共享数据层] DB[(MariaDB<br>Galera Cluster)] MQ[(RabbitMQ<br>镜像队列)] end end subgraph Data / External Network [数据/外部网络] subgraph Compute Nodes [计算节点集群] Compute1[compute01<br>172.30.14.12] Compute2[compute02<br>172.30.14.13] NovaNova[Nova-Compute<br>Neutron-Agent] end end User -->|1. 所有API/界面请求| VIP VIP -->|2. 负载均衡流量| Control Plane C1 <-->|3. 数据库集群同步| DB C2 <-->|3. 数据库集群同步| DB C1 <-->|4. 消息队列通信| MQ C2 <-->|4. 消息队列通信| MQ Control Plane <-.->|5. 发送部署指令<br>推送配置| Ansible Control Plane <-->|6. 下发调度指令<br>接收状态信息| Compute Nodes </div> </body> </html> ``` 2. 用浏览器打开该 HTML 文件,就能看到渲染好的流程图。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值