hadoop mapreduce加载ClientProtocol(JobRunner)方法解析

hadoop mapreduce加载ClientProtocol(JobRunner)使用了spi机制,具体方法在Cluster#initialize。它会使用frameworkLoader(一个ServiceLoader对象)加载ClientProtocolProvider,在hadoop的jar包里配置了两个实现类:

  • org.apache.hadoop.mapred.YarnClientProtocolProvider
    • 配置文件见~\.m2\repository\org\apache\hadoop\hadoop-mapreduce-client-jobclient\2.7.2\hadoop-mapreduce-client-jobclient-2.7.2.jar!\META-INF\services\org.apache.hadoop.mapreduce.protocol.ClientProtocolProvider
  • org.apache.hadoop.mapred.LocalClientProtocolProvider
    • 配置文件见~\.m2\repository\org\apache\hadoop\hadoop-mapreduce-client-common\2.7.2\hadoop-mapreduce-client-common-2.7.2-sources.jar!\META-INF\services\org.apache.hadoop.mapreduce.protocol.ClientProtocolProvider

核心逻辑如下:

for (ClientProtocolProvider provider : frameworkLoader) {
	if (jobTrackAddr == null) {
		clientProtocol = provider.create(conf);
	} else {
		clientProtocol = provider.create(jobTrackAddr, conf);
	}
	
	if (clientProtocol != null) {
	    clientProtocolProvider = provider;
	    client = clientProtocol;
	    break;
    }
}

framewordLoader的生成代码如下:

  private static ServiceLoader<ClientProtocolProvider> frameworkLoader =
      ServiceLoader.load(ClientProtocolProvider.class);

整体加载逻辑就是通过frameworkLoader加载ClientProtocolProvider的实现类,然后遍历所有实现类,并通过实现类生成ClientProtocol,如果在遍历过程中有一次成功创建ClientProtocol对象,则退出循环,返回该对象。

具体是否生成对象的逻辑在ClientProtocol各自的实现类里,在生成对象的时候,会根据mapreduce.framework.name属性,选择生成或不生成ClientProtocol,只有mapreduce.framework.name是该类目标值的时候才可以生成。如YarnClientProtocolProvider的生成代码如下:

  public ClientProtocol create(Configuration conf) throws IOException {
    // yarn
    if (MRConfig.YARN_FRAMEWORK_NAME.equals(conf.get(MRConfig.FRAMEWORK_NAME))) {
      return new YARNRunner(conf);
    }
    return null;
  }

在内部会判断mapreduce.framework.name是否是yarn,只有是yarn的时候才会生成。而LocalClientProtocolProvider则会判断是否是local

所以,把这些逻辑结合起来就是生成mapreduce.framework.name配置指定的ClientProtocol对象。

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值