成人午夜视频全免费观看高清-秋霞福利视频一区二区三区-国产精品久久久久电影小说-亚洲不卡区三一区三区一区

Hadoop調(diào)試源代碼

本節(jié)介紹兩種調(diào)試Hadoop源代碼的方法:利用Eclipse遠(yuǎn)程調(diào)試工具和打印調(diào)試日志。這兩種方法均可以調(diào)試偽分布式工作模式和完全分布式工作模式下的Hadoop。本節(jié)主要介紹偽分布式工作模式下的Hadoop調(diào)試方法。

我們提供的服務(wù)有:網(wǎng)站建設(shè)、成都做網(wǎng)站、微信公眾號(hào)開(kāi)發(fā)、網(wǎng)站優(yōu)化、網(wǎng)站認(rèn)證、南昌ssl等。為上千企事業(yè)單位解決了網(wǎng)站和推廣的問(wèn)題。提供周到的售前咨詢和貼心的售后服務(wù),是有科學(xué)管理、有技術(shù)的南昌網(wǎng)站制作公司

(1)利用Eclipse進(jìn)行遠(yuǎn)程調(diào)試

下面以調(diào)試ResourceManager為例,介紹利用Eclipse遠(yuǎn)程調(diào)試的基本方法,這可分兩步進(jìn)行。

步驟1 調(diào)試模式下啟動(dòng)Hadoop。

在Hadoop安裝目錄下運(yùn)行如下的Shell腳本:

export YARN_NODEMANAGER_OPTS="-Xdebug -Xrunjdwp:transport=dt_socket,address=8788, server=y,suspend=y"

sbin/start-all.sh

運(yùn)行了腳本后會(huì)看到Shell命令行終端顯示如下信息:

Listening for transport dt_socket at address: 8788

此時(shí)表明ResourceManager處于監(jiān)聽(tīng)狀態(tài),直到收到debug確認(rèn)信息。

步驟2 設(shè)置斷點(diǎn)。

在前面新建的Java工程“hadoop-2.0”中,找到ResourceManager相關(guān)代碼,并在感興趣的地方設(shè)置一些斷點(diǎn)。

步驟3 在Eclipse中調(diào)試Hadoop程序。

在Eclipse的菜單欄中,依次選擇 “Run”→“Debug Configurations”→“Remote Java Applications”,并按照要求填寫遠(yuǎn)程調(diào)試器名稱(自己定義一個(gè)即可),ResourceManager所在host以及監(jiān)聽(tīng)端口號(hào)等信息,并選擇Hadoop源代碼工程,便可進(jìn)入調(diào)試模式。

調(diào)試過(guò)程中,ResourceManager輸出的信息被存儲(chǔ)到日志文件夾下的yarn-XXX-resourcemanager-localhost.log文件(XXX為當(dāng)前用戶名)中,可通過(guò)以下命令查看調(diào)試過(guò)程中打印的日志:

tail -f logs/yarn-XXX-resourcemanager-localhost.log

(2)打印Hadoop調(diào)試日志

Hadoop使用了Apache log4j作為基本日志庫(kù),該日志庫(kù)將日志分別5個(gè)級(jí)別,分別為DEBUG、INFO、WARN、ERROR和FATAL。這5個(gè)級(jí)別是有順序的,即DEBUG < INFO < WARN < ERROR < FATAL,分別用來(lái)指定日志信息的重要程度。日志輸出規(guī)則為:只輸出級(jí)別不低于設(shè)定級(jí)別的日志信息,比如若級(jí)別設(shè)定為INFO,則INFO、WARN、ERROR和FATAL級(jí)別的日志信息都會(huì)輸出,但級(jí)別比INFO低的DEBUG則不會(huì)輸出。

在Hadoop源代碼中,大部分Java文件中存在調(diào)試日志(DEBUG級(jí)別日志),但默認(rèn)情況下,日志級(jí)別是INFO,為了查看更詳細(xì)的運(yùn)行狀態(tài),可采用以下幾種方法打開(kāi)DEBUG日志。

方法1 使用Hadoop Shell命令。

可使用Hadoop腳本中的daemonlog命令查看和修改某個(gè)類的日志級(jí)別,比如,可通過(guò)以下命令查看NodeManager類的日志級(jí)別:

bin/hadoop daemonlog -getlevel ${nodemanager-host}:8042 \

org.apache.hadoop.yarn.server.nodemanager.NodeManager

可通過(guò)以下命令將NodeManager類的日志級(jí)別修改為DEBUG:

bin/hadoop daemonlog -setlevel ${nodemanager-host}:8042 \

org.apache.hadoop.yarn.server.nodemanager.NodeManager DEBUG

其中,nodemanager-host為NodeManager服務(wù)所在的host,8042是NodeManager的HTTP端口號(hào)。

方法2 通過(guò)Web界面。

用戶可以通過(guò)Web界面查看和修改某個(gè)類的日志級(jí)別,比如,可通過(guò)以下URL修改NodeManager類的日志級(jí)別:

http://${nodemanager-host}:8042/logLevel

方法3 修改log4j.properties文件。

以上兩種方式只能暫時(shí)修改日志級(jí)別,當(dāng)Hadoop重啟后會(huì)被重置,如果要永久性改變?nèi)罩炯?jí)別,可在目標(biāo)節(jié)點(diǎn)配置目錄下的log4j.properties文件中添加以下配置選項(xiàng):

log4j.logger.org.apache.hadoop.yarn.server.nodemanager.NodeManager=DEBUG

此外,有時(shí)為了專門調(diào)試某個(gè)Java文件,需要把該文件的相關(guān)日志輸出到一個(gè)單獨(dú)文件中,可在log4j.properties中添加以下內(nèi)容:

#定義輸出方式為自定義的TTOUT

log4j.logger. org.apache.hadoop.yarn.server.nodemanager.NodeManager=DEBUG,TTOUT

#設(shè)置TTOUT的輸出方式為輸出到文件

log4j.appender.TTOUT =org.apache.log4j.FileAppender

#設(shè)置文件路徑

log4j.appender.TTOUT.File=${hadoop.log.dir}/NodeManager.log

#設(shè)置文件的布局

log4j.appender.TTOUT.layout=org.apache.log4j.PatternLayout

#設(shè)置文件的格式

log4j.appender.TTOUT.layout.ConversionPattern=%d{ISO8601} %p %c: %m%n

這些配置選項(xiàng)會(huì)把NodeManager.java中的DEBUG日志寫到日志目錄下的NodeManager.log文件中。

在閱讀源代碼的過(guò)程中,為了跟蹤某個(gè)變量值的變化,讀者可能需要自己添加一些DEBUG日志。在Hadoop源代碼中,大部分類會(huì)定義一個(gè)日志打印對(duì)象,通過(guò)該對(duì)象可打印各個(gè)級(jí)別的日志。比如,在NodeManager中用以下代碼定義對(duì)象LOG:

public static final Log LOG = LogFactory.getLog(NodeManager.class);

用戶可使用LOG對(duì)象打印調(diào)試日志。比如,可在NodeManager的main函數(shù)首行添加以下代碼:

LOG.debug("Start to lauch NodeManager...");

然后重新編譯Hadoop源代碼,并將org.apache.hadoop.yarn.server.nodemanager.NodeManager的調(diào)試級(jí)別修改為DEBUG,重新啟動(dòng)Hadoop后便可以看到該調(diào)試信息。

新聞標(biāo)題:Hadoop調(diào)試源代碼
鏈接URL:http://jinyejixie.com/article12/iiedgc.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供網(wǎng)站制作、微信公眾號(hào)網(wǎng)頁(yè)設(shè)計(jì)公司、App開(kāi)發(fā)商城網(wǎng)站、域名注冊(cè)

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請(qǐng)盡快告知,我們將會(huì)在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如需處理請(qǐng)聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來(lái)源: 創(chuàng)新互聯(lián)

成都做網(wǎng)站
高唐县| 宝清县| 张家港市| 望城县| 新乐市| 济阳县| 遂溪县| 故城县| 扎鲁特旗| 奉贤区| 玉山县| 蒲江县| 璧山县| 海口市| 西峡县| 乳山市| 军事| 湘西| 屯昌县| 原平市| 汉中市| 菏泽市| 临夏县| 谢通门县| 石柱| 固镇县| 镇雄县| 邯郸县| 东港市| 固始县| 林周县| 库车县| 河东区| 台安县| 江阴市| 湖州市| 新昌县| 正镶白旗| 琼海市| 安阳市| 临桂县|