Zmq本地进程间传输协议

zmq_ipc: zmq本地进程间的通信传输协议

描述:进程间传输采用与系统相关的IPC机制进行的本地进程间的信息传输

进程间通信方式,目前只能提供Unux定义socket系统上完全的实现

例如:

zmq_bind(socket, "transport://address");

transport://address: 这里的transport所指的要使用的底层的系统协议,address指定了所需要连接的指定地址信息

例如:

zmq_bind(socket, "tcp://*:5556"); //tcp

zmq_bind(socket, "ipc://weather.ipc");  //ipc

对于进程间通信传输,transport指的便是ipc,address任意字符串的文件名,能够唯一标志将要创建的文件

zmq_bind绑定socket:

当zmq_bind()函数进行ipc传输方式绑定一个socket套接字时,终结点可以任意字符串的文件名,能够唯一标志将要创建的文件。文件名应在是在使用ipc通信协议进行操作,这个操作系统名称在空间是唯一的。【注:文件名还必须满足操作系统对正常文件名在格式和长度上的限制】

当地址是*时,例如:zmq_bind(socket, "tcp://*:5556");此时zmq_bind()函数会生成一个临时的文件名

zmq_connect连接socket:

当使用zmq_connect()函数通过ipc向服务端进行连接时,终结点需要一个能够唯一标志文件名的 任意字符串。这个文件名必须已由操作系统创建,并且被分配给了一个已由zmq_bind()函数绑定的socket套接字【注:ipc连接时,若服务端与客户端不在同一个文件夹,客户端连接时,需给定相对应的文件的相对路径】

例如:

    zmq_bind(publisher, "ipc://weather.ipc");

    zmq_connect(subscriber, "ipc://./ZMQ/weather.ipc");

若客户端进行连接时,zmq_connect()函数所连接的地址是*时,此时编译客户端代码OK,但是在执行可执行程序时会存在问题

 

  • 0
    点赞
  • 8
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值