设为首页 收藏本站
查看: 1190|回复: 0

[经验分享] hadoop-2.6.4 NameNode 源码分析学习

[复制链接]
累计签到:2 天
连续签到:2 天
发表于 2017-3-2 11:30:10 | 显示全部楼层 |阅读模式
Namenode的介绍
  一个简单的hadoop集群是由一个ACtive的namenode和多个datenode组成的,
  namdnode是这个文件系统的管理节点。它维护着整个文件系统的目录树,文件/目标的元信息和每个文件对应的数据块列表。接受用户的操作请求。
  启动Namenode
  调用脚本:bin/hdfs namde
  hdfs的启动脚本:



...
COMMAND=$1
...
if [ "$COMMAND" = "namenode" ] ; then
CLASS='org.apache.hadoop.hdfs.server.namenode.NameNode'
HADOOP_OPTS="$HADOOP_OPTS $HADOOP_NAMENODE_OPTS"
...
# run it
exec "$JAVA" -Dproc_$COMMAND $JAVA_HEAP_MAX $HADOOP_OPTS $CLASS "$@"
####最终namenode是启动org.apache.hadoop.hdfs.server.namenode.NameNode这个类
  由shell脚本可以知道namenode的实现类是org.apache.hadoop.hdfs.server.namenode.NameNode;
  Namenode代码解释:



public class NameNode implements NameNodeStatusMXBean {
//namenode程序入口
public static void main(String argv[]) throws Exception {
if (DFSUtil.parseHelpArgument(argv, NameNode.USAGE, System.out, true)) {
System.exit(0);
}
try {
StringUtils.startupShutdownMessage(NameNode.class, argv, LOG);
//创建namenode实例
NameNode namenode = createNameNode(argv, null);
if (namenode != null) {
namenode.join();
}
} catch (Throwable e) {
LOG.fatal("Failed to start namenode.", e);
terminate(1, e);
}
}
public static NameNode createNameNode(String argv[], Configuration conf)
throws IOException {
...
//获取操作参数
StartupOption startOpt = parseArguments(argv);

switch (startOpt) {
case FORMAT: {//初次启动hadoop集群,要格式化namenode
boolean aborted = format(conf, startOpt.getForceFormat(),
startOpt.getInteractiveFormat());
terminate(aborted ? 1 : 0);
return null; // avoid javac warning
      }
......
default: {//正常启动namenode
DefaultMetricsSystem.initialize("NameNode");
return new NameNode(conf);
}
}
}  
//操作hdfs文件系统的类
public FSNamesystem namesystem;
/** httpServer,平时我们在浏览器查看的hdfs的web管理控制台,就是通过它显示的,它包装了一个内嵌的jetty */
protected NameNodeHttpServer httpServer;
/** RPC服务器,DFSClient,DataNode和Namenode通信都要通过它 */
private NameNodeRpcServer rpcServer;
protected NameNode(Configuration conf, NamenodeRole role)
throws IOException {
...  
//执行initialize方法初始化
      initialize(conf);
...
this.started.set(true);
}
protected void initialize(Configuration conf) throws IOException {
...
//启动http服务器,启动后可以通过http://namenode:50070 访问hdfs的管理页面
if (NamenodeRole.NAMENODE == role) {
startHttpServer(conf);
}
....
//从fsimage和edits log加载元数据
    loadNamesystem(conf);
//启动RPC server
rpcServer = createRpcServer(conf);
....
}
}
  我特别关注的是namenode两个部分的实现:与client,datanode的rpc通信,和文件管理的实现FSNamesystem
  namenode启动rpc服务:



//这个类是用于RPC服务的响应
class NameNodeRpcServer implements NamenodeProtocols {
//监听datanode请求的rpc服务  
private final RPC.Server serviceRpcServer;
//监听client请求的rpc服务
protected final RPC.Server clientRpcServer;
public NameNodeRpcServer(Configuration conf, NameNode nn)
throws IOException {
...
//在服务端创建了一堆的rpc协议的实现类
       ClientNamenodeProtocolServerSideTranslatorPB
clientProtocolServerTranslator =
new ClientNamenodeProtocolServerSideTranslatorPB(this);
BlockingService clientNNPbService = ClientNamenodeProtocol.
newReflectiveBlockingService(clientProtocolServerTranslator);
...
//创建RPC服务端,监听datanode的请求
this.serviceRpcServer = new RPC.Builder(conf)
.setProtocol(
org.apache.hadoop.hdfs.protocolPB.ClientNamenodeProtocolPB.class)
.setInstance(clientNNPbService)
.setBindAddress(bindHost)
.setPort(serviceRpcAddr.getPort()).setNumHandlers(serviceHandlerCount)
.setVerbose(false)
.setSecretManager(namesystem.getDelegationTokenSecretManager())
.build();
//想datanode监听rpc服务器进行协议的添加
DFSUtil.addPBProtocol(conf, HAServiceProtocolPB.class, haPbService,
serviceRpcServer);
.....
}
}
  FSNamesystem是文件系统命名空间系统类,实现了namenode的基本服务功能,
  FSNamesystem类就是实现去与datanode进行交互操作的类:

运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-349265-1-1.html 上篇帖子: JSON-RPC(jsonrpc4j)使用demo 下篇帖子: mac 安装solr5.x
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表