posix版:http://download.zeromq.org/zeromq-2.1.7.tar.gz
win版:http://download.zeromq.org/zeromq-2.1.7.zip
2.安装
tar -zxvf zeromq-2.1.7.tar.gz
cd zeromq-2.1.7
ls
./configure --prefix=/data/zeromq
make
make install
3.测试
服务端测试代码,服务端服务器上的zmq是按照默认目录安装,因此和下面的client.c的编译不一样:
/*gcc server.c -o server -lzmq
./server
接收客户消息,并回复随机数字
*/ #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);
//监听5555端口
zmq_bind (responder, "tcp://*: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);
//接收客户端消息
zmq_recv (responder, &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));
//发送
zmq_send (responder, &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;
}
客户端代码,若是server和客户端端不是同一台机器,需要把localhost改为server的ip:
/* gcc client.c -o client -lzmq -L/data/zeromq/lib -I/data/zeromq/include
./client "I am jack"
向服务器发送消息,并打印回复消息 */ #include <zmq.h>
#include <string.h>
#include <stdio.h>
#include <unistd.h>
#include <stdlib.h>
int main (int argc,char**argv)
{
//参数1为要发送的消息
if(argc < 2){
printf("need send msg\n");
return 1;
}
void *context = zmq_init (1);
// Socket to talk to server
printf ("Connecting to hello world server...\n");
//连接server
void *requester = zmq_socket (context, ZMQ_REQ);
zmq_connect (requester, "tcp://localhost:5555");
int request_nbr=0;
for (request_nbr = 0; request_nbr != 10; request_nbr++) {
//构建发送消息
zmq_msg_t request={0};
//申请消息的空间
zmq_msg_init_size (&request, strlen(argv[1]));
//填充消息
memcpy (zmq_msg_data (&request), argv[1], strlen(argv[1]));
printf ("Sending Hello %d\n", request_nbr);
//发送消息
zmq_send (requester, &request, 0);
zmq_msg_close (&request);
//准备接收回复
zmq_msg_t reply={0};
zmq_msg_init (&reply);
//接收回复
zmq_recv (requester, &reply, 0);
//读取回复消息
int size = zmq_msg_size (&reply);
char *string = malloc (size + 1);
memset(string,0,size+1);
memcpy (string, zmq_msg_data (&reply), size);
printf ("recv from server string=[%s]\n",string);
free(string);
zmq_msg_close (&reply);
}
zmq_close (requester);
zmq_term (context);
return 0;
}