【Linux】 POSIX 消息队列通讯

5 篇文章 0 订阅
#include <stdio.h>
#include <unistd.h>
#include <stdlib.h>
#include <string.h>
#include <fcntl.h>
#include <errno.h>
#include <sys/msg.h>
#include <mqueue.h>

#define BUF_SIZE 1024

#define FILE_PATH_S "/mq_sw"
#define FILE_PATH_C "/mq_cw"


int main()
{
    int ret=0;
    int len=0;

    unsigned int prio=0;

    char *buf=NULL;
    
    long mq_msgsize=0;

    // fork
    pid_t pid=fork();

    if(-1==pid)
    {
        perror("fork");
        exit(-1);
    }
    if(0==pid)
    {
        // client
        mqd_t mq_id_cw=0;
        mqd_t mq_id_cr=0;

        // open mq
        mq_id_cw=mq_open(FILE_PATH_C,O_WRONLY | O_CREAT, 0666, NULL);
        if(-1==mq_id_cw)
        {
            perror("mq_open");
            exit(-1);
        }
        mq_id_cr=mq_open(FILE_PATH_S,O_RDONLY);
        if(-1==mq_id_cr)
        {
            perror("mq_open");
            exit(-1);
        }

        // get mq attr
        struct mq_attr mq_attr_cr;
        struct mq_attr mq_attr_cw;

        ret=mq_getattr(mq_id_cr,&mq_attr_cr);
        if(-1==ret)
        {
            perror("mq_getattr");
            exit(-1);
        }

        ret=mq_getattr(mq_id_cw,&mq_attr_cw);
        if(-1==ret)
        {
            perror("mq_getattr");
            exit(-1);
        }
        
        // display mq attr
        printf("mq_attr:mq_msgsize=%ld\n",mq_attr_cr.mq_msgsize);
        printf("mq_attr:mq_maxmsg=%ld\n",mq_attr_cr.mq_maxmsg);
        printf("mq_attr:mq_flags=%ld\n",mq_attr_cr.mq_flags);
        printf("mq_attr:mq_curmsgs=%ld\n",mq_attr_cr.mq_curmsgs);
        

        // save mq_msgsize
        mq_msgsize=mq_attr_cr.mq_msgsize;

        // init buf
        buf=(char*)malloc(mq_msgsize);
        if(NULL==buf)
        {
            printf("malloc: Failed to allocate memory!");
            exit(-1);
        }

        for(;;)
        {
            printf("enter 'exit' to close!\n>");
            bzero(buf,mq_msgsize);
            scanf("%s",buf);

            //send to server
            len=mq_send(mq_id_cw,buf,strlen(buf),0);
            if(-1==len)
            {
                printf("send message failed!\n");
                perror("write");
            }else{
                printf("send successful!\n");
            }

            if(0==strcmp(buf,"exit"))
            {
                // close message queue
                mq_close(mq_id_cw);
                mq_close(mq_id_cr);
                mq_unlink(FILE_PATH_C);
                printf("client closed!\n");
                break;
            }

            //read from server
            bzero(buf,mq_msgsize);
            len=mq_receive(mq_id_cr,buf,mq_msgsize,&prio);
            if(-1==len)
            {
                perror("mq_receive");
            }else{
                printf("recv message from server!\ndata:%s\n",buf);
            }
        }
        free(buf);
    }else{
        
        //server
        int fd=0;
        mqd_t mq_id_sr=0;
        mqd_t mq_id_sw=0;

        // open mq
        mq_id_sw=mq_open(FILE_PATH_S,O_WRONLY | O_CREAT, 0666, NULL);
        if(-1==mq_id_sw)
        {
            perror("mq_open");
            exit(-1);
        }

        mq_id_sr=mq_open(FILE_PATH_C,O_RDONLY);
        if(-1==mq_id_sr)
        {
            perror("mq_open");
            exit(-1);
        }

        // get mq attr
        struct mq_attr mq_attr_sr;
        struct mq_attr mq_attr_sw;

        ret=mq_getattr(mq_id_sr,&mq_attr_sr);
        if(-1==ret)
        {
            perror("mq_getattr");
            exit(-1);
        }

        ret=mq_getattr(mq_id_sw,&mq_attr_sw);
        if(-1==ret)
        {
            perror("mq_getattr");
            exit(-1);
        }

        // don't display; save some info
        mq_msgsize=mq_attr_sr.mq_msgsize;
        
        // init buf
        buf=(char*)malloc(mq_msgsize);
        if(NULL==buf)
        {
            printf("malloc: Failed to allocate memory!");
            exit(-1);
        }
        
        for(;;)
        {
            bzero(buf,mq_msgsize);
            // read from client
            len=mq_receive(mq_id_sr,buf,mq_msgsize,&prio);
            if(-1==len)
            {
                perror("mq_receive");
            }else if(1>=strlen(buf))
            {
                // nothing to do
            }else
            {
                // if recv 'exit' to close
                if(0==strcmp(buf,"exit"))
                {
                    mq_close(mq_id_sw);
                    mq_close(mq_id_sr);
                    mq_unlink(FILE_PATH_S);
                    printf("[SERVER]:closed!\n");
                    break;
                }


                // open file and read 
                fd=open(buf,O_RDONLY);
                if(-1==fd)
                {
                    char *error_msg=strerror(errno);
                    bzero(buf,mq_msgsize);
                    strcpy(buf,error_msg);
                    
                }else{
                    bzero(buf,mq_msgsize);
                    read(fd,buf,mq_msgsize);
                }

                // send message to client
                mq_send(mq_id_sw,buf,strlen(buf),0);
                close(fd);
            }   
        }
        free(buf);
    }
}
Makefile
CC=gcc

mq_posix:mq_posix.c
	${CC} mq_posix.c -o mq_posix -lrt

演示截图

在这里插入图片描述

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值