您好,登錄后才能下訂單哦!
一、揭開 Docker 的神秘面紗
Docker 是在Linux容器中運行的應(yīng)用的開源工具,是一種輕量級的“虛擬機”誕生于2013年,短短幾年時間,已經(jīng)成為了開源社區(qū)最火爆的項目。
.
那么為什么Docker會這么火呢?看看下圖就知道了:
作為一種輕量級的虛擬機方式,Docker 與傳統(tǒng)虛擬機相比具有顯著的優(yōu)勢。
Docker 之所以擁有眾多優(yōu)勢,與操作系統(tǒng)虛擬化自身的特點是分不開的。傳統(tǒng)虛擬機需要額外的虛擬機管理程序和虛擬機操作系統(tǒng)層,而Docker容器是直接在操作系統(tǒng)層面上實現(xiàn)的虛擬化。
Docker 的使用場景
現(xiàn)在開發(fā)者需要能方便地創(chuàng)建運行在云平臺上的應(yīng)用,必須要脫離底層硬件,同時還需要任何時間地點可獲取這些資源,這正是Docker所能提供的。Docker 的容器技術(shù)可以在一臺主機上輕松為任何應(yīng)用創(chuàng)建一個輕量級的、可移植的、自給自足的容器。通過這中容器打包應(yīng)用程序,意味著簡化了重新部署、調(diào)試這些瑣碎的重復(fù)工作,極大的提高了工作效率。例如,服務(wù)器從騰訊云遷移到阿里云,如果采用Docker容器技術(shù),遷移只需要在新的服務(wù)器上啟動需要的容器即可。
二、Docker 的核心概念:
1.鏡像
Docker的鏡像(mage) 是創(chuàng)建容器的基礎(chǔ),類似虛擬機的快照.可以理解為是一個 面向Docker 容器引擎的只讀模板。比如,一個鏡像可以是一個完整的 CentOS操作系統(tǒng)環(huán)境,稱為一個CentOS 鏡像;可以是一個安裝了MySQL的應(yīng)用程序.稱為一個MySOL鏡像.等等
Doacker提供了簡單的機制來創(chuàng)建和更新現(xiàn)有的鏡像.用戶也可以從網(wǎng)上下載已經(jīng)做好的應(yīng)用鏡像來直接使用。
2.容器
Docker的容器(Conainer! 是從鏡像創(chuàng)建的運行實例,它可以被啟動.停止和刪除。所創(chuàng)建的每個容器都是相互隔離.互不可見,可以保證安全性的平臺。可以把容器看作一個簡易版的Linux環(huán)境,Docker 利用容器來運行和隔離應(yīng)用。
3.倉庫
Docker倉庫(Repository) 是用來集中保存鏡像的地方,當(dāng)創(chuàng)建了自己的鏡像之后,可以使用push 命令將它上傳到公有倉庫(Pbli) 或者私有倉庫(Private), 這樣一來當(dāng)下次要 在另外一臺機器上使用這個鏡像時,只需要從倉庫上拉取下來就可以了。
倉庫注冊服務(wù)器(Registry) 是存放倉庫的地方,其中包含了多個倉庫,每個倉庫集中存放某一類鏡像,并且使用不同的標(biāo)簽(Tag) 來區(qū)分它們,目前最大的公共倉庫是Docker Hb,存放了數(shù)量龐大的鏡像供用戶下載使用。
三、安裝Docker
Centos 系統(tǒng)下安裝 Docker 可以有兩種方式:一種是使用 curl 獲得 Docker 的安裝腳本進(jìn)行安裝。另一種是使用 YUM 倉庫來安裝Docker。
注意:目前Docker只能支持64位操作系統(tǒng)
注意:目前Docker只能支持64位操作系統(tǒng)
注意:目前Docker只能支持64位操作系統(tǒng)
這里我使用的是Docker自己的YUM源進(jìn)行安裝
開始安裝:
[root@test /]# yum -y install docker # 安裝docker
[root@test /]# systemctl start docker # 啟動服務(wù)
[root@test /]# systemctl enable docker # 設(shè)為開機自啟動
Created symlink from /etc/systemd/system/multi-user.target.wants/docker.service to /usr/lib/systemd/system/docker.service.
安裝好的Docker有兩個程序:Docker服務(wù)端和Docker客戶端。其中Docker服務(wù)進(jìn)程,管理著所有的容器。Docker 客戶端則扮演著Docker服務(wù)端的遠(yuǎn)程控制器,可以用來控制 Docker 的服務(wù)端進(jìn)程。大部分的情況下,Docker服務(wù)端和客戶端運行在一臺機器上。
[root@test /]# docker version
Client:
Version: 1.13.1
API version: 1.26
Package version: docker-1.13.1-75.git8633870.el7.centos.x86_64
Go version: go1.9.4
Git commit: 8633870/1.13.1
Built: Fri Sep 28 19:45:08 2018
OS/Arch: linux/amd64
Server:
Version: 1.13.1
API version: 1.26 (minimum version 1.12)
Package version: docker-1.13.1-75.git8633870.el7.centos.x86_64
Go version: go1.9.4
Git commit: 8633870/1.13.1
Built: Fri Sep 28 19:45:08 2018
OS/Arch: linux/amd64
Experimental: false
Docker 鏡像操作
Docker 運行容器前需要本地存在對應(yīng)的鏡像,如果不存在本地鏡像,Docker 就會嘗試從默認(rèn)鏡像倉庫 https://hub.docker.com 處下載,這是一個由 Docker 官方維護(hù)的一個公共倉庫。
1、搜索鏡像:
[root@test /]# docker search dhcp # 命令格式 docker search 關(guān)鍵字
INDEX NAME DESCRIPTION STARS OFFICIAL AUTOMATED
docker.io docker.io/networkboot/dhcpd Suitable for running a DHCP server for you... 43 [OK]
docker.io docker.io/joebiellik/dhcpd DHCP server running on Alpine Linux 15 [OK]
docker.io docker.io/gns3/dhcp A DHCP container for GNS3 using dnsmasq 3 [OK]
............... // 省略部分內(nèi)容
2、獲取鏡像:
搜索到符合的鏡像,可以使用docker pull 進(jìn)行下載到本地
[root@test /]# docker pull docker.io/networkboot/dhcpd
Using default tag: latest
Trying to pull repository docker.io/networkboot/dhcpd ...
latest: Pulling from docker.io/networkboot/dhcpd
898c46f3b1a1: Downloading 5.602 MB/32.47 MB
63366dfa0a50: Download complete
041d4cd74a92: Download complete
6e1bee0f8701: Download complete
114483241095: Downloading 3.693 MB/6.702 MB
ef446bdcb1f0: Waiting
3、查看鏡像信息:
[root@test /]# docker images
REPOSITORY TAG IMAGE ID CREATED SIZE
docker.io/networkboot/dhcpd latest 52cbff801df2 8 months ago 105 MB
從回顯的信息中可以讀出:
REPOSITORY:鏡像屬于的倉庫
TAG:鏡像的標(biāo)簽信息,標(biāo)記同一個倉庫的不同鏡像
IMAGE ID :鏡像的唯一ID號,唯一標(biāo)識了該鏡像
CREATED:鏡像創(chuàng)建時間
VIRTUAL SIZE:鏡像大小
用戶可根據(jù)鏡像的唯一標(biāo)識ID號,獲取鏡像的詳細(xì)信息:
[root@test /]# docker inspect 52cbff801df2
[
{
"Id": "sha256:52cbff801df2c6e2da3866d9f9476f20f190f64a0e886fbdfa79d843befa666a",
"RepoTags": [
"docker.io/networkboot/dhcpd:latest"
],
............................... // 省略部分內(nèi)容
鏡像的詳細(xì)信息包含了創(chuàng)建時間、系統(tǒng)版本、主機名、域名、用戶、卷、標(biāo)簽、操作系統(tǒng)、設(shè)備ID等各種信息。
為了方便使用,可為本地的鏡像添加新標(biāo)簽:
[root@test /]# docker tag docker.io/networkboot/dhcpd dhcp:dhcp
[root@test /]# docker images
REPOSITORY TAG IMAGE ID CREATED SIZE
dhcp dhcp 52cbff801df2 8 months ago 105 MB
docker.io/networkboot/dhcpd latest 52cbff801df2 8 months ago 105 MB
4、刪除鏡像:
命令格式:
docker rmi 倉庫名稱:標(biāo)簽
或者
docker rmi 鏡像ID號
當(dāng)使用 docker rmi 命令后面跟上鏡像的 ID 號時,必須確保該鏡像沒有被容器正在使用才能進(jìn)行,刪除時系統(tǒng)會先刪除所有指向該鏡像的標(biāo)簽,然后刪除該鏡像文件本身。如果該鏡像已經(jīng)被容器使用,正確的做法是先刪除依賴該鏡像的所有容器,再去刪除鏡像。
5、存出和載入鏡像:
存出
[root@test /]# docker save -o /tmp/dhcp docker.io/networkboot/dhcpd
[root@test /]# ll -d /tmp/dhcp
-rw------- 1 root root 107891712 Nov 25 17:56 /tmp/dhcp
載入
[root@test tmp]# docker load --input dhcp
[root@test tmp]# docker load < dhcp
6、上傳鏡像:
本地存出的鏡像越來越多,就需要指定一個專門存放這些鏡像的地方——倉庫,目前比較方便的就是公共倉庫,默認(rèn)上傳到 DockerHub 官方倉庫,需要注冊使用公共倉庫的賬號,可以使用docker login 命令來輸入用戶名、密碼和郵箱來注冊和登陸。在上傳鏡像之前還需要對本地鏡像添加新的標(biāo)簽,然后再使用docker push來進(jìn)行上傳。
例如: 在公共倉庫上已經(jīng)注冊了一個賬號,本例賬號為test,鏡像標(biāo)簽為docker/dhcp:centos7.3
(1)首先使用賬號登錄官方倉庫:
[root@test /]# docker login
Login with your Docker ID to push and pull images from Docker Hub. If you don't have a Docker ID, head over to https://hub.docker.com to create one.
Username: test # 輸入賬號
Password: # 輸入密碼
Login Succeeded
(2)成功登陸后就可以上傳鏡像:
[root@test /]# docker push docker/dhcp:centos7.3
Docker 容器操作
容器是Docker的另一個核心概念,簡單來說,容器就是鏡像的一個運行實例,是獨立運行的一個或一組應(yīng)用及它們所必須的運行環(huán)境,包括文件系統(tǒng)、系統(tǒng)類庫、shell環(huán)境等。鏡像是只讀模板,而容器會給這個只讀模板一個額外的可寫層。
1、容器的創(chuàng)建與啟動:
Docker 的創(chuàng)建就是鏡像加載到容器的過程,Docker 的容器十分輕量級,用戶可以隨時創(chuàng)建或刪除。新創(chuàng)建的容器默認(rèn)處于停止?fàn)顟B(tài),不運行任何程序,需要在其中發(fā)起一個進(jìn)程來啟動容器,這個進(jìn)程就是該容器的唯一進(jìn)程,所以當(dāng)該進(jìn)程結(jié)束的時候,容器也會完全停止。停止的容器可以重新啟動并保留原來的修改。
[root@test /]# docker create -it docker.io/networkboot/dhcpd /bin/bash # 創(chuàng)建容器
08ab448cd0be320b24d6878b377bfa6957127c7ffb4c7e050e64340deeee1562
# -i 表示讓容器的輸入保持打開;-t 表示讓Docker分配一個偽終端
如果此處創(chuàng)建容器命令報錯“WARNING: IPv4 forwarding is disabled.Networking will notwork." ,就使用vi編輯器打開/usr/lib/sysctl.d/00-system.conf文件,在其中添加net.ipv4.ip_ forward=1, 然后使用service network start命令重啟網(wǎng)絡(luò)服務(wù)。
使用docker create 命令創(chuàng)建新容器后會返回一個唯一的ID。
[root@test /]# docker ps -a # 查看所有容器的運行狀態(tài) -a 可以列出系統(tǒng)最近一次啟動的容器
CONTAINER ID IMAGE COMMAND CREATED STATUS PORTS NAMES
08ab448cd0be docker.io/networkboot/dhcpd "/entrypoint.sh /b..." 5 minutes ago Created keen_payne
命令格式: docker start 容器的ID/名稱
[root@test /]# docker start 08ab448cd0be # 可跟容器的ID與名稱
08ab448cd0be
[root@test /]# docker ps -a | grep 08ab448cd0be
08ab448cd0be docker.io/networkboot/dhcpd "/entrypoint.sh /b..." 8 minutes ago Up About a minute keen_payne
# 容器啟動后,可以看到容器狀態(tài)一欄已經(jīng)變成了 UP ,表示容器已經(jīng)處于啟動狀態(tài)
2、容器的運行與停止:
[root@test /]# docker stop 08ab448cd0be
08ab448cd0be
[root@test /]# docker ps -a
CONTAINER ID IMAGE COMMAND CREATED STATUS PORTS NAMES
08ab448cd0be docker.io/networkboot/dhcpd "/entrypoint.sh /b..." 10 minutes ago Exited (0) 5 seconds ago keen_payne
# 查看容器的運行狀態(tài),可以看出容器處于Exited,中止?fàn)顟B(tài)。
3、容器的進(jìn)入:
[root@test /]# docker exec -it 08ab448cd0be /bin/bash
# -i 表示讓容器的輸入保持打開;-t 表示讓Docker分配一個偽終端
root@08ab448cd0be:/# ls # 已經(jīng)進(jìn)入到了容器中
bin boot dev entrypoint.sh etc home lib lib64 media mnt opt proc root run sbin srv sys tmp usr var
root@08ab448cd0be:/# exit
exit
[root@test /]#
4、容器的導(dǎo)出與導(dǎo)入:
用戶可以將任何一個 Docker 容器從一臺機器遷移到另一臺機器。在遷移過程中,首先需要將已經(jīng)創(chuàng)建好的容器導(dǎo)出為文件,可以使用 docker export 命令實現(xiàn),無論這個容器是處于運行還是停止均可導(dǎo)出。導(dǎo)出之后可將導(dǎo)出文件傳輸?shù)狡渌麢C器,通過相應(yīng)的導(dǎo)入命令實現(xiàn)容器的遷移。
命令格式:docker export 容器ID/名稱>文件名
[root@test /]# docker export 08ab448cd0be>centos7dhcp
[root@test /]# ll -d centos7dhcp
-rw-r--r-- 1 root root 87825920 Nov 25 19:58 centos7dhcp
導(dǎo)出的文件從A機器復(fù)制到B機器,之后使用docker import 命令導(dǎo)入,成為鏡像 。
命令格式:cat 文件名 | docker import - 生成的鏡像名稱:標(biāo)簽
[root@test /]# cat centos7dhcp | docker import - centos7:dhcp
sha256:e7193f77c973a89dd2d1046f09eb4328798f4ee9dff92ad13514fb7268bc3c27
[root@test /]# docker images | grep centos7
centos7 dhcp e7193f77c973 17 seconds ago 84.7 MB
5、容器的刪除:
命令格式:docker rm 容器ID/名稱
[root@test /]# docker stop 08ab448cd0be
08ab448cd0be
[root@test /]# docker rm 08ab448cd0be
08ab448cd0be
[root@test /]# docker ps -a
CONTAINER ID IMAGE COMMAND CREATED STATUS PORTS NAMES
# 如果刪除一個正在運行的容器,可以添加 -f 選項強制刪除,但是建議先將容器停止再做刪除操作
Docker 默認(rèn)的存儲目錄在/var/lib/docker ,Docker 的鏡像、容器、日志等內(nèi)容全部存儲在此,可以單獨使用大容量的的分區(qū)來存儲這些內(nèi)容,并且一般選擇建立LVM邏輯卷,從而避免 Docker 運行過程中存儲目錄容量不足的問題。
免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進(jìn)行舉報,并提供相關(guān)證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權(quán)內(nèi)容。