单一消息队列完成客户-服务器进程间的双向通信

2023-11-02 06:18

本文主要是介绍单一消息队列完成客户-服务器进程间的双向通信,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

单一消息队列完成客户—服务器进程间的双向通信,客户端接收输入字符串,如接收到的是exit字符串,直接退出,否则传送接收字符串到服务器端,并等待服务器端回传消息。服务器端:接收客户端请求,接收后将接收到的字符串逆序后回传到对应客户端。

//服务器端:
#include<sys/msg.h>
#include<sys/types.h>
#include<sys/ipc.h>
#include<stdio.h>
#include<sys/errno.h>
#include<string.h>
extern int errno;
struct mymsgbuf1
{long mtype;char ctext[100];
};
struct mymsgbuf
{long mtype;pid_t pid;char ctext[100];
};
void main(){struct mymsgbuf buf;struct mymsgbuf1 buf1;int msgid,ret,i,len;if((msgid = msgget(0x1234,0666|IPC_CREAT))<0){fprintf(stderr,"openmsg%xfailed.\n",0x1234);return;}while(1){memset(&buf,0,sizeof(buf));while((ret = msgrcv(msgid,&buf,sizeof(buf.ctext)+sizeof(buf.pid),1,0))<0){if(errno == EINTR)continue;return;}fprintf(stderr,"Receivemessageform%d,content:%s\n",buf.pid,buf.ctext);memset(&buf1,0,sizeof(buf1));//strcpy(buf1.ctext,buf.ctext);len=strlen(buf.ctext)for(i = 0;i < len;i++){buf1.ctext[len-1-i] = buf.ctext[i];}buf1.mtype = buf.pid;while((msgsnd(msgid,&buf1,strlen(buf1.ctext),0))<0){if(errno == EINTR)continue;return;}}
}
//客户端:
#include<sys/msg.h>
#include<sys/types.h>
#include<sys/ipc.h>
#include<stdio.h>
#include<sys/errno.h>
#include<string.h>
extern int errno;
struct tmymsgbuf1
{longmtype;charctext[100];
};
struct mymsgbuf
{long mtype;pid_t pid;char ctext[100];
};
void main()
{struct mymsgbuf buf;struct mymsgbuf1 buf1;int msgid,ret;pid_t pid = getpid();if((msgid = msgget(0x1234,0666|IPC_CREAT))<0){fprintf(stderr,"openmsg%xfailed.\n",0x1234);return;}while(1){memset(&buf,0,sizeof(buf));fgets(buf.ctext,sizeof(buf.ctext),stdin);if(!strcmp(buf.ctext,"exit"))break;buf.mtype = 1;buf.pid = pid;while((msgsnd(msgid,&buf,strlen(buf.ctext)+sizeof(buf.pid),0))<0){if(errno == EINTR)continue;return;}memset(&buf1,0,sizeof(buf1));while((ret = msgrcv(msgid,&buf1,sizeof(buf1.ctext),pid,0))<0){if(errno == EINTR)continue;return;}fprintf(stderr,"Receivemessageformservercontent:%s\n",buf1.ctext);}
}

在这里插入图片描述

一个服务器对应多个客户端,一个消息队列,客户端都将发送信息的类型设置为1,然后将自己的进程id放到数据部分,服务器接收所有客户端的请求,在返回给客户端信息的时候将类型设置为所接收的数据部分的进程id,客户端这边接收信息的函数里将接收类型设置为自己的进程id,就可以对应上了。

这篇关于单一消息队列完成客户-服务器进程间的双向通信的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/328690

相关文章

Python极速搭建局域网文件共享服务器完整指南

《Python极速搭建局域网文件共享服务器完整指南》在办公室或家庭局域网中快速共享文件时,许多人会选择第三方工具或云存储服务,但这些方案往往存在隐私泄露风险或需要复杂配置,下面我们就来看看如何使用Py... 目录一、android基础版:HTTP文件共享的魔法命令1. 一行代码启动HTTP服务器2. 关键参

一文解密Python进行监控进程的黑科技

《一文解密Python进行监控进程的黑科技》在计算机系统管理和应用性能优化中,监控进程的CPU、内存和IO使用率是非常重要的任务,下面我们就来讲讲如何Python写一个简单使用的监控进程的工具吧... 目录准备工作监控CPU使用率监控内存使用率监控IO使用率小工具代码整合在计算机系统管理和应用性能优化中,监

SpringBoot改造MCP服务器的详细说明(StreamableHTTP 类型)

《SpringBoot改造MCP服务器的详细说明(StreamableHTTP类型)》本文介绍了SpringBoot如何实现MCPStreamableHTTP服务器,并且使用CherryStudio... 目录SpringBoot改造MCP服务器(StreamableHTTP)1 项目说明2 使用说明2.1

RabbitMQ消息总线方式刷新配置服务全过程

《RabbitMQ消息总线方式刷新配置服务全过程》SpringCloudBus通过消息总线与MQ实现微服务配置统一刷新,结合GitWebhooks自动触发更新,避免手动重启,提升效率与可靠性,适用于配... 目录前言介绍环境准备代码示例测试验证总结前言介绍在微服务架构中,为了更方便的向微服务实例广播消息,

Linux进程CPU绑定优化与实践过程

《Linux进程CPU绑定优化与实践过程》Linux支持进程绑定至特定CPU核心,通过sched_setaffinity系统调用和taskset工具实现,优化缓存效率与上下文切换,提升多核计算性能,适... 目录1. 多核处理器及并行计算概念1.1 多核处理器架构概述1.2 并行计算的含义及重要性1.3 并

Linux下进程的CPU配置与线程绑定过程

《Linux下进程的CPU配置与线程绑定过程》本文介绍Linux系统中基于进程和线程的CPU配置方法,通过taskset命令和pthread库调整亲和力,将进程/线程绑定到特定CPU核心以优化资源分配... 目录1 基于进程的CPU配置1.1 对CPU亲和力的配置1.2 绑定进程到指定CPU核上运行2 基于

Javaee多线程之进程和线程之间的区别和联系(最新整理)

《Javaee多线程之进程和线程之间的区别和联系(最新整理)》进程是资源分配单位,线程是调度执行单位,共享资源更高效,创建线程五种方式:继承Thread、Runnable接口、匿名类、lambda,r... 目录进程和线程进程线程进程和线程的区别创建线程的五种写法继承Thread,重写run实现Runnab

怎样通过分析GC日志来定位Java进程的内存问题

《怎样通过分析GC日志来定位Java进程的内存问题》:本文主要介绍怎样通过分析GC日志来定位Java进程的内存问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录一、GC 日志基础配置1. 启用详细 GC 日志2. 不同收集器的日志格式二、关键指标与分析维度1.

Java进程异常故障定位及排查过程

《Java进程异常故障定位及排查过程》:本文主要介绍Java进程异常故障定位及排查过程,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录一、故障发现与初步判断1. 监控系统告警2. 日志初步分析二、核心排查工具与步骤1. 进程状态检查2. CPU 飙升问题3. 内存

mysql中的服务器架构详解

《mysql中的服务器架构详解》:本文主要介绍mysql中的服务器架构,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录1、背景2、mysql服务器架构解释3、总结1、背景简单理解一下mysqphpl的服务器架构。2、mysjsql服务器架构解释mysql的架