ZooKeeper源码解析(7)-请求处理(上)

在前面的文章中,我们分析了Cluster模式的启动过程,以及Zab的实现.

在这篇文章中,我们会详细介绍,ZooKeeper是如何处理每个请求的.

过程

ZooKeeper源码解析(3)-Cluster启动过程解析这篇文章中,我们介绍了,Cluster模式在启动时,会创建一个用户创建ServerCnxnServerCnxnFactory.默认情况下是NIOServerCnxnFactory

这不,在这里,我们再一次用到了NIOServerCnxnFactory

NIOServerCnxnFactoryrun()方法中,

我们可以看到,NIOServerCnxnFactory会根据不同的事件来做不同的事:

  • 如果是SelectionKey.OP_ACCEPT事件,代表客户端请求建立一个新的连接,那么就创建一个NIOServerCnxn并且将其注册到Selector中
  • 如果是SelectionKey.OP_READ | SelectionKey.OP_WRITE事件,那么就找到对应的NIOServerCnxn并执行其doIO()方法.

我们来具体看一下NIOServerCnxndoIO()方法的实现.

在这个方法中,会判断目前发生的到底是SelectionKey.OP_READ事件还是SelectionKey.OP_WRITE事件.

我们先看一下,当发生的是SelectionKey.OP_READ事件时,会如何处理.

其实这里还是蛮难理解的.特别是readLength()这个函数.

其实这段代码的功能,我在注释里已经写的很清楚了.

这段代码的功能,总的来说,就是:

  • 判断客户端执行的是不是monitor command
  • 如果是monitor command,那么在readLength()函数中就进行处理
  • 如果是其他的命令,那么就处理用户请求

这里,我们需要清楚什么是monitor command.

monitor command就是监控命令,就是能够查看Server此时状态的一些命令.这些命令都是四个字符的.

ZooKeeper Administrator's Guide中,我们可以看到,有这么一些Monitor Command

全部的Monitor Command请参考这个列表.

我们可以看到,其中有两个很重要的变量,一个是incomingBuffer,一个是lenBuffer

我们看一下其定义:

我们可以看到,它们开始都是一个capacity为4的ByteBuffer.

我们可以看到,当有读事件时,先将数据的前四个字节读入incomingBuffer

我们可以看到,下面有一个if block,判断语句为是否incomingBuffer == lenBuffer,而从上面的定义中,我们看到,incomingBuffer就是== lenBuffer

其实这里的重点是readLength()方法.

readLength()方法中,我们可以看到,如果前面的条件都通过,那么最后会重新初始化incomingBuffer

其实这段代码,只要记住我上面说的功能,就很容易理解了.

这里也吐槽一下,起的名字这么难理解,而且感觉简单的事情让它给搞复杂了.

如果是Monitor Command,那么在readLength()方法以及后续的方法中,就对它进行处理了.

而如果不是Monitor Command,就要进入到readPayload()方法中处理.

readPayload()方法的主体如下:

我们可以看到,进行如下处理:

  • 如果此时Server还未初始化完成,那么就调用readConnectRequest()方法对ConnectRequest进行处理,然后将initialized设置为true.当然,这些都是readConnectRequest()方法内部做的事情.
  • 如果Server已经初始化完成,那么就调用readRequest()方法进行处理

我们可以看到,在Server未初始化完成之前,还是可以处理ConnectRequest的.

这里我们不深入去看readConnectRequest()的源码,请读者自行查看源码来理解.

我们重点关注readRequest()方法.

在这个方法内部,会调用ZooKeeperServerprocessPacket()方法.

而在processPacket()方法内部,会调用submitRequest()方法,让ZooKeeperServer中的RequestProcessor对请求进行处理.

我们看一下ZooKeeperServersubmitRequest()方法的主体:

那么,RequestProcessor是什么时候被配置的呢?

它是在启动ZooKeeperServer的时候,配置的.

我们看一下ZooKeeper默认配置的RequestProcessor都有哪些.

我们可以看到,其中并没有用于进行Zab算法提议的RequestProcessor

还记得我们在ZooKeeper源码解析(3)-Cluster启动过程解析这篇文章中,提到的,Server在发现自己是Leader之后,会启动一个LeaderZooKeeperServer吗?

没错,就是这里.

我们看看,LeaderZooKeeperServer都设置了哪些RequestProcessor

我们可以看到,其中就有用于Zab算法的提议的RequestProcessor

关于不同的RequestProcessor的介绍,我们会在下一篇文章中介绍.

我们这里主要关注PreRequestProcessor

我们可以看到,它的processRequest()方法的实现,特别简单:

就是非常简单的添加到submittedRequests这个集合中.

那么何时来处理呢?

其实PreRequestProcessor是一个线程,在它启动后,它就会不断从submittedRequest中读取数据,并处理:

主要的处理函数就是pRequest()方法,其实现如下:

上面我们主要介绍了读事件的处理过程,那么写事件呢?

过程也很简单,就是添加一些监控信息,然后将数据发送给客户端就好了.

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

推荐阅读更多精彩内容