红联Linux门户
Linux帮助

Ubuntu下ZeroMQ安装与使用

发布时间:2016-05-03 10:59:29来源:linux网站作者:奔跑的小鱼_

一、zmq简介
ZMQ(以下ZeroMQ简称ZMQ)是一个简单好用的传输层,像框架一样的一个socket library,他使得Socket编程更加简单、简洁和性能更高。是一个消息处理队列库,可在多个线程、内核和主机盒之间弹性伸缩。ZMQ的明确目标是“成为标准网络协议栈的一部分,之后进入Linux内核”。现在还未看到它们的成功。但是,它无疑是极具前景的、并且是人们更加需要的“传统”BSD套接字之上的一层封装。

官网:http://zeromq.org/


二、ubuntu下zmq安装
(1)下载zmq:wget http://download.zeromq.org/zeromq-4.1.4.tar.gz  (可以将“4.1.4”改成当前最新版本编号)
(2)解压:tar -zxvf zeromq-4.1.4.tar.gz
(3)编译安装
A.执行configure文件:./configure
出现错误:
configure: error: Package requirements (libsodium) were not met:
No package 'libsodium' found
解决方案:忽略这个库
./configure --prefix=/home/ygy/zmq --without-libsodium(prefix中的路径是zmq存放的目录)
B.编译:make
C.安装:make install


三、样例程序
(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 -I./include -L./lib
g++ client.cpp -o client -lzmq -I./include -L./lib
(4)运行程序
先运行server端:./server
出现错误:
./server: error while loading shared libraries: libzmq.so.5: cannot open shared object file: No such file or directory
解决方案:
找出libzmq.so所在路径:sudo find ./ -depth -name "libzmq.so" -print
方案一:需要root权限,永久有效
将找到的路径写入ld.so.conf文件中:echo "填入所找到的路径" >> /etc/ld.so.conf
重新加载配置文件:ldconfig
方案二:无需root权限,临时有效
export LD_LIBRARY_PATH=填入所找到的路径:$LD_LIBRARY_PATH
再次执行server文件:./server
开新窗口再执行client文件:./client
(4)运行结果
服务端:

Ubuntu下ZeroMQ安装与使用

客户端:

Ubuntu下ZeroMQ安装与使用


本文永久更新地址:http://www.linuxdiyf.com/linux/20300.html