最近事情挺多的,好久不寫博客了。今天在看hadoop的時候,突然心血來潮,想在windows的eclipse下跑hadoop的shell腳本,這樣就方便多了,查了一個晚上,終于看似找到了,淚奔。記錄&分享一下,如果有人也有這樣的需求或者備以后自己看。
當然在windows下跑shell當然是要先安裝cygwin了,關于這個cygwin的安裝就不在這里說了,另外關于如何在cygwin配置hadoop貌似已經有人寫過了,也不在這里介紹了,有興趣的童鞋可以參考:
http://blog.csdn.net/yanical/article/details/4474830所以本文只關注如何將cygwin引入到eclipse中以運行shell腳本。
在eclipse中,通過External Tools方式來支持嵌入包括cygwin在內的其他工具,以下是這些步驟:
1. eclipse->Run->External Tools->External Tools Configuration....
2. 在配置頁面中,那么可以按你的愛好隨便指定,如cywin_hadoop,location是指externl tools的地址,這里就是解釋shell的bash,簡單一點的,可以直接指定:C:\cygwin\bin\bash.exe,這樣可以執行一些簡單的命令,但是如果要引用其他解釋器,那就有問題了,比如執行hadoop的shell文件,就會發現dirname命令找不到的提示。所以一種解決方法是自己寫一個bat腳本,把需要用到的目錄都寫道PATH中,比如我編寫了如下的bat腳本(當然如果需要其他更多其他目錄的命令,可以往PATH中添加):
@echo off
rem 上一行關閉命令回顯
PATH=C:\cygwin\bin\;%PATH%
bash %1
rem 開啟命令回顯
echo on
然后把location指向該文件。
3. Work Directory是指工作目錄,可以指定你腳本所在目錄,如我的hadoop腳本在scripts下,那么我就指定了:${workspace_loc:/hadoop/scripts}
4. Arguments我指定了當前的文件名:${resource_name},如果在實際運行hadoop腳本時參數可以往后再添加。
這樣就配置好了,直接點擊Run就可以運行了。這樣感覺以后開發就方便多了。
另外,還發現了一個非常有趣的東東,一同記錄分享。
為了在windows下點擊shell腳本文件就可以直接運行shell腳本,有人想出了如下命令(出自:
http://stackoverflow.com/questions/105075/how-can-i-associate-sh-files-with-cygwin):
assoc .sh=bashscript
ftype bashscript=C:\cygwin\bin\bash.exe --login -i -c 'cd "$(dirname "$(cygpath -u "%1")")"; bash "$(cygpath -u "%1")"'
即設置*.sh文件的默認執行軟件是bash,如果在win7下需要用管理員身份打開cmd,然后運行這兩個指令。可惜我好像木有運行成功,沒有仔細找原因,不過我嘗試了一下命令確實可以運行:
assoc .sh=bashscript
ftype bashscript=C:\cygwin\bin\bash.exe %1
感覺挺好玩的。。。。
posted on 2012-04-12 00:38
DLevin 閱讀(5782)
評論(0) 編輯 收藏 所屬分類:
Hadoop