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!

推薦閱讀: