今天在安装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...

(转)zeromq 安装的更多相关文章

  1. ZeroMQ安装

    一.ZeroMQ介绍 ZeroMQ是一个开源的消息队列系统,按照官方的定义,它是一个消息通信库,帮助开发者设计分布式和并行的应用程序. 首先,我们需要明白,ZeroMQ不是传统的消息队列系统(比如Ac ...

  2. ZeroMQ安装说明

    ZeroMQ安装说明 1.   安装 1.1.Linux zmq安装 安装过程参考地址:http://zeromq.org/intro:get-the-software的说明 安装步骤如下(在安装时参 ...

  3. ZeroMQ 在 centos 6.5_x86_64 下的安装

    ZeroMQ 在 centos 6.5_x86_64 下的安装 作者:chszs,转载需注明.博客主页:http://blog.csdn.net/chszs 一.ZeroMQ介绍 ZeroMQ是一个开 ...

  4. storm安装(2)ZeroMQ、JZMQ、Python、Java环境的安装

    2.ZeroMQ安装 把安装本件zeromq-2.1.7.tar.gz拷贝到home文件路径下, 给文件加入权限 chmod +x /home/zeromq-2.1.7.tar.gz 解压文件 tar ...

  5. Linux下zeromq.js安装

    本文章主要阐述在离线环境下安装zeromq.js的方法和步骤.zeromq.js下载地址: https://www.npmjs.com/package/zeromq或者 https://github. ...

  6. zeromq的安装,部署(号称最快的消息队列,消息中间件)

    1:Storm作为一个实时处理的框架,产生的消息需要快速的进行处理,比如存在消息队列ZeroMQ里面. 由于消息队列ZeroMQ是C++写的,而我们的程序是运行在JVM虚拟机里面的.所以需要jzmq这 ...

  7. 【Linux】ZeroMQ 在 centos下的安装

    转自:http://www.cnblogs.com/mjorcen/p/4479642.html 一.ZeroMQ介绍 ZeroMQ是一个开源的消息队列系统,按照官方的定义,它是一个消息通信库,帮助开 ...

  8. linux 下 php 安装 ZeroMQ 扩展

    一.下载安装源码包 ZeroMQ源码包下载地址: http://zeromq.org/area:download 如:zeromq-4.1.4.tar.gz   php的zmq扩展源码包 https: ...

  9. Twitter Storm安装配置(Ubuntu系统)单机版

    要使用storm首先要安装以下工具:JDK.Python.zookeeper.zeromq.jzmq.storm (注:各个模块都是独立的,如果安装失败或者卡顿可以单独百度某个模块的安装,都是可以的. ...

随机推荐

  1. [codeforces] 17E Palisection

    原题 题目要求相交的回文串对数,这显然非常难,但是要有一种正难则反的心态,求不出来相交的,求出来不相交的不就好了! 对于每以位置i结尾的字符串,在他后面与他不相交的就是以这个位置为结尾的个数和以这个位 ...

  2. 深入研究JavaScript的事件机制

    本篇开始将回顾下Javascript的事件机制.同时会从一个最小的函数开始写到最后一个具有完整功能的,强大的事件模块.为叙述方便将响应函数/回调函数/事件Listener/事件handler都称为事件 ...

  3. JAVA List 一边遍历一边删除元素

    JAVA List 一边遍历一边删除元素,报java.util.ConcurrentModificationException异常 2015年02月10日 14:42:49 zhanzkw 阅读数:3 ...

  4. 如何把阿里云的服务器配置为mac的共享文件夹(亲测有效)

    写在开头的就是,我只能百分之九十确定这个是真的有效....毕竟试了太多的方法,最后莫名其妙的就好了.. - -# 基础的步骤就不说了,网上一搜一大把,大家可能follow了所有的步骤以后发现还是连接不 ...

  5. bzoj 1124 [POI2008]枪战Maf 贪心

    [POI2008]枪战Maf Time Limit: 10 Sec  Memory Limit: 162 MBSubmit: 741  Solved: 295[Submit][Status][Disc ...

  6. [04] css 选择器

    1.元素选择器 常见的html标签元素 h1 { color: red; } body { background: red; } 2.分组选择器 例如body和h2标签的字体颜色都是red,使用逗号将 ...

  7. vue遇到的坑(一)——数组更新

    最近在项目中遇到个问题,数组已经更新了,但是页面中的DOM并没有触发变化.我一直以来的想法就是: 既然vue实现的实时数据双向绑定,那么在model层发生了变化之后为什么就没有在view层更新呢? 在 ...

  8. 【BZOJ2527】【POI2011】Meteors [整体二分]

    Meteors Time Limit: 60 Sec  Memory Limit: 128 MB[Submit][Status][Discuss] Description 这个星球经常会下陨石雨.BI ...

  9. 01-UIDynamic简单演练demo源代码

    源代码下载: 01-简单演练.zip72.0 KB // //  ViewController.m //  01.简单演练 // //  Created by apple on 13-12-24. / ...

  10. bzoj 1064 图论

    我们根据能否看见建图,有向图边权设成1,然后我们转成无向图, 对于每条有向边连一条反边,边权是-1,然后从每个块中任意一个点开始 dfs,每个点有一个值,经过一条边到另一个点之后,用原来的点值和边权 ...