Ubuntu下ZeroMQ安装与使用

一、zmq简介
ZMQ(以下ZeroMQ简称ZMQ)是一个简单好用的传输层,像框架一样的一个socket library,他使得Socket编程更加简单、简洁和性能更高。是一个消息处理队列库,可在多个线程、内核和主机盒之间弹性伸缩。ZMQ的明确目标是“成为标准网络协议栈的一部分,之后进入Linux内核”。现在还未看到它们的成功。但是,它无疑是极具前景的、并且是人们更加需要的“传统”BSD套接字之上的一 层封装。 
可以参考: http://blog.csdn.net/lfsf802/article/details/38238007
官网: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  
可以参考: http://www.jb51.net/article/35383.htm
再次执行server文件:./server
开新窗口再执行client文件:./client
(4)运行结果
服务端:
 
 
客户端:
   
 
————————————————
版权声明:本文为CSDN博主「奔跑的小鱼_」的原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接及本声明。
原文链接:https://blog.csdn.net/xiaoyezi_1834/article/details/51298408

 

 

  • 0
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值