一、介绍
ZMQ(以下ZeroMQ简称ZMQ)是一个简单好用的传输层,像框架一样的一个socket library,他使得Socket编程更加简单、简洁和性能更高。是一个消息处理队列库,可在多个线程、内核和主机盒之间弹性伸缩。ZMQ的明确目标是“成为标准网络协议栈的一部分,之后进入Linux内核”。现在还未看到它们的成功。但是,它无疑是极具前景的、并且是人们更加需要的“传统”BSD套接字之上的一层封装。
二、安装
1 安装必需库:
$ sudo apt-get install libtool pkg-config build-essential autoconf automake
2 编译安装加密库,ZMQ核心库,ZMQ的C和C++封装,默认安装目录:
头文件都在:usr/local/include
库文件都在:usr/local/lib
2-1 编译安装ZMQ使用的加密库:
$ git clone git://github.com/jedisct1/libsodium.git
cd libsodium
./autogen.sh
./configure && make check
sudo make install
sudo ldconfig
cd ..
2-2 编译安装ZMQ核心库:
git clone https://github.com/zeromq/libzmq
./autogen.sh
./configure && make check
sudo make install
sudo ldconfig
cd ..
由于ZMQ把核心和实现分开了。因此只装核心库是不够的。我们开发一般用C/C++。下面安装这两个语言的绑定库。其他语言参考:http://zeromq.org/bindings:_start
2-3 编译安装ZMQ的C绑定:
git clone git://github.com/zeromq/czmq.git
cd czmq
./autogen.sh
./configure && make check
sudo make install
sudo ldconfig
cd ..
之后就可以编译C绑定的ZMQ程序了:gcc-lczmq -lzmq myapp.c -o myapp
2-4 添加ZMQC++绑定
这个不需要编译安装,只是把一个头文件放到系统包含目录里:
git clone https://github.com/zeromq/cppzmq.git
cd cppzmq
sudo cp zmq.hpp /usr/local/include/
cd ..
3 学习ZMQ。
根据ZMQ官网的guide。下面说一下怎么编译运行例子
git clone https://github.com/imatix/zguide.git
3-1 C的示例:
cd zguide/examples/C
./build all
这样就编译了所有这个目录下的例子。下面运行一个客户服务端例子:
打开两个终端,都进入到zguide/examples/C
T1输入:
./hwserver
T2输入:
./hwclient
三、测试Demo
(1)server端代码:server.cpp
#include <stdio.h>
#include <unistd.h>
#include <string.h>
#include <assert.h>
#include <zmq.h>
int main (void)
{
// Socket to talk to clients
void *context = zmq_ctx_new ();
void *responder = zmq_socket (context, ZMQ_REP);
int rc = zmq_bind (responder, "tcp://*:5555");
assert (rc == 0);
while (1) {
char buffer [10];
zmq_recv (responder, buffer, 10, 0);
printf ("Received Hello\n");
sleep (1); // Do some 'work'
zmq_send (responder, "World", 5, 0);
}
return 0;
}
(2)client端代码:client.cpp
#include <zmq.h>
#include <string.h>
#include <stdio.h>
#include <unistd.h>
int main (void)
{
printf ("Connecting to hello world server…\n");
void *context = zmq_ctx_new ();
void *requester = zmq_socket (context, ZMQ_REQ);
zmq_connect (requester, "tcp://localhost:5555");
int request_nbr;
for (request_nbr = 0; request_nbr != 10; request_nbr++) {
char buffer [10];
printf ("Sending Hello %d…\n", request_nbr);
zmq_send (requester, "Hello", 5, 0);
zmq_recv (requester, buffer, 10, 0);
printf ("Received World %d\n", request_nbr);
}
zmq_close (requester);
zmq_ctx_destroy (context);
return 0;
}
(3) 编译
g++ server.cpp -o server -lzmq
g++ client.cpp -o client -lzmq
四、效果:
参考资料:
https://blog.****.net/qq_16775293/article/details/81119576
https://blog.****.net/xiaoyezi_1834/article/details/51298408