日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當(dāng)前位置: 首頁 > 运维知识 > linux >内容正文

linux

linux zeromq

發(fā)布時間:2024/1/17 linux 52 豆豆
生活随笔 收集整理的這篇文章主要介紹了 linux zeromq 小編覺得挺不錯的,現(xiàn)在分享給大家,幫大家做個參考.

本人在centos下安裝zeromq

?

1.下載最新版的zeromq

? ??http://download.zeromq.org/

2 解壓

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

3 運行configure

? ./configure --prefix=/data/zeromq ?PKG_CONFIG_PATH="/data/sodium/lib/pkgconfig/"? ? (prefix ?指定安裝目錄)

 出現(xiàn)問題:

configure: error: Package requirements (libsodium >= 0.0.0) were not met

參考:
http://www.cnblogs.com/jim-hwg/p/4952349.html

 這里最好使用

libsodium-1.0.3 小于等于版本。
cd /home/shengkaishan/software/libsodium-1.0.3
./configure --prefix=/data/sodium
make
make install

4. make

5. make install

?

c代碼

server.c

#include <zmq.h> #include <stdio.h> #include <unistd.h> #include <string.h> #include <stdlib.h> int main (void) {void *context = zmq_init (1);void *responder = zmq_socket (context, ZMQ_REP);zmq_bind(responder, "tcp://127.0.0.1:5566");while (1) {// Wait for next request from client zmq_msg_t request;zmq_msg_init(&request);zmq_recvmsg(responder, &request, 0);//printf("Received client msg = [%s]\n", (char *)zmq_msg_data(&request)); #if 1 int size = zmq_msg_size(&request);char *msg = (char *)malloc(size + 1);memset(msg, 0, size+1);memcpy(msg, zmq_msg_data(&request), size);printf ("Received Client=[%s]\n", msg);free(msg); #endifzmq_msg_close(&request);// Do some 'work'sleep (1);// Send reply back to client zmq_msg_t reply;zmq_msg_init_data(&reply, "world", 6, NULL, NULL);zmq_sendmsg(responder, &reply, 0);zmq_msg_close(&reply); #if 0zmq_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); #endif}// 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> #include <stdlib.h> int main () { void *context = zmq_init(1);void *requester = zmq_socket(context, ZMQ_REQ); zmq_connect (requester, "tcp://127.0.0.1:5566"); int request_nbr; for (request_nbr = 0; request_nbr != 10; request_nbr++) { zmq_msg_t request;zmq_msg_init_size(&request, 5);//memset(zmq_msg_data(&request), 'H', 5);//memcpy(zmq_msg_data(&request), "Hello", 5); zmq_msg_init_data(&request, "Hello", 5, NULL, NULL); zmq_sendmsg(requester, &request, 0);zmq_msg_close(&request); zmq_msg_t reply; zmq_msg_init(&reply); //zmq_recv(requester, &reply, 0,0); zmq_recvmsg(requester, &reply, 0);//printf ("Received reply %d: [%s]\n", request_nbr, (char *)zmq_msg_data(&reply)); #if 1int size = zmq_msg_size(&reply);char *msg = (char *)malloc(size + 1);memset(msg, 0, size+1);memcpy(msg, zmq_msg_data(&reply), size);printf ("Received Server=[%s]\n", msg);free(msg); #endif zmq_msg_close(&reply); } zmq_close(requester); zmq_term(context); return 0; }

?

?

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

?

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?

?

轉(zhuǎn)載于:https://www.cnblogs.com/kaishan1990/p/5636332.html

總結(jié)

以上是生活随笔為你收集整理的linux zeromq的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網(wǎng)站內(nèi)容還不錯,歡迎將生活随笔推薦給好友。