zoukankan      html  css  js  c++  java
  • zookeeper原理解析-序列化

    1)底层通信数据封装与操作

             

    BinaryInputArchive& BinaryOutputArchive底层通信数据封装与操作

        BinaryInputArchive是对于DataInput的封装,用于处理基于zookeeper协议的底层数据,其实是从DataInputStream输入中读取数据。

        BinaryOutputArchive是对于DataOutput的封装,根据zookeeper协议将数据写入到DataOutputStream中去。

      

          

    1.  读取int, boolean基本数据类型直接代理给DataInput执行

     

       写入int, boolean基本数据类型直接代理给DataOutput执行

     

    2.   读取String和Buffer是,BinaryInputArchive根据Zookeeper协议做了处理

        1) 读取四个字节int值表示读取数据内容的大小

        2) 根据数据大小构建一个byte数组

        3) 将DataInput的数据读取到字节数组中


       

    写入String和Buffer是,BinaryOutputArchive根据Zookeeper协议做了处理

    1) 写入四个字节int值表示写入数据内容的大小, 如果写入数据为null,值为-1

    2)将数据转为字节数组,写入DataOutput中

    3. 读取复杂的数据对象,Zookeeper底层传输的对象都需要实现Record接口,readRecord方法,会代理给Record进行反序列化

            写入复杂的数据对象,Zookeeper底层传输的对象都需要实现Record接口writeRecord方法,会代理给Record进行序列化

           

    4.   对于Record对象中持有集合对象(当然能够序列化与反序列化,集合中的元素必须也实现Record):

    BinaryInputArchive提供startVector

    1)  读取四个字节的int数,表示集合的大小

    2)  构建一个BinaryIndex对象返回

           

           

          BinaryOutputArchive提供startVector

           向DataOutput数据流中写入集合大小,如果为null值为-1

         

     5.  BinaryInputArchive对象的内部类BinaryIndex作用,主要是用来计数集合对象的反序列话的

      

    Record是zookeepr底层通信数据序列化与反序列化统一接口,

    2)Record接口

         

    Record是zookeepr底层通信数据序列化与反序列化统一接口

    1. 继承结构

    子类以Request结尾的是Client向Server发起请求

    子类以Response结尾的是Server向Client发起响应

    子类以Txn结尾是Server向Server发起事务请求的

    子类以Packet结尾是…???

    其他如Id, ACL往往被其他对象持有,不会单独在网络传输

    2. 举例

    1)CreateRequest: 用于在客户端创建一个节点时向服务器端发送的请求

    序列化CreateRequest,

    archive对象是对DataOutput封装,顺序的将数据写入到DataOutputStream输出流中去

    反序列化CreateRequest,

    archive对象是对DataInput封装,顺序的从DataInputStream输入流中中读取数据

          

  • 相关阅读:
    Python爬取Boss直聘,帮你获取全国各类职业薪酬榜
    【深入浅出etcd系列】1. 架构概览
    00041_类与接口的关系
    ASP.NET MVC4 部分视图
    Ueditor编辑器 从word中复制内容带多张图片
    百度Ueditor编辑器 从word中复制内容带多张图片
    百度Ueditor 从word中复制内容带多张图片
    C#.NET实现大文件上传
    .NET实现大文件上传
    asp.net实现大文件上传
  • 原文地址:https://www.cnblogs.com/wxd0108/p/6251700.html
Copyright © 2011-2022 走看看