ZeroMQ分享-part1

1. ZeroMQ背景知识(version-4.2.0)

ZMQ(以下ZeroMQ简称ZMQ)是一个简单好用的、轻量级的消息组件,像框架一样的一个socket library。它的本质是个消息处理队列库,在BSD socket基础上做了一层封装,将网络通讯、进程通讯和线程通讯抽象为统一的接口,可在多个线程、内核和主机盒之间弹性伸缩。

2. ZMQ的几种模型

  • Client-server模型(http://rfc.zeromq.org/spec:41/CLISRV/)
    • client端可以连接一个或多个server。当连接到多个server时,发送数据采用轮询的方式;接收数据采用公平队列按序接收。
    • client端在没有可用连接时会阻塞,或者返回错误。(除非特殊配置)
    • server端可以连接0或多个client。它只能回复client的请求信息,应答数据会送到指定的client端。接收数据采用公平队列按序接受。
    • server端应答时,若client端接收队列已满,会马上返回(重试),不会阻塞。
    • 任何一对client-server都是全双工的,每端都会维护两个队列用于收发数据。
    • 无论哪端,都不会因为不能入队列丢弃消息。
    • client和server套接字是线程安全的。
  • Publish-subscribe模型(http://rfc.zeromq.org/spec:29)
    • pub端向一系列sub或xsub端广播数据,并且只发数据,会丢弃所有从sub端(一般是xsub)发送过来的数据。
    • pub端在sub端接收队列已满的情况下,会丢弃发送数据,不会堵塞。
    • pub端会将数据发送到所有订阅消息的sub端。
    • xpub拓展了pub,可以从同时收发数据。在接收数据时,会将订阅和非订阅的sub端数据提交给应用程序。
    • sub端连接了任意多个pub或xpub端,只会接收数据(除向pub端发送订阅非订阅外),采用公平队列策略。
    • xsub拓展了sub,可以同时收发数据。在pub端接收队列已满的情况下,会丢弃所发送的数据,不会阻塞。
  • Pipline模型(http://rfc.zeromq.org/spec:30)
    • push端采用轮询的方式向任意多个pull端发送数据。
    • push端在没有可用连接时,发送数据会阻塞,或者返回一个错误。
    • push端在无可用连接时不会接收应用程序的数据,因此不会丢弃数据。
    • pull端采用公平队列的方式接收一系列push端的数据。
    • push端不能接收数据,同样,pull端不能发送数据。
  • Exclusive pair模型(http://rfc.zeromq.org/spec:31)
    • peer两端互连,一个用于进程间通讯的模型
    • 当peer进入静音模式时(缓冲区满或未建立连接),任何一方的发送数据都会被阻塞,因此不会丢弃数据。
  • Native模型
    • 用于TCP连接两端进行异步请求和应答的模型。
    • 在将接收到的数据传递给应用程序之前,socket会提前准备一个包含数据发送端id的消息。
    • 在发送消息时,会移除消息的第一部分用于路由选择,再将剩余的消息发送到指定id的接收端。不能路由的消息会返回错误信息并发送失败。
// Create a new ZMQ context
void *context = zmq_ctx_new();
// For client-server pattern
void *client_receiver = zmq_socket(context, ZMQ_CLIENT)
void *server_receiver = zmq_socket(context, ZMQ_SERVER)
// For publish-subscribe pattern
void *pub_receiver = zmq_socket(context, ZMQ_PUB)
void *xpub_receiver = zmq_socket(context, ZMQ_XPUB)
void *sub_receiver = zmq_socket(context, ZMQ_SUB)
void *xsub_receiver = zmq_socket(context, ZMQ_XSUB)
// For pipeline pattern
void *push_receiver = zmq_socket(context, ZMQ_PUSH)
void *pull_receiver = zmq_socket(context, ZMQ_PULL)
// For exclusive pair pattern
void *pair_receiver = zmq_socket(context, ZMQ_PAIR)
int rc;
rc = zmq_bind(pair_receiver, "inproc://#1")
assert(rc == 0);
rc = zmq_connect(pair_receiver, "inproc://#1")
assert(rc == 0);

// Native pattern
void *stream_receiver = zmq_socket(context, ZMQ_STREAM)

3. I/O模型

  • (同步)阻塞式I/O模型
    • 默认情形下,所有的socket都是阻塞的。以用户线程在内核进行IO操作为例,用户在发起read系统调用后发生阻塞,转到内核空间,内核等到数据到达后将数据拷到用户空间,完成操作,线程返回。如下图所示:


      阻塞式I/O模型
  • (同步)非阻塞式I/O模型
    • 通过将socket设置为非阻塞式的,可以在IO不能立即响应时返回一个错误,此时并没有数据返回。用户线程需不断重复发起IO请求,直到数据到达后才能得到真正的数据,剩余部分和阻塞式I/O相同。如下图所示:


      非阻塞式I/O模型
    • 非阻塞式I/O模型一般很少直接使用,往往实在其他模型中使用非阻塞这一特性。因为该模型需要反复发起IO请求,消耗了大量的CPU资源。
  • (同步)I/O复用模型
    • 建立在内核提供的select基础之上,可以避免非阻塞式I/O模型中轮询等待的问题。与阻塞式I/O不同,I/O复用模型会阻塞在select或poll调用处,直到等待的套接字中有变为可读的。如下图所示:


      I/O复用模型
  • 异步I/O模型
    • 异步I/O需要操作系统更强的支持,与I/O复用不同,异步I/O不需要用户线程自行读取数据、处理数据,而是讲这些工作讲给操作系统完成,只接收内核通知I/O事件已经完成。如下图所示:


      异步I/O模型
    • 异步I/O中,用户需要自行编写处理数据的回调程序并递交给操作系统。相比较于I/O复用,异步I/O并十分常用。很多高性能并发服务器使用I/O复用加多线程任务处理的架构基本可以满足需求。
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 216,039评论 6 498
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 92,223评论 3 392
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 161,916评论 0 351
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 58,009评论 1 291
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 67,030评论 6 388
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 51,011评论 1 295
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,934评论 3 416
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,754评论 0 271
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 45,202评论 1 309
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,433评论 2 331
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,590评论 1 346
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,321评论 5 342
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,917评论 3 325
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,568评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,738评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,583评论 2 368
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,482评论 2 352

推荐阅读更多精彩内容