真实的国产乱ⅩXXX66竹夫人,五月香六月婷婷激情综合,亚洲日本VA一区二区三区,亚洲精品一区二区三区麻豆

成都創(chuàng)新互聯(lián)網(wǎng)站制作重慶分公司

Docker是什么,怎么裝,怎么用

一、揭開(kāi) Docker 的神秘面紗
Docker 是在Linux容器中運(yùn)行的應(yīng)用的開(kāi)源工具,是一種輕量級(jí)的“虛擬機(jī)”誕生于2013年,短短幾年時(shí)間,已經(jīng)成為了開(kāi)源社區(qū)最火爆的項(xiàng)目。
.
那么為什么Docker會(huì)這么火呢?看看下圖就知道了:
Docker 是什么,怎么裝,怎么用

青神網(wǎng)站制作公司哪家好,找創(chuàng)新互聯(lián)建站!從網(wǎng)頁(yè)設(shè)計(jì)、網(wǎng)站建設(shè)、微信開(kāi)發(fā)、APP開(kāi)發(fā)、響應(yīng)式網(wǎng)站等網(wǎng)站項(xiàng)目制作,到程序開(kāi)發(fā),運(yùn)營(yíng)維護(hù)。創(chuàng)新互聯(lián)建站自2013年起到現(xiàn)在10年的時(shí)間,我們擁有了豐富的建站經(jīng)驗(yàn)和運(yùn)維經(jīng)驗(yàn),來(lái)保證我們的工作的順利進(jìn)行。專注于網(wǎng)站建設(shè)就選創(chuàng)新互聯(lián)建站。

作為一種輕量級(jí)的虛擬機(jī)方式,Docker 與傳統(tǒng)虛擬機(jī)相比具有顯著的優(yōu)勢(shì)。
Docker 之所以擁有眾多優(yōu)勢(shì),與操作系統(tǒng)虛擬化自身的特點(diǎn)是分不開(kāi)的。傳統(tǒng)虛擬機(jī)需要額外的虛擬機(jī)管理程序和虛擬機(jī)操作系統(tǒng)層,而Docker容器是直接在操作系統(tǒng)層面上實(shí)現(xiàn)的虛擬化。
Docker 是什么,怎么裝,怎么用
Docker 的使用場(chǎng)景
現(xiàn)在開(kāi)發(fā)者需要能方便地創(chuàng)建運(yùn)行在云平臺(tái)上的應(yīng)用,必須要脫離底層硬件,同時(shí)還需要任何時(shí)間地點(diǎn)可獲取這些資源,這正是Docker所能提供的。Docker 的容器技術(shù)可以在一臺(tái)主機(jī)上輕松為任何應(yīng)用創(chuàng)建一個(gè)輕量級(jí)的、可移植的、自給自足的容器。通過(guò)這中容器打包應(yīng)用程序,意味著簡(jiǎn)化了重新部署、調(diào)試這些瑣碎的重復(fù)工作,極大的提高了工作效率。例如,服務(wù)器從騰訊云遷移到阿里云,如果采用Docker容器技術(shù),遷移只需要在新的服務(wù)器上啟動(dòng)需要的容器即可。
二、Docker 的核心概念
1.鏡像
Docker的鏡像(mage) 是創(chuàng)建容器的基礎(chǔ),類似虛擬機(jī)的快照.可以理解為是一個(gè) 面向Docker 容器引擎的只讀模板。比如,一個(gè)鏡像可以是一個(gè)完整的 CentOS操作系統(tǒng)環(huán)境,稱為一個(gè)CentOS 鏡像;可以是一個(gè)安裝了MySQL的應(yīng)用程序.稱為一個(gè)MySOL鏡像.等等
Doacker提供了簡(jiǎn)單的機(jī)制來(lái)創(chuàng)建和更新現(xiàn)有的鏡像.用戶也可以從網(wǎng)上下載已經(jīng)做好的應(yīng)用鏡像來(lái)直接使用。
2.容器
Docker的容器(Conainer! 是從鏡像創(chuàng)建的運(yùn)行實(shí)例,它可以被啟動(dòng).停止和刪除。所創(chuàng)建的每個(gè)容器都是相互隔離.互不可見(jiàn),可以保證安全性的平臺(tái)。可以把容器看作一個(gè)簡(jiǎn)易版的Linux環(huán)境,Docker 利用容器來(lái)運(yùn)行和隔離應(yīng)用。
3.倉(cāng)庫(kù)
Docker倉(cāng)庫(kù)(Repository) 是用來(lái)集中保存鏡像的地方,當(dāng)創(chuàng)建了自己的鏡像之后,可以使用push 命令將它上傳到公有倉(cāng)庫(kù)(Pbli) 或者私有倉(cāng)庫(kù)(Private), 這樣一來(lái)當(dāng)下次要 在另外一臺(tái)機(jī)器上使用這個(gè)鏡像時(shí),只需要從倉(cāng)庫(kù)上拉取下來(lái)就可以了。
倉(cāng)庫(kù)注冊(cè)服務(wù)器(Registry) 是存放倉(cāng)庫(kù)的地方,其中包含了多個(gè)倉(cāng)庫(kù),每個(gè)倉(cāng)庫(kù)集中存放某一類鏡像,并且使用不同的標(biāo)簽(Tag) 來(lái)區(qū)分它們,目前最大的公共倉(cāng)庫(kù)是Docker Hb,存放了數(shù)量龐大的鏡像供用戶下載使用。
三、安裝Docker
Centos 系統(tǒng)下安裝 Docker 可以有兩種方式:一種是使用 curl 獲得 Docker 的安裝腳本進(jìn)行安裝。另一種是使用 YUM 倉(cāng)庫(kù)來(lái)安裝Docker。
注意:目前Docker只能支持64位操作系統(tǒng)
注意:目前Docker只能支持64位操作系統(tǒng)
注意:目前Docker只能支持64位操作系統(tǒng)
這里我使用的是Docker自己的YUM源進(jìn)行安裝
開(kāi)始安裝:

[root@test /]# yum -y install docker             # 安裝docker
[root@test /]# systemctl start docker              # 啟動(dòng)服務(wù)
[root@test /]# systemctl enable docker           # 設(shè)為開(kāi)機(jī)自啟動(dòng)
Created symlink from /etc/systemd/system/multi-user.target.wants/docker.service to /usr/lib/systemd/system/docker.service.

安裝好的Docker有兩個(gè)程序:Docker服務(wù)端和Docker客戶端。其中Docker服務(wù)進(jìn)程,管理著所有的容器。Docker 客戶端則扮演著Docker服務(wù)端的遠(yuǎn)程控制器,可以用來(lái)控制 Docker 的服務(wù)端進(jìn)程。大部分的情況下,Docker服務(wù)端和客戶端運(yùn)行在一臺(tái)機(jī)器上。

[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ùn)行容器前需要本地存在對(duì)應(yīng)的鏡像,如果不存在本地鏡像,Docker 就會(huì)嘗試從默認(rèn)鏡像倉(cāng)庫(kù) https://hub.docker.com 處下載,這是一個(gè)由 Docker 官方維護(hù)的一個(gè)公共倉(cāng)庫(kù)。
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:鏡像屬于的倉(cāng)庫(kù)
TAG:鏡像的標(biāo)簽信息,標(biāo)記同一個(gè)倉(cāng)庫(kù)的不同鏡像
IMAGE ID :鏡像的唯一ID號(hào),唯一標(biāo)識(shí)了該鏡像
CREATED:鏡像創(chuàng)建時(shí)間
VIRTUAL SIZE:鏡像大小

用戶可根據(jù)鏡像的唯一標(biāo)識(shí)ID號(hào),獲取鏡像的詳細(xì)信息:

[root@test /]# docker inspect 52cbff801df2
[
    {
        "Id": "sha256:52cbff801df2c6e2da3866d9f9476f20f190f64a0e886fbdfa79d843befa666a",
        "RepoTags": [
            "docker.io/networkboot/dhcpd:latest"
        ],
...............................  // 省略部分內(nèi)容

鏡像的詳細(xì)信息包含了創(chuàng)建時(shí)間、系統(tǒng)版本、主機(jī)名、域名、用戶、卷、標(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  倉(cāng)庫(kù)名稱:標(biāo)簽
或者
docker rmi   鏡像ID號(hào)

當(dāng)使用 docker rmi 命令后面跟上鏡像的 ID 號(hào)時(shí),必須確保該鏡像沒(méi)有被容器正在使用才能進(jìn)行,刪除時(shí)系統(tǒng)會(huì)先刪除所有指向該鏡像的標(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、上傳鏡像:
本地存出的鏡像越來(lái)越多,就需要指定一個(gè)專門(mén)存放這些鏡像的地方——倉(cāng)庫(kù),目前比較方便的就是公共倉(cāng)庫(kù),默認(rèn)上傳到 DockerHub 官方倉(cāng)庫(kù),需要注冊(cè)使用公共倉(cāng)庫(kù)的賬號(hào),可以使用docker login 命令來(lái)輸入用戶名、密碼和郵箱來(lái)注冊(cè)和登陸。在上傳鏡像之前還需要對(duì)本地鏡像添加新的標(biāo)簽,然后再使用docker push來(lái)進(jìn)行上傳。
例如:在公共倉(cāng)庫(kù)上已經(jīng)注冊(cè)了一個(gè)賬號(hào),本例賬號(hào)為test,鏡像標(biāo)簽為docker/dhcp:centos7.3
(1)首先使用賬號(hào)登錄官方倉(cāng)庫(kù):

[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                       # 輸入賬號(hào)
Password:                               # 輸入密碼
Login  Succeeded

(2)成功登陸后就可以上傳鏡像:

[root@test /]# docker push docker/dhcp:centos7.3

Docker 容器操作
容器是Docker的另一個(gè)核心概念,簡(jiǎn)單來(lái)說(shuō),容器就是鏡像的一個(gè)運(yùn)行實(shí)例,是獨(dú)立運(yùn)行的一個(gè)或一組應(yīng)用及它們所必須的運(yùn)行環(huán)境,包括文件系統(tǒng)、系統(tǒng)類庫(kù)、shell環(huán)境等。鏡像是只讀模板,而容器會(huì)給這個(gè)只讀模板一個(gè)額外的可寫(xiě)層。
1、容器的創(chuàng)建與啟動(dòng):
Docker 的創(chuàng)建就是鏡像加載到容器的過(guò)程,Docker 的容器十分輕量級(jí),用戶可以隨時(shí)創(chuàng)建或刪除。新創(chuàng)建的容器默認(rèn)處于停止?fàn)顟B(tài),不運(yùn)行任何程序,需要在其中發(fā)起一個(gè)進(jìn)程來(lái)啟動(dòng)容器,這個(gè)進(jìn)程就是該容器的唯一進(jìn)程,所以當(dāng)該進(jìn)程結(jié)束的時(shí)候,容器也會(huì)完全停止。停止的容器可以重新啟動(dòng)并保留原來(lái)的修改。

[root@test /]# docker create -it docker.io/networkboot/dhcpd /bin/bash           # 創(chuàng)建容器
08ab448cd0be320b24d6878b377bfa6957127c7ffb4c7e050e64340deeee1562
# -i 表示讓容器的輸入保持打開(kāi);-t 表示讓Docker分配一個(gè)偽終端

如果此處創(chuàng)建容器命令報(bào)錯(cuò)“WARNING: IPv4 forwarding is disabled.Networking will notwork." ,就使用vi編輯器打開(kāi)/usr/lib/sysctl.d/00-system.conf文件,在其中添加net.ipv4.ip_ forward=1, 然后使用service network start命令重啟網(wǎng)絡(luò)服務(wù)。

使用docker create 命令創(chuàng)建新容器后會(huì)返回一個(gè)唯一的ID。

[root@test /]# docker ps -a                 # 查看所有容器的運(yùn)行狀態(tài)        -a 可以列出系統(tǒng)最近一次啟動(dò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
# 容器啟動(dòng)后,可以看到容器狀態(tài)一欄已經(jīng)變成了 UP ,表示容器已經(jīng)處于啟動(dòng)狀態(tài)

2、容器的運(yùn)行與停止:

[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
# 查看容器的運(yùn)行狀態(tài),可以看出容器處于Exited,中止?fàn)顟B(tài)。

3、容器的進(jìn)入:

[root@test /]# docker exec -it 08ab448cd0be /bin/bash
#  -i 表示讓容器的輸入保持打開(kāi);-t 表示讓Docker分配一個(gè)偽終端
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)入:
用戶可以將任何一個(gè) Docker 容器從一臺(tái)機(jī)器遷移到另一臺(tái)機(jī)器。在遷移過(guò)程中,首先需要將已經(jīng)創(chuàng)建好的容器導(dǎo)出為文件,可以使用 docker export 命令實(shí)現(xiàn),無(wú)論這個(gè)容器是處于運(yùn)行還是停止均可導(dǎo)出。導(dǎo)出之后可將導(dǎo)出文件傳輸?shù)狡渌麢C(jī)器,通過(guò)相應(yīng)的導(dǎo)入命令實(shí)現(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機(jī)器復(fù)制到B機(jī)器,之后使用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
# 如果刪除一個(gè)正在運(yùn)行的容器,可以添加 -f 選項(xiàng)強(qiáng)制刪除,但是建議先將容器停止再做刪除操作

Docker 默認(rèn)的存儲(chǔ)目錄在/var/lib/docker ,Docker 的鏡像、容器、日志等內(nèi)容全部存儲(chǔ)在此,可以單獨(dú)使用大容量的的分區(qū)來(lái)存儲(chǔ)這些內(nèi)容,并且一般選擇建立LVM邏輯卷,從而避免 Docker 運(yùn)行過(guò)程中存儲(chǔ)目錄容量不足的問(wèn)題。


網(wǎng)站名稱:Docker是什么,怎么裝,怎么用
當(dāng)前地址:http://weahome.cn/article/pgdhss.html

其他資訊

在線咨詢

微信咨詢

電話咨詢

028-86922220(工作日)

18980820575(7×24)

提交需求

返回頂部