利用管道命名锁,实现进程间名称的不同

本文介绍了如何利用管道命名锁来实现在不同进程中保持Kafka流消费组的独立性,即使在系统重启后,也能确保每个组能从历史节点继续读取数据。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

场景,比如需要不同的group消费一个流(kafa),但是重启又希望能继续使用历史节点读取。

#include <unistd.h>
#include <stdlib.h>
#include <fcntl.h>
#include <limits.h>
#include <sys/types.h>
#include <sys/stat.h>
#include <stdio.h>
#include <string.h>
#include <sstream>
#include <iostream>
#include <dirent.h>
const int max_process_num = 10;
static const char qbus_head [] = "qbus_group+host";
std::string createGroupId(){
    int i = 0;

    std::stringstream ss;
    std::string fifo_name;
    for(;i<max_process_num;i++){
        ss<<qbus_head<<i;
        fifo_name = ss.str();
        if(access(fifo_name.c_str(),F_OK) == -1){
            int res = mkfifo(fifo_name.c_str(),0777);
            if(res!=0){
                printf("Could not create fifo %s\n",fifo_name.c_str());
            }else
                break;
        }
        ss.str("");
    }
    return fifo_name;
}


int main(){
    std::string id1 = createGroupId();
    std::string id2 = createGroupId();
    std::string id3 = createGroupId();
    std::string id4 = createGroupId();
    printf("id1:%s\n",id1.c_str());
    printf("id2:%s\n",id2.c_str());
    printf("id3:%s\n",id3.c_str());
    printf("id4:%s\n",id4.c_str());
    sleep(1);
    remove(id1.c_str());//rm -f file
    //closedir(id2.c_str());
}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值