`
youzifei
  • 浏览: 66718 次
  • 性别: Icon_minigender_1
  • 来自: 北京
文章分类
社区版块
存档分类
最新评论

zeromq 安装

阅读更多

 

今天在安装zeromq的时候费了好大的力气才算装好

 

下面来回顾一下在linux安装zeromq的过程

首先

http://download.zeromq.org/

1.下载最新版的zeromq

    http://download.zeromq.org/zeromq-3.1.0-beta.tar.gz

2 解压

    tar -xvf zeromq-3.1.0-beta.tar.gz

3 运行configure

    ./configure --prefix=/data/zeromq     (prefix  指定安装目录)

4. make

5. make install

6. 设置环境变量

    export CPPFLAGS=-I/home/mine/0mq/include/

    export LDFLAGS=-L/home/mine/0mq/lib/

 

7.测试代码

server.c

#######################################

#include </data/zeromq/include/zmq.h>

#include <stdio.h>

#include <unistd.h>

#include <string.h>

#include <stdlib.h>

int main (void)

{

    void *context = zmq_init (1);

// Socket to talk to clients

    void *responder = zmq_socket (context, ZMQ_REP);

    zmq_bind (responder, "tcp://192.168.0.185:5555");

    printf("binding on port 5555.\nwaiting client send message...\n");

    while (1) {

        // Wait for next request from client

        zmq_msg_t request;

        zmq_msg_init (&request);

        char buf[32];

        zmq_recv (responder,buf, &request, 0);

        int size = zmq_msg_size (&request);

        char *string = malloc (size + 1);

        memset(string,0,size+1);

        memcpy (string, zmq_msg_data (&request), size);

        printf ("Received Hello string=[%s]\n",string);

        free(string);

        zmq_msg_close (&request);

        // Do some 'work'

        sleep (1);

        // Send reply back to client

        zmq_msg_t reply;

        char res[128]={0};

        snprintf(res,127,"reply:%d",random());

        zmq_msg_init_size (&reply, strlen(res));

        memcpy (zmq_msg_data (&reply), res, strlen(res));

        char buf2[32];

        zmq_send (responder, buf2, &reply, 0);

        zmq_msg_close (&reply);

    }

    // We never get here but if we did, this would be how we end

    zmq_close (responder);

    zmq_term (context);

    return 0;

}

 

 

########################################################

#client.c

#include <zmq.h> 

#include <string.h> 

#include <stdio.h> 

#include <unistd.h>  

int main () 

{     

 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://192.168.0.185:5555");       

 int request_nbr;     

 for (request_nbr = 0; request_nbr != 10; request_nbr++) 

 {         

  zmq_msg_t request;         

  zmq_msg_init_data (&request, "Hello", 6, NULL, NULL);         

  printf ("Sending request %d...\n", request_nbr);         

  zmq_send (requester, &request, 0,0); 

  printf("send over")      ; 

  zmq_msg_close (&request);           

  zmq_msg_t reply;         

  zmq_msg_init (&reply);         

  zmq_recv (requester, &reply, 0,0);         

  printf ("Received reply %d: [%s]\n", request_nbr, (char *) zmq_msg_data (&reply));         

  zmq_msg_close (&reply);     

 }     

 zmq_close (requester);     

 zmq_term (context);     

 return 0; 

}

 

gcc server.c -o server -lzmq   -L/data/zeromq/lib -I/data/zeromq/include 

gcc client.c -o client -lzmq   -L/data/zeromq/lib -I/data/zeromq/include 

 

./server

./client

 

 

 

jzmq 是zeromq 的java客户端

 

下载地址

https://github.com/zeromq/jzmq/downloads

 

1. tar xzf zeromq-jzmq-semver-90-g58c6108.tar.gz

2. ./configure

   这个时候需要上面环境变量的配置,

   还需要

   随便  

    vi /data/zeromq/.bashrc

 

    export PATH=$PATH:/data/zeromq/include

    export LD_LIBRARY_PATH=$LD_LIBRARY_PATH:/data/zeromq/lib:/data/zeromq/include

 

    只要configure 执行完毕就会生成makefile文件

3.make

4.make install

测试

 

hwserver.java

 

//

//  Hello World server in Java

//  Binds REP socket to tcp://*:5555

//  Expects "Hello" from client, replies with "World"

//

//  Naveen Chawla <naveen.chwl@gmail.com>

//

import org.zeromq.ZMQ;

 

public class hwserver {

    public static void main(String[] args) {

        //  Prepare our context and socket

        ZMQ.Context context = ZMQ.context(1);

        ZMQ.Socket socket = context.socket(ZMQ.REP);

        socket.bind ("tcp://*:5555");

 

        while (true) {

            byte[] request;

 

            //  Wait for next request from client

            //  We will wait for a 0-terminated string (C string) from the client,

            //  so that this server also works with The Guide's C and C++ "Hello World" clients

            request = socket.recv (0);

            //  In order to display the 0-terminated string as a String,

            //  we omit the last byte from request

            System.out.println ("Received request: [" +

            new String(request,0,request.length-1)  //  Creates a String from request, minus the last byte

            + "]");

 

            //  Do some 'work'

            try {

                Thread.sleep (1000);

            }

            catch(InterruptedException e){

                e.printStackTrace();

            }

 

            //  Send reply back to client

            //  We will send a 0-terminated string (C string) back to the client,

            //  so that this server also works with The Guide's C and C++ "Hello World" clients

            String replyString = "World" + " ";

            byte[] reply = replyString.getBytes();

            reply[reply.length-1]=0; //Sets the last byte of the reply to 0

            socket.send(reply, 0);

        }

    }

}

 

 

 

hwclient.java

 

//

//  Hello World client in Java

//  Connects REQ socket to tcp://localhost:5555

//  Sends "Hello" to server, expects "World" back

//

//  Naveen Chawla <naveen.chwl@gmail.com>

//

import org.zeromq.ZMQ;

 

public class hwclient{

    public static void main(String[] args){

        //  Prepare our context and socket

        ZMQ.Context context = ZMQ.context(1);

        ZMQ.Socket socket = context.socket(ZMQ.REQ);

 

        System.out.println("Connecting to hello world server...");

        socket.connect ("tcp://localhost:5555");

 

        //  Do 10 requests, waiting each time for a response

        for(int request_nbr = 0; request_nbr != 10; request_nbr++) {

            //  Create a "Hello" message.

            //  Ensure that the last byte of our "Hello" message is 0 because

            //  our "Hello World" server is expecting a 0-terminated string:

            String requestString = "Hello" + " ";

            byte[] request = requestString.getBytes();

            request[request.length-1]=0; //Sets the last byte to 0

            // Send the message

            System.out.println("Sending request " + request_nbr + "...");

            socket.send(request, 0);

 

            //  Get the reply.

            byte[] reply = socket.recv(0);

            //  When displaying reply as a String, omit the last byte because

            //  our "Hello World" server has sent us a 0-terminated string:

            System.out.println("Received reply " + request_nbr + ": [" + new String(reply,0,reply.length-1) + "]");

        }

    }

}

 

javac -classpath /data/jzmq/share/java/zmq.jar -d . h*.java

 

java -Djava.library.path=/data/jzmq/lib -cp /data/jzmq/share/java/zmq.jar:. hwserver

java -Djava.library.path=/data/jzmq/lib -cp /data/jzmq/share/java/zmq.jar:. hwclient

 

显示内容:

 

server端

Received request: [Hello]

Received request: [Hello]

Received request: [Hello]

Received request: [Hello]

Received request: [Hello]

Received request: [Hello]


client端
Connecting to hello world server...
Sending request 0...
Received reply 0: [World]
Sending request 1...
Received reply 1: [World]
Sending request 2...
Received reply 2: [World]
Sending request 3...
Received reply 3: [World]
Sending request 4...
Received reply 4: [World]
Sending request 5...

 

 

分享到:
评论
1 楼 qianshangding 2013-12-28  
请问zeromq是在哪里启动啊,找了半天没找到

相关推荐

    zeromq安装编译

    本篇文章将深入探讨zeromq的安装与编译过程,并基于提供的资源进行解析。 首先,zeromq的安装通常分为两部分:库文件的获取与编译,以及对应的开发头文件和库的安装。在Windows环境下,可以使用预编译的二进制版本...

    消息队列zeromq学习的安装包之一libsodium

    安装好libsodium后,接着安装zeromq。这个过程也包括下载、解压、配置、编译和安装几个步骤。安装完成后,你可以通过编写简单的示例程序来测试zeromq的功能,例如创建一个发布者和一个订阅者,看看消息是否能正确地...

    zeromq-2.1.7.tar.gz

    默认情况下,这会将ZeroMQ安装到 `/usr/local` 目录下。 5. **验证安装**: 安装完成后,可以通过运行测试程序或简单地查看安装的库和头文件来确认安装是否成功。 ZeroMQ支持多种协议,如PUB/SUB(发布/订阅)、...

    zeromq-3.2.4.tar.gz

    4. 可选地,运行`make install`将zeromq安装到系统路径,以便其他程序能方便地找到和使用。 5. 在自己的项目中通过包含zeromq的头文件和链接库,编写利用zeromq进行通信的代码。 zeromq的特性包括: - 高性能:...

    zeromq-2.1.9.tar.gz

    4. **安装**:最后,使用`sudo make install`将zeromq安装到系统路径中,通常为`/usr/local`: ```bash sudo make install ``` 在Linux环境中,zeromq可以与多种编程语言配合使用,如C、C++、Python、Java等,...

    zeroMQ初体验

    3. **编译与安装**:执行`make`命令编译源码,然后运行`make install`将编译好的ZeroMQ安装到指定目录。 **测试ZeroMQ** 为了验证ZeroMQ是否安装成功,可以使用官方提供的示例代码进行测试。这些示例代码涵盖了...

    消息队列zeromq4.1.8版本安装包

    5. 使用`sudo make install`命令将zeromq安装到系统路径。 6. 安装相应的语言绑定,如`pip install pyzmq`(Python)或`gem install ffi-rzmq`(Ruby)。 在编程中,使用zeromq需要理解其API,并根据你的需求选择...

    zeromq-4.1.5.tar.gz

    6. **安装到系统路径**:使用`sudo make install`将ZeroMQ安装到系统路径,通常为`/usr/local`。 7. **设置环境变量**:将ZeroMQ的库路径添加到`LD_LIBRARY_PATH`,例如`export LD_LIBRARY_PATH=$LD_LIBRARY_PATH:/...

    zeromq的windows版本安装包

    “ZMQ(以下ZeroMQ简称ZMQ)是一个简单好用的传输层,像框架一样的一个socket library,他使得Socket编程更加简单、简洁和性能更高。是一个消息处理队列库,可在多个线程、内核和主机盒之间弹性伸缩。ZMQ的明确目标是...

    ZeroMQ4.3.4

    在Win10上安装并使用MingW编译ZeroMQ4.3.4的步骤大致包括: 1. 安装MingW:下载并安装MingW,配置环境变量,使其包含在PATH中。 2. 获取ZeroMQ源代码:从官方仓库或者镜像站点下载ZeroMQ4.3.4的源码包。 3. 解压源码...

    zeromq简易demo搭建(java版本)

    zeromq简易demo搭建(java版本)是针对Java开发者介绍如何使用ZeroMQ这一高效的消息队列库进行简单应用开发的教程。ZeroMQ,也被称为ØMQ、0MQ或 ...记得在运行代码之前,确保已正确安装和配置ZeroMQ及其Java绑定库。

    CentOS7下编译的zeromq 4.3.1版本静态和动态库

    在CentOS7环境下编译zeromq 4.3.1版本,涉及到的知识点包括C++编程、Linux系统管理、开源软件安装以及库的编译与链接。 1. **C++编程**:zeromq是用C++编写的,因此理解和使用它的API需要对C++有一定的掌握。这包括...

    zeromq-4.3.2.zip

    4. **构建脚本**:用于在不同平台上编译和安装ZeroMQ的脚本,如`configure`、`makefile`等。 5. **测试套件**:一组自动化测试用例,用于验证ZeroMQ的功能和性能。 要编译和使用ZeroMQ 4.3.2,你需要遵循以下步骤:...

    ZeroMQ(java)window库

    ZeroMQ(以下ZeroMQ简称ZMQ)是一个简单好用的传输层,像框架一样的一个socket library,他使得Socket编程更加简单、简洁和性能更高。(摘自百度百科) ZMQ官方网址http://zeromq.org/ ZMQ本身只提供了C++版本的下载,...

    ZEROmq实例

    3. **安装和配置**:在Windows环境下,我们需要下载ZeroMQ的二进制包,并配置环境变量,确保编译器能够找到ZeroMQ的头文件和库文件。 4. **Visual Studio集成**:在VS项目中,我们需要添加对ZeroMQ库的引用,并配置...

    ZeroMQ及java绑定

    在使用zeromq-3.2.1这个压缩包时,你需要确保你的系统已经安装了Java运行环境(JRE),并将包含libzmq.dll和jzmq.dll的“lib”目录添加到系统的PATH环境变量中。这样,Java运行时环境就能够找到并加载这些库文件。...

    ZeroMQ中文说明文档带目录

    1. **安装与配置**:在各种操作系统上,可以通过包管理器或者源代码编译来安装ZeroMQ。配置包括设置环境变量,如`ZMQ_PREFIX`和`ZMQ_LIB_DIR`,以及编译选项。 2. **编程接口**:ZeroMQ提供了多种语言的API,如C++...

    ZeroMQ网上收集中文文档

    读者将学习到如何安装ZeroMQ的C#绑定库(如 czmq 或 NetMQ),创建和配置C# socket对象,以及如何利用这些对象进行消息的发送和接收。此外,这个文档可能还会包含一些示例代码,演示如何在实际项目中应用ZeroMQ,...

    zeromq网络开发库

    在使用"zeromq-3.2.3"时,你需要先安装ZeroMQ库,然后根据你的编程语言选择相应的绑定库,如pyzmq(Python)、czmq(C++)等。之后,你可以创建Socket对象并指定其类型,比如创建一个PUB类型的Socket来发布消息,...

Global site tag (gtag.js) - Google Analytics