啟動容器

啟動容器有兩種方式,一種是基於映像檔新增一個容器並啟動,另外一個是將在終止狀態(stopped)的容器重新啟動。

因為 Docker 的容器實在太輕量級了,很多時候使用者都是隨時刪除和新建立容器。

新增並啟動

所需要的指令主要為 docker run

例如,下面的指令輸出一個 「Hello World」,之後終止容器。

$ sudo docker run ubuntu:14.04 /bin/echo 'Hello world'
Hello world

這跟在本地直接執行 /bin/echo 'hello world' 幾乎感覺不出任何區別。

下面的指令則啟動一個 bash 終端機,允許使用者進行互動。

$ sudo docker run -t -i ubuntu:14.04 /bin/bash
[email protected]:/#

其中,-t 選項讓Docker指派一個偽終端機(pseudo-tty)並繫結到容器的標準輸入上, -i 則讓容器的標準輸入保持開啟。

在互動模式下,使用者可以透過所建立的終端機來輸入指令,例如

[email protected]:/# pwd
/
[email protected]:/# ls
bin boot dev etc home lib lib64 media mnt opt proc root run sbin srv sys tmp usr var

當利用 docker run 來建立容器時,Docker 在後台執行的標準作業包括:

  • 檢查本地是否存在指定的映像檔,不存在就從公有倉庫下載
  • 利用映像檔建立並啟動一個容器
  • 指派一個檔案系統,並在唯讀的映像檔層外面載入一層可讀寫層
  • 從宿主主電腦設定的橋接器介面中橋接一個虛擬介面到容器中去
  • 從位址池設定一個 ip 位址給容器
  • 執行使用者指定的應用程式
  • 執行完畢後容器被終止

啟動已終止容器

可以利用 docker start 指令,直接將一個已經終止的容器啟動執行。

容器的核心為所執行的應用程式,所需要的資源都是應用程式執行所必需的。除此之外,並沒有其它的資源。可以在偽終端機中利用 pstop 來 檢視處理序資訊。

[email protected]:/# ps
  PID TTY          TIME CMD
    1 ?        00:00:00 bash
   11 ?        00:00:00 ps

可見,容器中僅執行了指定的 bash 應用。這種特點使得 Docker 對資源的利用率極高,是貨真價實的輕量級虛擬化。

results matching ""

    No results matching ""