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,但是在执行可执行程序时会存在问题