spark 遠端調試
本地調試遠端集群運行的spark項目,當spark項目在集群上報錯,但是本地又查不出問題時,最好的方式就是調試一步一步跟蹤代碼。但是在集群上的代碼又不能像本地一樣的調試。那么就試試這個調試方法吧。
遠程調試spark其實就四步:
首先
首先了解jvm一些參數屬性
-Xdebug -Xrunjdwp:transport=dt_socket,server=y,suspend=y,address=8888
這里對上面的幾個參數進行說明:
第一步 將jar包拷貝到集群
將spark 項目打jar包, 將jar包放到集群master節點上;
第二步 配置idea
編輯idea配置:
點擊小三角,選擇:edit Configurations
如圖
添加一個remote 配置
配置遠端地址和端口 (此處配置的是 遠端master 節點的地址)
第三步 遠端啟動spark項目
在集群啟動要調試的spark項目。命令如下:
/tmp/mySpark.jar 為你sprak 項目在集群master上的位置
spark-submit --class WordCount --master spark://192.168.100.xx:7077 --driver-java-options "-Xdebug -Xrunjdwp:transport=dt_socket,server=y,suspend=y,address=8888" /tmp/mySpark.jar
也可在conf/spark-env.sh這個文件最后加入(不過沒有進行實際測試)
export SPARK_JAVA_OPTS+="-Xdebug -Xrunjdwp:transport=dt_socket,server=y,suspend=y,address=8888"
如圖進入監聽:
第四步 啟動idea
啟動idea 的debug 模式就會進入斷點。
總結
以上就是這篇文章的全部內容了,希望本文的內容對大家的學習或者工作具有一定的參考學習價值,謝謝大家對VeVb武林網的支持。
新聞熱點
疑難解答
圖片精選