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