• hadoop配置文件的加载机制 分类: A1_HADOOP 2015-01-21 11:29 839人阅读 评论(0) 收藏




    hadoop通过Configuration类来保存配置信息
    1、通过Configuration.addResource()来加载配置文件
    2、通过Configuration.get***()来获取配置属性

    1、创建一个新的Configuration实例时,会加载core-default.xml与core-site.xml,若还有其它配置,则调用addResource()继续添加。
    package org.jediael.hadoopdemo;

    import org.apache.hadoop.conf.Configuration;

    public class ConfigurationDemo {
        public static void main(String[] args){
            Configuration conf = new Configuration();
            //conf.addResource("/opt/jediael/hadoop-1.2.1/conf/core-site.xml");
            Configuration.addDefaultResource("mapred-default.xml");
            
            //System.out.println(conf.get("fs.default.name"));
            System.out.println(conf.get("hadoop.tmp.dir"));
            System.out.println(conf.get("io.sort.mb"));
        }
    }
    输出结果为:
    www:Downloads liaoliuqing$ hadoop jar hdemo.jar org.jediael.hadoopdemo.ConfigurationDemo
    hdfs://localhost:9000
    /opt/tmp
    null

    2、可以通过Configuration.addDefaultResource()加载CLASSPATH下的内容,主要用于加载hdfs-default.xml  hdfs-site.xml  mapred-default.xm  mapred-site.xml

    package org.jediael.hadoopdemo;

    import org.apache.hadoop.conf.Configuration;

    public class ConfigurationDemo {
        public static void main(String[] args){
            Configuration conf = new Configuration();
            //conf.addResource("/opt/jediael/hadoop-1.2.1/conf/core-site.xml");
            Configuration.addDefaultResource("mapred-default.xml");
            
            System.out.println(conf.get("fs.default.name"));
            System.out.println(conf.get("hadoop.tmp.dir"));
            System.out.println(conf.get("io.sort.mb"));
        }
    }
    输出结果为:
    www:Downloads liaoliuqing$ hadoop jar hdemo.jar org.jediael.hadoopdemo.ConfigurationDemo
    hdfs://localhost:9000
    /opt/tmp
    100

    若color.xml位于$HADOOP_HOME/conf
    package org.jediael.hadoopdemo;

    import org.apache.hadoop.conf.Configuration;

    public class ConfigurationDemo {
        public static void main(String[] args){
            Configuration conf = new Configuration();
            //conf.addResource("/opt/jediael/hadoop-1.2.1/conf/color.xml");
            Configuration.addDefaultResource("color.xml");
            Configuration.addDefaultResource("mapred-default.xml");
            
            System.out.println(conf.get("fs.default.name"));
            System.out.println(conf.get("hadoop.tmp.dir"));
            System.out.println(conf.get("io.sort.mb"));
            
            System.out.println(conf.get("color"));        
        }
    }
    输出结果为:

    www:Downloads liaoliuqing$ hadoop jar hdemo.jar org.jediael.hadoopdemo.ConfigurationDemo
    hdfs://localhost:9000
    /opt/tmp
    100
    yellow
    若color.xml不位于$HADOOP_HOME/conf,则color的输出值为null。

    3、conf.addResource()与Configuration.addDefaultResource()的区别



    版权声明:本文为博主原创文章,未经博主允许不得转载。

  • 相关阅读:
    开发环境搭建
    添加约束设置方式
    ubuntu和windows双系统启动顺序的修改
    函数指针,指针函数,数组指针,指针数组 区分
    boost
    centos7 64位如何配置网络
    MySQL数据库(主键、索引、外键、触发器...)
    几种常见字符集与字符编码
    ODBC、OLEDB应用详解
    C#事件以及EventHandler、EventArgs
  • 原文地址:https://www.cnblogs.com/lujinhong2/p/4637242.html
Copyright © 2020-2023  润新知