上善若水
          In general the OO style is to use a lot of little objects with a lot of little methods that give us a lot of plug points for overriding and variation. To do is to be -Nietzsche, To bei is to do -Kant, Do be do be do -Sinatra
          posts - 146,comments - 147,trackbacks - 0
          最近事情挺多的,好久不寫博客了。今天在看hadoop的時候,突然心血來潮,想在windows的eclipse下跑hadoop的shell腳本,這樣就方便多了,查了一個晚上,終于看似找到了,淚奔。記錄&分享一下,如果有人也有這樣的需求或者備以后自己看。

          當(dāng)然在windows下跑shell當(dāng)然是要先安裝cygwin了,關(guān)于這個cygwin的安裝就不在這里說了,另外關(guān)于如何在cygwin配置hadoop貌似已經(jīng)有人寫過了,也不在這里介紹了,有興趣的童鞋可以參考:http://blog.csdn.net/yanical/article/details/4474830

          所以本文只關(guān)注如何將cygwin引入到eclipse中以運行shell腳本。
          在eclipse中,通過External Tools方式來支持嵌入包括cygwin在內(nèi)的其他工具,以下是這些步驟:
          1. eclipse->Run->External Tools->External Tools Configuration....
          2. 在配置頁面中,那么可以按你的愛好隨便指定,如cywin_hadoop,location是指externl tools的地址,這里就是解釋shell的bash,簡單一點的,可以直接指定:C:\cygwin\bin\bash.exe,這樣可以執(zhí)行一些簡單的命令,但是如果要引用其他解釋器,那就有問題了,比如執(zhí)行hadoop的shell文件,就會發(fā)現(xiàn)dirname命令找不到的提示。所以一種解決方法是自己寫一個bat腳本,把需要用到的目錄都寫道PATH中,比如我編寫了如下的bat腳本(當(dāng)然如果需要其他更多其他目錄的命令,可以往PATH中添加):
          @echo off
          rem 上一行關(guān)閉命令回顯

          PATH
          =C:\cygwin\bin\;%PATH%

          bash 
          %1

          rem 開啟命令回顯
          echo on
          然后把location指向該文件。
          3. Work Directory是指工作目錄,可以指定你腳本所在目錄,如我的hadoop腳本在scripts下,那么我就指定了:${workspace_loc:/hadoop/scripts}
          4. Arguments我指定了當(dāng)前的文件名:${resource_name},如果在實際運行hadoop腳本時參數(shù)可以往后再添加。

          這樣就配置好了,直接點擊Run就可以運行了。這樣感覺以后開發(fā)就方便多了。

          另外,還發(fā)現(xiàn)了一個非常有趣的東東,一同記錄分享。
          為了在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 --'cd "$(dirname "$(cygpath -u "%1")")"; bash "$(cygpath -u "%1")"'
          即設(shè)置*.sh文件的默認執(zhí)行軟件是bash,如果在win7下需要用管理員身份打開cmd,然后運行這兩個指令??上液孟衲居羞\行成功,沒有仔細找原因,不過我嘗試了一下命令確實可以運行:
          assoc .sh=bashscript
          ftype bashscript
          =C:\cygwin\bin\bash.exe %1
          感覺挺好玩的。。。。
          posted on 2012-04-12 00:38 DLevin 閱讀(5792) 評論(0)  編輯  收藏 所屬分類: Hadoop
          主站蜘蛛池模板: 南乐县| 陇西县| 东阿县| 西乡县| 浑源县| 宣汉县| 扎赉特旗| 大理市| 青阳县| 双柏县| 凉城县| 嘉兴市| 宜宾县| 莎车县| 宁津县| 修文县| 麻栗坡县| 吴桥县| 弥渡县| 南宁市| 通山县| 密山市| 原平市| 灵武市| 普宁市| 镇江市| 二手房| 云安县| 四子王旗| 沿河| 南澳县| 乳源| 红安县| 扎鲁特旗| 宾川县| 塘沽区| 抚远县| 应城市| 丹寨县| 玉溪市| 安平县|