如何做好生產(chǎn)環(huán)境和開發(fā)環(huán)境的隔離?
Docker的優(yōu)勢在于環(huán)境的隔離和復(fù)用。
比如你有10個應(yīng)用要用到nginx,傳統(tǒng)的做法可能寫成1(10)個配置文件,這樣如果這1(10)個配置文件有個被修改出錯了,nginx就無法啟動了,你所有的應(yīng)用都無法訪問了。
再比如你服務(wù)器上裝了一個mysql程序,10個應(yīng)用都是連接的它,但是有1個應(yīng)用占用較多的連接數(shù)或者在瘋狂消耗IO,那么其它應(yīng)用訪問數(shù)據(jù)庫的性能都會下降。
最后比如不同的java程序依賴不同的jdk,那么這時候就要指定一堆的環(huán)境變量,安裝多個jdk。
容器就可以把以上內(nèi)容封裝成相互對立的執(zhí)行環(huán)境,避免相互影響。
復(fù)用就更好理解了,如果你在調(diào)試docker容器的某個問題,不小心導(dǎo)致程序崩潰了,沒關(guān)系,利用鏡像重新啟動一個容器就恢復(fù)了。
又比如你要排查線上環(huán)境的一個問題,為了百分之百模擬環(huán)境,你可以直接把docker容器提交成鏡像,然后在本地開發(fā)環(huán)境上運行容器,隨意調(diào)試。