Linux下编译并使用ZeroMQ

(1)下载ZeroMQ以及头文件zmq.hpp

ZeroMQ:http://download.zeromq.org/

zmq.hpp:https://github.com/zeromq/cppzmq/archive/master.zip

(2)编译生成动态库

 1.解压

tar -xvf zeromq-4.1.2.tar.gz
2.编译

cd zeromq-4.1.2
./configure --prefix=/home/libdev/zmq --without-libsodium
make && make install

如果第二步报错:


则执行以下命令:

./configure --prefix=/home/libdev/zmq --without-libsodium
3.示例以及编译、运行

服务端:Server

hwserver.cpp
#include <zmq.hpp>
#include <string>
#include <iostream>
#include <unistd.h>

int main () {
    // Prepare our context and socket
    zmq::context_t context (1);
    zmq::socket_t socket (context, ZMQ_REP);
    socket.bind ("tcp://*:5555");

    while (true) {
        zmq::message_t request;

        // Wait for next request from client
        socket.recv (&request);
        std::cout << "Received Hello" << std::endl;

        // Do some 'work'
        sleep (1);

        // Send reply back to client
        zmq::message_t reply (5);
        memcpy ((void *) reply.data (), "World", 5);
        socket.send (reply);
    }
    return 0;
}

客户端:Client

hwclient.cpp
<span style="font-size:18px;">//
// Hello World client
// Connects REQ socket to tcp://localhost:5555
// Sends "Hello" to server, expects "World" back
//
#include <zmq.h>
#include <string.h>
#include <stdio.h>
#include <unistd.h>

int main (void)
{
    void *context = zmq_init (1);

    // Socket to talk to server
    printf ("Connecting to hello world server…\n");
    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++) {
        zmq_msg_t request;
        zmq_msg_init_size (&request, 5);
        memcpy (zmq_msg_data (&request), "Hello", 5);
        printf ("Sending Hello %d…\n", request_nbr);
        zmq</span><span style="font-family: Arial, Helvetica, sans-serif;"><span style="font-size:12px;">_msg</span></span><span style="font-size:18px;">_send (&request, requester, 0);
        zmq_msg_close (&request);

        zmq_msg_t reply;
        zmq_msg_init (&reply);
        zmq_msg_recv (&reply, requester, 0);
        printf ("Received World %d\n", request_nbr);
        zmq_msg_close (&reply);
    }
    zmq_close (requester);
    zmq_term (context);
    return 0;
}</span>
编译命令:

g++ -g -Wall -fPIC -I/home/libdev/zmq/include -L/home/libdev/zmq/lib -lzmq hwserver.cpp -o server 
g++ -g -Wall -fPIC -I/home/libdev/zmq/include -L/home/libdev/zmq/lib -lzmq hwclient.cpp -o client

如果编译出错,请下载zmq.hpp放入zmq安装目录的include目录下

4.运行

./server


./client


  • 3
    点赞
  • 22
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

TechGenius

文章很值,请作者喝一杯咖啡吧!

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值