在Ubuntu中安裝Docker和docker的使用

Fengwr發表於2019-07-25

1.在Ubuntu中安裝Docker

更新ubuntu的apt源索引

sudo apt-get update

安裝包允許apt通過HTTPS使用倉庫

sudo apt-get install \
    apt-transport-https \
    ca-certificates \
    curl \
    software-properties-common

新增Docker官方GPG key

curl -fsSL https://download.docker.com/linux/ubuntu/gpg | sudo apt-key add -

設定Docker穩定版倉庫

sudo add-apt-repository \
   "deb [arch=amd64] https://download.docker.com/linux/ubuntu \
   $(lsb_release -cs) \
   stable"

新增倉庫後,更新apt源索引

sudo apt-get update

安裝最新版Docker CE(社群版)

sudo apt-get install docker-ce

檢查Docker CE是否安裝正確

sudo docker run hello-world

出現如下資訊,表示安裝成功

為了避免每次命令都輸入sudo,可以設定使用者許可權,注意執行後須登出重新登入

sudo usermod -a -G docker $USER

2.啟動與停止

安裝完成Docker後,預設已經啟動了docker服務,如需手動控制docker服務的啟停,可執行如下命令

# 啟動docker
sudo service docker start

# 停止docker
sudo service docker stop

# 重啟docker
sudo service docker restart

3. Docker映象操作

什麼是Docker映象

Docker 映象是由檔案系統疊加而成(是一種檔案的儲存形式)。最底端是一個檔案引 導系統,即 bootfs,這很像典型的 Linux/Unix 的引導檔案系統。Docker 使用者幾乎永遠不會和 引導系統有什麼互動。實際上,當一個容器啟動後,它將會被移動到記憶體中,而引導檔案系 統則會被解除安裝,以留出更多的記憶體供磁碟映象使用。Docker 容器啟動是需要一些檔案的, 而這些檔案就可以稱為 Docker 映象。

Docker 把應用程式及其依賴,打包在 image 檔案裡面。只有通過這個檔案,才能生成 Docker 容器。image 檔案可以看作是容器的模板。Docker 根據 image 檔案生成容器的例項。同一個 image 檔案,可以生成多個同時執行的容器例項。

image 是二進位制檔案。實際開發中,一個 image 檔案往往通過繼承另一個 image 檔案,加上一些個性化設定而生成。舉例來說,你可以在 Ubuntu 的 image 基礎上,往裡面加入 Apache 伺服器,形成你的 image。

image 檔案是通用的,一臺機器的 image 檔案拷貝到另一臺機器,照樣可以使用。一般來說,為了節省時間,我們應該儘量使用別人製作好的 image 檔案,而不是自己製作。即使要定製,也應該基於別人的 image 檔案進行加工,而不是從零開始製作。

為了方便共享,image 檔案製作完成後,可以上傳到網上的倉庫。Docker 的官方倉庫 Docker Hub 是最重要、最常用的 image 倉庫。此外,出售自己製作的 image 檔案也是可以的。

列出映象

docker images

  • REPOSITORY:映象所在的倉庫名稱
  • TAG:映象標籤
  • IMAGEID:映象ID
  • CREATED:映象的建立日期(不是獲取該映象的日期)
  • SIZE:映象大小

為了區分同一個倉庫下的不同映象,Docker 提供了一種稱為標籤(Tag)的功能。每個 映象在列出來時都帶有一個標籤,例如latest、 12.10、12.04 等等。每個標籤對組成特定映象的一 些映象層進行標記(比如,標籤 12.04 就是對所有 Ubuntu12.04 映象層的標記)。這種機制 使得同一個倉庫中可以儲存多個映象。

我們在執行同一個倉庫中的不同映象時,可以通過在倉庫名後面加上一個冒號和標籤名 來指定該倉庫中的某一具體的映象,例如 docker run --name custom_container_name –i –t docker.io/ubunto:12.04 /bin/bash,表明從映象 Ubuntu:12.04 啟動一個容器,而這個映象的操 作系統就是 Ubuntu:12.04。在構建容器時指定倉庫的標籤也是一個好習慣。

搜尋映象

docker search django

拉取映象

Docker維護了映象倉庫,分為共有和私有兩種,共有的官方倉庫Docker Hub(https://hub.docker.com/)是最重要最常用的映象倉庫。私有倉庫(Private Registry)是開發者或者企業自建的映象儲存庫,通常用來儲存企業 內部的 Docker 映象,用於內部開發流程和產品的釋出、版本控制。

要想獲取某個映象,我們可以使用pull命令,從倉庫中拉取映象到本地,如

docker pull hackeryx/ubuntu:16.04

刪除映象

docker image rm 映象名或映象id

4. Docker 容器操作

建立容器

docker run [option] 映象名 [向啟動容器中傳入的命令]

常用可選引數說明:

  • -i 表示以“互動模式”執行容器
  • -t 表示容器啟動後會進入其命令列。加入這兩個引數後,容器建立就能登入進去。即 分配一個偽終端。
  • --name 為建立的容器命名
  • -v 表示目錄對映關係(前者是宿主機目錄,後者是對映到宿主機上的目錄,即 宿主機目錄:容器中目錄),可以使 用多個-v 做多個目錄或檔案對映。注意:最好做目錄對映,在宿主機上做修改,然後 共享到容器上。
  • -d 在run後面加上-d引數,則會建立一個守護式容器在後臺執行(這樣建立容器後不 會自動登入容器,如果只加-i -t 兩個引數,建立後就會自動進去容器)。
  • -p 表示埠對映,前者是宿主機埠,後者是容器內的對映埠。可以使用多個-p 做多個埠對映
  • -e 為容器設定環境變數
  • --network=host 表示將主機的網路環境對映到容器中,容器的網路與主機相同

互動式容器

例如,建立一個互動式容器,並命名為myubuntu

docker run -it --name=ubuntu --network=host hackeryx/ubuntu:16.04 /bin/bash

在容器中可以隨意執行linux命令,就是一個ubuntu的環境,當執行exit命令退出時,該容器也隨之停止。

守護式容器

建立一個守護式容器:如果對於一個需要長期執行的容器來說,我們可以建立一個守護式容器。在容器內部exit退出時,容器也不會停止。

docker run -itd --name=ubuntu2 --network=host hackeryx/ubuntu:16.04

進入已執行的容器

docker exec -it 容器名或容器id 進入後執行的第一個命令
# 例如
docker exec -it ubuntu /bin/bash

檢視容器

# 列出本機所有容器,包括已經終止執行的
docker ps -a

停止與啟動容器

# 停止一個已經在執行的容器
docker container stop 容器名或容器id

# 啟動一個已經停止的容器
docker container start 容器名或容器id

# kill掉一個已經在執行的容器
docker container kill 容器名或容器id

刪除容器

docker container rm 容器名或容器id

5. 將容器儲存為映象

我們可以通過如下命令將容器儲存為映象

docker commit 容器名 映象名

6. 映象備份與遷移

我們可以通過save命令將映象打包成檔案,拷貝給別人使用

docker save -o 儲存的檔名 映象名

例如

docker save -o ./ubuntu.tar ubuntu

在拿到映象檔案後,可以通過load方法,將映象載入到本地

docker load -i ./ubuntu.tar

 

相關文章