Shell編程之/bin/bash和/bin/sh的區別淺析
前言
早期,學過shell的5種啟動方式,學的沒有那麼深入。從而導致瞭想深究一下docker exec 命令為什麼tomcat容器用/bin/bash,nginx容器卻用/bin/sh,被這個問題,折騰瞭半天!
從/bin/bash,就是進入不瞭nginx容器,由此引發瞭一系列的排查。如果你對,docker的這個錯誤感興趣,點擊進入。
正題
簡單的講,/bin/sh是早期版本,是一種便攜方式的解釋性腳本語言,自帶有posix便攜式功能,以該方式聲明的腳本,腳本中間發生錯誤會終止腳本的運行,不再運行下面的代碼。
/bin/bash,是/bin/sh的升級版,默認沒有開啟posix便攜模式,所以以/bin/bash聲明的腳本,中間即使發生錯誤,依然會繼續向下運行。
也就是說:shell腳本,第一行寫成 #!/bin/bash –posix,腳本執行效果跟#!/bin/sh是一樣的。
可以簡單的認為:
/bin/sh ==等價於== /bin/bash –posix
註意事項(重要):
假設你編寫瞭一個shell腳本,如下:
#!/bin/bash echo hello
正常情況下,我們執行這個腳本,會寫作 ./test.sh,然後回車,但是很不幸,你不是很瞭解shell腳本的5種運行方式的差異,隨手使用的運行方式是 sh test.sh,那麼
即使在test.sh腳本中指定瞭#!/bin/bash,但仍然是使用/bin/sh執行test.sh,中間發生錯誤,依然會終止運行。
註意
你日常所使用的/bin/sh可能是個假shell(它是bash的軟鏈接),它的真身很可能是/bin/bash,也就是說,如果你使用瞭/bin/sh它的本質是#!/bin/bash –posix。
何以得知?通過man sh 和man bash,就看出來瞭,他們展示的內容幾乎是一模一樣。
也就是說,在新版本的Linux內核中,老的sh已經被後來者bash整合瞭。
補充:docker容器使用/bin/bash命令
問題描述
本地運行命令和docker運行命令的解釋器不同,在本地已經是/bin/bash,但是docker中仍然是/bin/sh,需要修改docker中/bin/sh為/bin/bash
解決方案
1、首先看docker容器的詳細信息。輸入“docker container ls |grep xxxx”,看其中的命令部分,如果是“/bin/sh”說明使用的不一定是bash,可能是dash解釋器。
使用命令ls -l /bin/sh,如果顯示的是/bin/sh -> dash,說明用的是dash
2、在DockerFile中修改CMD部分,將其設置為/bin/bash
#原先命令 CMD ./start.sh #修改為 CMD ["/bin/bash", "-c", "./start.sh"]
總結
到此這篇關於Shell編程之/bin/bash和/bin/sh區別的文章就介紹到這瞭,更多相關Shell /bin/bash和/bin/sh區別內容請搜索WalkonNet以前的文章或繼續瀏覽下面的相關文章希望大傢以後多多支持WalkonNet!
推薦閱讀:
- Docker報錯:OCI runtime exec failed: exec failed: container_linux.go:380: starting container process的解決方法
- Docker部署單頁應用的詳細操作
- 使用Dockerfile腳本定制鏡像的方法
- linux shell 編程之函數使用詳解
- 利用Dockerfile文件部署php項目的全過程