configration这个类是分析hadoop源代码一个很好地入口。
先从需求说起。对于一个大型的文件系统,基于配置文件可以增强灵活性。congfigration类就是为了管理配置文件的。
配置文件的一个一对对的KV对。 所以configration类的核心是用了hashmape存储了KV对。
先放上类图
所以configration类核心在于加载资源和解析资源。
举一个例子来解析。
Configuration conf = new Configuration(); conf.addResource("core-default.xml");
用这种默认的字符串方式加载资源实际上市加载的 代码路径下的资源.
resources.add(resource); private ArrayList<Object> resources = new ArrayList<Object>();
可以看到addResource方法其实没有开始加载XML 文件,只是先把资源文件放在了一个数组里。
真正加载文件 在调用的时候 看代码
conf.get("fs.hsftp.impl")
public String get(String name) { return substituteVars(getProps().getProperty(name)); }
private synchronized Properties getProps() { if (properties == null) { properties = new Properties(); loadResources(properties, resources, quietmode);
else if (name instanceof String) { // a CLASSPATH resource URL url = getResource((String)name); if (url != null) { if (!quiet) { LOG.info("parsing " + url); } doc = builder.parse(url.toString());
这里面有了Dom解析的方式解析了XML 文件。