場景
在Windows下用sublime text 3創(chuàng)建了sh文件用于跑定時腳本任務(wù),但是上傳到Unix服務(wù)器之后發(fā)現(xiàn)并沒有被執(zhí)行到。手動執(zhí)行,發(fā)現(xiàn)報錯:
報錯信息
看到,換行的同時,把shell命令給覆蓋了一部分。
vim 對應(yīng)文件,執(zhí)行:set ff 命令,發(fā)現(xiàn)fileformat=dos 表示這是DOS格式的文件
測試
同時執(zhí)行原先在Unix環(huán)境下創(chuàng)建的sh文件,則一切正常。
找到原因
確定原因,是因?yàn)樵赪indows系統(tǒng)下創(chuàng)建的sh文件的換行格式和Unix系統(tǒng)不同,導(dǎo)致Unix系統(tǒng)不能識別
解決方案
經(jīng)過Google,百度blabla,歸納出三種解決方案:
一、從源頭解決問題:用sublime text 3創(chuàng)建出現(xiàn)的問題,就從st3上去解決。
Perferences->Settings->User,添加配置”default_line_ending”: “unix”,保存
將出現(xiàn)問題的sh文件一個個刪除,再重新寫入shell命令,保存。
優(yōu)點(diǎn):一勞永逸,以后使用st3創(chuàng)建的sh文件直接上傳到Unix服務(wù)器就可以直接執(zhí)行,而不會出現(xiàn)問題了。
缺點(diǎn):一個個刪除文件再重新創(chuàng)建太麻煩了點(diǎn)。- -!!
二、用dos2unix命令
dos2unix file.sh
優(yōu)點(diǎn):一次性可以修復(fù)所有文件的換行格式問題
缺點(diǎn):服務(wù)器上修改文件格式,如果有用到git或者SVN版本控制軟件,可能導(dǎo)致服務(wù)器上的sh文件版本改變,下次從本地上傳文件,需要先還原這次修改的內(nèi)容才可以,還是別這么干吧。。
三、用:set ff=unix命令
:set ff=unix
或
:set fileformat=unix
優(yōu)點(diǎn):修改個別文件,不會誤操作(唯一能想到的優(yōu)點(diǎn))
缺點(diǎn):(跟dos2unix命令的缺點(diǎn)一樣)
四、最佳方案:結(jié)合方案一,再使用sed命令
st3設(shè)置Perferences->Settings->User,添加配置”default_line_ending”: “unix”,保存
本地虛擬機(jī)終端使用sed命令sed -i "s/\r//" file.sh
優(yōu)點(diǎn):一勞永逸且修改方便
結(jié)果
完美解決,再執(zhí)行sh file.sh,發(fā)現(xiàn)正常運(yùn)行,一切那么美好。。