亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 學院 > 開發設計 > 正文

hadoop配置文件加載順序

2019-11-14 22:08:01
字體:
來源:轉載
供稿:網友
hadoop配置文件加載順序

  用了一段時間的hadoop,現在回來看看源碼發現別有一番味道,溫故而知新,還真是這樣的

  在使用hadoop之前我們需要配置一些文件,hadoop-env.sh,core-site.xml,hdfs-site.xml,maPRed-site.xml。那么這些文件在什么時候被hadoop使用?

  一般的在啟動hadoop的時候使用最多就是start-all.sh,那么這個腳本都干了些什么?

start-all.sh
# Start all hadoop daemons. Run this on master node.#特別的地方時要在master節點上啟動hadoop所有進程 bin=`dirname "$0"`bin=`cd "$bin"; pwd` #bin=$HADOOP_HOME/bin if [ -e "$bin/../libexec/hadoop-config.sh" ]; then. "$bin"/../libexec/hadoop-config.shelse. "$bin/hadoop-config.sh"fi # start dfs daemons"$bin"/start-dfs.sh --config $HADOOP_CONF_DIR # start mapred daemons"$bin"/start-mapred.sh --config $HADOOP_CONF_DIR

加載hadoop-env.sh  腳本先找到hadoop中的bin目錄,在配置了hadoop環境變量的情況下該處可以使用$HADOOP_HOME/bin直接代替。接下來是執行hadoop-config.sh,這個文件可能會在$HADOOP_HOME/libexec目錄或者是$HADOOP_HOME/bin目錄下,在我使用的hadoop版本中是在$HADOOP_HOME/libexec目錄下,在hadoop-config.sh文件中有下面這幾行腳本hadoop-config.sh
if [ -f "${HADOOP_CONF_DIR}/hadoop-env.sh" ]; then. "${HADOOP_CONF_DIR}/hadoop-env.sh"fi

測試$HADOOP_HOME/conf/hadoop-env.sh為普通文件后,通過. "${HADOOP_CONF_DIR}/hadoop-env.sh"執行hadoop-env.sh這個腳本,ok,我們在hadoop-env.sh中配置的環境變量 java_HOME 生效了,其實我感覺這個地方完全可以不用配置,為什么?因為我們在linux上安裝hadoop肯定要安裝java,那么安裝時肯定都會配置JAVA_HOME,在/etc/profile中配置的環境變量在任何的shell進程中都生效。

加載core-*.xml,hdfs.*.xml文件 執行完hadoop-config.sh命令后,執行$HADOOP_HOME/start-dfs.sh。該腳本的作用是啟動namenode,datename,secondarynamenode這三個與hdfs有關的進程start-dfs.sh
# Run this on master node. usage="Usage: start-dfs.sh [-upgrade|-rollback]" bin=`dirname "$0"`bin=`cd "$bin"; pwd` if [ -e "$bin/../libexec/hadoop-config.sh" ]; then. "$bin"/../libexec/hadoop-config.shelse. "$bin/hadoop-config.sh"fi # get argumentsif [ $# -ge 1 ]; thennameStartOpt=$1shiftcase $nameStartOpt in(-upgrade);;(-rollback)dataStartOpt=$nameStartOpt;;(*)echo $usageexit 1;;esacfi # start dfs daemons# start namenode after datanodes, to minimize time namenode is up w/o data# note: datanodes will log connection errors until namenode starts"$bin"/hadoop-daemon.sh --config $HADOOP_CONF_DIR start namenode $nameStartOpt"$bin"/hadoop-daemons.sh --config $HADOOP_CONF_DIR start datanode $dataStartOpt"$bin"/hadoop-daemons.sh --config $HADOOP_CONF_DIR --hosts masters start secondarynamenode

仔細看看不能發現,在start-dfs.sh中同樣也會執行hadoop-config.sh,之所以有這一步,是因為我們不總是使用start-all.sh來啟動hadoop的所有進程,有時候我們只需要使用hdfs而不需要MapReduce,此時只需要單獨執行start-dfs.sh,同樣hadoop-config.sh中定義的變量也會被文件系統相關進程使用,所以這里在啟動namenode,datanode,secondarynamenode之前需要先執行hadoop-config.sh,同時hadoop-env.sh文件被執行。再來看看最后的三行代碼,分別是啟動namenode,datanode,secondarynamenode的腳本。啟動hadoop后一共有5個進程,其中三個就是namenode,datanode,secondarynamenode,既然能啟動進程說明對應的類中一定有main方法,看看源碼就可以驗證這一點,這不是重點,重點是來看看對應的類是怎么加載配置文件的。無論是namenode,還是dataname,還是secondarynamenode,他們在啟動時都會加載core-*.xml和hdfs-*.xml文件,以org.apache.hadoop.hdfs.server.namenode.NameNode 這個類為例,其他的兩個類org.apache.hadoop.hdfs.server.datanode.DataNode,org.apache.hadoop.hdfs.server.namenode.SecondaryNameNode類似。

org.apache.hadoop.hdfs.server.namenode.NameNode
public class NameNode implements ClientProtocol, DatanodeProtocol,NamenodeProtocol, FSConstants,RefreshAuthorizationPolicyProtocol,RefreshUserMappingsProtocol {static{Configuration.addDefaultResource("hdfs-default.xml");Configuration.addDefaultResource("hdfs-site.xml");}...}

看看靜態代碼塊里面內容,會很興奮,看到了hdfs-default.xml和hdfs-site.xml。對重點就在這里,static code block在類加載到jvm執行類的初始化時會執行(不是對象初始化)。Configuration.addDefaultResource("hdfs-default.xml");這段代碼執行前會先將Configuration這個類加載jvm中,那么看下org.apache.hadoop.conf.Configuration這個類中的static code block干了些什么

org.apache.hadoop.conf.Configuration
static{//print deprecation warning if hadoop-site.xml is found in classpathClassLoader cL = Thread.currentThread().getContextClassLoader();if (cL == null) {cL = Configuration.class.getClassLoader();}if(cL.getResource("hadoop-site.xml")!=null) {LOG.warn("DEPRECATED: hadoop-site.xml found in the classpath. " +"Usage of hadoop-site.xml is deprecated. Instead use core-site.xml, "+ "mapred-site.xml and hdfs-site.xml to override properties of " +"core-default.xml, mapred-default.xml and hdfs-default.xml " +"respectively");}addDefaultResource("core-default.xml");addDefaultResource("core-site.xml");}

Configuration類在類的初始化時加載了core-default.xml和core-site.xml這兩個文件。這樣namenode在啟動的時候就加載了core-*.xml和hdfs-*.xml文件,其中core-*.xml是由Configuration這個類加載的。

加載core-*.xml和mapred-*.xml文件執行完start-dfs.xml后,執行start-mapred.sh,該腳本和start-hdf.sh差不多。
start-mapred.sh# Start hadoop map reduce daemons. Run this on master node. bin=`dirname "$0"`bin=`cd "$bin"; pwd` if [ -e "$bin/../libexec/hadoop-config.sh" ]; then. "$bin"/../libexec/hadoop-config.shelse. "$bin/hadoop-config.sh"fi # start mapred daemons# start jobtracker first to minimize connection errors at startup"$bin"/hadoop-daemon.sh --config $HADOOP_CONF_DIR start jobtracker"$bin"/hadoop-daemons.sh --config $HADOOP_CONF_DIR start tasktracker 

該腳本同樣也會執行hadoop-config.sh,同樣也會執行hadoop-env.sh。這里和start-dfs.sh是統一的。最后兩行代碼是啟動jobtracker和tasktracker進程的。同樣對應著兩個類org.apache.hadoop.mapred.JobTracker和org.apache.hadoop.mapred.TaskTracker

以org.apache.hadoop.mapred.JobTracker為例,org.apache.hadoop.mapred.TaskTracker類似org.apache.hadoop.mapred.JobTracker
public class JobTracker implements MRConstants, InterTrackerProtocol,JobSubmissionProtocol, TaskTrackerManager, RefreshUserMappingsProtocol,RefreshAuthorizationPolicyProtocol, AdminOperationsProtocol,JobTrackerMXBean { static{Configuration.addDefaultResource("mapred-default.xml");Configuration.addDefaultResource("mapred-site.xml");}...}

ok,有了上面的解釋,現在已經很明白了。JobTracker啟動時加載了core-*.xml和mapred-*.xml文件,其中core-*.xml是由Configuration完成的。summarize: 使用start-all.sh啟動hadoop所有的進程時,各種配置文件得加載順序: HDFS:hadoop-env.sh --> core-default.xml --> core-site.xml --> hdfs-default.xml --> hdfs-site.xml Mapred:hadoop-env.sh --> core-default.xml --> core-site.xml --> mapred.default.xml --> mapred.site.xml注意到一點,core-*.xml系統的文件總是優先加載,而且hadoop中5個進程都會加載,這也說明core-*.xml是公共的基礎庫,被大家伙共享。 配置文件時在進程啟動時加載的,這也可以證明如果修改了hadoop的配置文件,無論是系統配置文件還是管理員配置文件,都需要重新啟動進程生效。
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
亚洲一区二区三区在线视频| 亚洲国产小视频在线观看| 色噜噜久久综合伊人一本| 这里只有精品视频| 欧美激情一级二级| 亚洲国产福利在线| 91精品国产色综合久久不卡98口| 欧美日韩裸体免费视频| 日韩在线视频观看正片免费网站| 亚洲曰本av电影| 中国日韩欧美久久久久久久久| 日韩麻豆第一页| 久久久久久免费精品| 韩国精品美女www爽爽爽视频| xvideos亚洲人网站| 中文字幕在线日韩| 97香蕉超级碰碰久久免费的优势| 日韩三级影视基地| 欧美一级大片在线免费观看| 亚洲开心激情网| 奇门遁甲1982国语版免费观看高清| 日韩av网址在线观看| 精品av在线播放| 国产精品久久久久久超碰| 欧美亚洲另类视频| 国产一区二区成人| 91av视频在线播放| 亚洲国产成人av在线| 91精品国产综合久久久久久久久| 久久久国产精彩视频美女艺术照福利| 欧美孕妇毛茸茸xxxx| 精品久久久久久国产91| 亚洲一区av在线播放| 91久久综合亚洲鲁鲁五月天| 国产一区二区av| 亚洲日韩欧美视频| 国产精品久久77777| 人人做人人澡人人爽欧美| 欧美多人乱p欧美4p久久| 久久久亚洲欧洲日产国码aⅴ| 亚洲国产成人精品久久久国产成人一区| 欧美日韩中国免费专区在线看| 日韩在线播放av| 欧美黑人xxx| 亚洲新声在线观看| 97在线视频国产| 国产午夜精品视频| 欧美视频精品一区| 亚洲男人天堂手机在线| 国产ts一区二区| 国模吧一区二区三区| 日韩va亚洲va欧洲va国产| 欧美成年人网站| 久久影院资源站| 亚洲国产日韩欧美在线99| 亚洲精美色品网站| 欧美在线视频一区二区| 欧美精品少妇videofree| 久久精品免费电影| 欧美黑人巨大xxx极品| 久久久精品亚洲| 精品国产视频在线| 成人妇女淫片aaaa视频| 国产精品日韩欧美| 国产色婷婷国产综合在线理论片a| 色偷偷噜噜噜亚洲男人的天堂| 永久免费看mv网站入口亚洲| 欧美激情精品久久久久久免费印度| 亚洲精品日韩久久久| 亚洲激情视频网| 国产视频丨精品|在线观看| 国产精品久久久久免费a∨| 狠狠躁18三区二区一区| 最近2019中文字幕大全第二页| 亚洲国产精品va在线| 欧美一级免费看| 成人免费网视频| 国产z一区二区三区| 欧美精品在线看| 亚洲国产精品悠悠久久琪琪| 日本欧美国产在线| 国产有码一区二区| 91精品国产91久久久久久久久| 三级精品视频久久久久| 亚洲欧美日韩网| 日本91av在线播放| 日韩精品福利网站| 国产精品一区二区电影| 91av中文字幕| 在线日韩日本国产亚洲| 久久精品99国产精品酒店日本| 91社区国产高清| 久久精品视频网站| 久久夜精品va视频免费观看| 98午夜经典影视| 中文字幕精品av| 亚洲国产精品va在线看黑人| 亚洲国产精彩中文乱码av在线播放| 亚洲最大中文字幕| 久久av在线看| 国产精品露脸av在线| 国产精品精品国产| 日韩麻豆第一页| 久久精品国产99国产精品澳门| 欧美电影第一页| 亚洲综合大片69999| 久久久久久国产精品| 国产精品久久久久久久av大片| 777午夜精品福利在线观看| 在线a欧美视频| 欧美成人一区二区三区电影| 国产日韩换脸av一区在线观看| 国产高清在线不卡| 国产又爽又黄的激情精品视频| 国产精品爽黄69| 亚洲欧美一区二区三区四区| 欧美做受高潮电影o| 国产精品自拍网| 高清欧美性猛交xxxx黑人猛交| 国产亚洲精品综合一区91| 久久久99免费视频| 亚洲欧美制服另类日韩| 一本一本久久a久久精品牛牛影视| 亚洲欧洲日韩国产| 日韩精品一区二区三区第95| 午夜精品一区二区三区在线| 国内精久久久久久久久久人| 日韩成人网免费视频| 久久不射热爱视频精品| 欧美亚洲国产日本| 亚洲性视频网址| 色婷婷综合久久久久中文字幕1| 91超碰中文字幕久久精品| 国产伦精品免费视频| 亚洲一区二区久久久久久久| 成人啪啪免费看| 亚洲天堂男人天堂女人天堂| 久久天堂av综合合色| 成人在线国产精品| 青青草成人在线| 精品香蕉一区二区三区| 日韩网站免费观看高清| 日韩精品在线免费观看视频| 亚洲福利视频免费观看| 亚洲成人激情视频| 亚洲一区二区三区香蕉| 久操成人在线视频| 久久久亚洲精选| 国产精品亚洲网站| 日本人成精品视频在线| 91丨九色丨国产在线| 91性高湖久久久久久久久_久久99| 成人国产精品一区二区| 亚洲精品国产综合区久久久久久久| 亚洲精品久久久久中文字幕欢迎你| 欧美电影免费观看大全| 国产精品久久一区主播| 亚洲美女自拍视频| 91精品国产九九九久久久亚洲| 国产精品十八以下禁看| 亚洲伊人成综合成人网| 欧美老女人性生活| 日本久久亚洲电影| 亚洲国产精品热久久|