java jute_ZooKeeper源码阅读(六):JUTE

java jute_ZooKeeper源码阅读(六):JUTEZooKeeper 中的 Leader 选举也不是 Paxos 实现相关的类包括 FastLeaderEl LeaderElecti FastLeaderEl Leader 选举初始投票选自己 收到别人的投票之后判断是否 JUTE 是跨语言序列化 反序列化工具 类似 Thrift 用于产生 java c 版本的消息类比如 zkDataBase addCommitted

[ZooKeeper中的Leader选举也不是Paxos, 实现相关的类包括FastLeaderElection, LeaderElection.FastLeaderElection: Leader选举初始投票选自己,收到别人的投票之后判断是否

JUTE是跨语言序列化/反序列化工具,类似Thrift

用于产生java/c版本的消息类

比如:

zkDataBase.addCommittedProposal:

QuorumPacket pp = newQuorumPacket(Leader.PROPOSAL, request.zxid,

baos.toByteArray(), null);

Proposal p = newProposal();

p.packet = pp;

p.request = request;

这里就用到了jute生成的java版QuorumPacket。

rcc.jj –javacc–> org.apache.jute.compiler

zookeeper.jute –org.apache.jute.compiler.generated.RCC–> java/c的消息类实现

//JUTE由javacc编译src\java\main\org\apache\jute\compiler\generated\rcc.jj产生

Jute is a partial implementation of Hadoop’s record serialization format.

//javacc : a lexer andparser generator for LL(k) grammars

//org.apache.jute.compiler 包含C、C++、C#、java的生成器

//Generate record code in given language. Language should be alllowercase.

public voidgenCode(String language, File outputDirectory)

//org.apache.jute.compiler

CppGenerator andJavaGenerator are the main entry points from the parser.

//入口在JFile.genCode

JFile又在rcc.jj中被引用

generate_jute_parser:

创建${build.dir}/jute_compiler/org/apache/jute/compiler/generated目录

target=”${java.src.dir}${jute_javacc.packagedir}/rcc.jj”

outputdirectory=”${jute_javacc.dir}${jute_javacc.packagedir}/”

javacchome=”${ivy.lib}”

/>

javacc rcc.jj

javacc编译.jj语法文件,生成一个工具Rcc。Rcc调用JFile的genCode

compile_jute:[A simple totally ordered broadcast protocol causal relationship指的是同一个发送者发送的两个消息,或者leader改变前发送的消息和改变后发送的消息。 怎么保证casual

生成:实体类java代码。(在文件夹src/java/generated目录下)

org.apache.zookeeper.data

生成:对应的C代码

rcc –l C++ …

org.apache.jute包中其余的类:

OutputArchive 序列化需要实现的接口

+BinaryInputArchive

+CsvInputArchive

+XmlInputArchive

InputArchive 反序列化需要实现的接口

+BinaryInputArchive

+CsvInputArchive

+XmlInputArchive

Index 表现为反序列化map的一个迭代器

+BinaryIndex

+CsvIndex

+XmlIndex

*Index idx = startVector(…);

* while(!idx.done()) {

*   …. // read element of a vector

*   idx.incr();

* }

Record : 所有产生的类都必须实现的接口

public interface Record{

public voidserialize(OutputArchive archive, String tag) throws IOException;

public voiddeserialize(InputArchive archive, String tag) throws IOException;

}

RecordReader、RecordWriter是所有InputArchive/OutputArchive的工厂类[源代码:http://svn.apache.org/repos/asf/zookeeper/trunk/ 导入eclipse:在包含build.xml目录下执行ant eclipse将产生.classpath文件 目录结构:src/recipes:提供了各

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/210611.html原文链接:https://javaforall.net

(0)
上一篇 2026年3月19日 上午7:16
下一篇 2026年3月19日 上午7:16


相关推荐

  • FZU 1686 龙之谜 重复覆盖

    FZU 1686 龙之谜 重复覆盖

    2022年1月10日
    42
  • RelativeLayout.LayoutParams.addRule()方法

    RelativeLayout.LayoutParams.addRule()方法1、应用场景

    2022年7月17日
    26
  • springboot的单元测试(junit单元测试实例)

    转载 原文:https://www.codenong.com/cs106212170/文章目录一.Junit测试二.集成测试1.SpringBoot测试-测试其中的Bean2.SpringBootWeb测试-启动tomcat3.SpringBootWeb测试-不启动tomcat(模拟环境)三.单元测试1.web层测试2.mybtismapper测试3.测试任意的bean4.Mock操作四.相关注解的汇总五.参考网站一.Junit测试当你的单元测试代码不需要用到..

    2022年4月13日
    38
  • sitemap死链检测工具-免费sitemap死链检测抓取工具

    sitemap死链检测工具-免费sitemap死链检测抓取工具sitemap死链检测工具,为什么要检测sitemap死链?当你辛辛苦苦生成sitemap然后再提交到搜索引擎收录。搜索引擎抓取你的网站后发现你的sitemap存在大量的死链,给你网站降权,或者降低关键词排名就得不偿失了。今天给大家分享这款免费的sitemap生成软件。不仅可以检测网站的死链。还支持未收录网站sitemap生成详细参考图片。目前需求建立网站的企业十分得多,sitemap死链检测工具而且有许多企业以为,网站建立是一个十分重要的工作,这一点的正确性大家不能承认,但是还有一点大家一定也不可以无视那

    2022年7月23日
    17
  • 十大排序算法简单讲解

    十大排序算法简单讲解

    2021年9月28日
    50
  • 测试用例八大要素

    测试用例八大要素测试用例八大要素1.测试用例编号由字母、字符、数字组合而成的字符串,有唯一性,易识别性。eg:1)系统测试:产品编号-ST-系统测试项名-系统测试子项名-编号2)集成测试:产品编号-IT-集成测试项名-集成测试子项名-编号3)单元测试:产品编号-UT-单元测试项名-单元测试子项名-编号这样看到编号就可以知道是做的什么测试,测试的对象是什么,也方便维护。…

    2022年6月28日
    32

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号