ZMQ安裝和使用html
ZMQ 並不像是一個傳統意義上的消息隊列服務器,事實上,它也根本不是一個服務器,它更像是一個底層的網絡通信庫,在 Socket API 之上作了一層封裝,將網絡通信、進程通信和線程通信抽象爲統一的 API 接口node
跟 Socket 的區別是:普通的 socket 是端到端的(1:1的關係),而 ZMQ 倒是能夠N:M 的關係,人們對 BSD 套接字的瞭解較多的是點對點的鏈接,點對點鏈接須要顯式地創建鏈接、銷燬鏈接、選擇協議(TCP/UDP)和處理錯誤等,而 ZMQ 屏蔽了這些細節,讓你的網絡編程更爲簡單。ZMQ 用於 node 與 node 間的通訊,node 能夠是主機或者是進程。編程
ZMQ 提供了三個基本的通訊模型,分別是「Request-Reply 「,」Publisher-Subscriber「,」Parallel Pipeline」,具體內容參見http://news.cnblogs.com/n/154000/ubuntu
區別:vim
一、zmq套接字是異步的,能夠實現特定模式服務器
二、TCP是一對一,ZeroMQ是多對多的,能夠根據套接字類型實現一對多,一對一,多對一,或多對多網絡
三、ZeroMQ傳輸消息,TCP傳輸字節異步
四、ZeroMQ 隱藏IO細節,ZeroMQ不在意目的是否存在socket
五、ZeroMQ能夠往多個節點發送數據,能夠從多個節點接收數據tcp
1、安裝
在ubuntu上安裝並測試成功,過程見下:
(1)下載最新的ZeroMQ:http://download.zeromq.org/
(2)解壓:tar -xvf zeromq-4.1.2.tar.gz
(3)編譯
./configure 提示
checking for sodium... no configure: error: Package requirements (libsodium) were not met
解決辦法,暫時先屏蔽掉這個庫:
./configure --prefix=/home/libdev/zmq --without-libsodium //紅色部分路徑能夠去掉 make make install
安裝成功。
二、測試程序
server端:
#include <stdio.h> #include <unistd.h> #include <string.h> #include <assert.h> #include <zmq.h> int main (void) { // Socket to talk to clients void *context = zmq_ctx_new (); void *responder = zmq_socket (context, ZMQ_REP); int rc = zmq_bind (responder, "tcp://*:5555"); assert (rc == 0); while (1) { char buffer [10]; zmq_recv (responder, buffer, 10, 0); printf ("Received Hello\n"); sleep (1); // Do some 'work' zmq_send (responder, "World", 5, 0); } return 0; }
client端:
// Hello World client #include <zmq.h> #include <string.h> #include <stdio.h> #include <unistd.h> int main (void) { printf ("Connecting to hello world server…\n"); /*建立一個新的上下文*/ void *context = zmq_ctx_new (); void *requester = zmq_socket (context, ZMQ_REQ); /*經過tcp協議,5555端口,鏈接本機服務端*/ zmq_connect (requester, "tcp://localhost:5555"); int request_nbr; for (request_nbr = 0; request_nbr != 10; request_nbr++) { char buffer [10]; printf ("Sending Hello %d…\n", request_nbr); zmq_send (requester, "Hello", 5, 0); zmq_recv (requester, buffer, 10, 0); printf ("Received World %d\n", request_nbr); } zmq_close (requester); zmq_ctx_destroy (context); return 0; }
編譯:注意加上動態庫
gcc hwserver_.c -o hwserver -lzmq
gcc hwclient_.c -o hwclient -lzmp
運行:出現以下錯誤
[root@localhost hwserver]# ./hwserver ./hwserver: error while loading shared libraries: libzmq.so.5: cannot open shared object file: No such file or directory
解決辦法:加上zmq.so的路徑:
sudo find ./ -depth -name "libzmq.so" -print //找出動態庫路徑 cd /etc sudo vim ld.so.conf // include /usr/local/lib //把zmq.so的路徑加進來 ldconfig //記住執行這句話
而後啓動hwserver和hwclient,執行結果以下所示:
參考:http://www.cnblogs.com/Anker/p/4706244.html