中文字幕av专区_日韩电影在线播放_精品国产精品久久一区免费式_av在线免费观看网站

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

Docker容器的介紹和容器的使用

發布時間:2020-06-03 17:11:54 來源:億速云 閱讀:279 作者:Leah 欄目:系統運維

這篇文章的知識點包括:Docker容器的簡介、Docker容器的優勢、Docker容器的核心理念以及Docker容器的使用,閱讀完整文相信大家對Docker容器有了一定的認識。

一、Docker簡介

官網 www.docker.com

github  https://github.com/docker/docker.github.io

開源的容器引擎,可以讓開發者打包應用以及依賴的庫,然后發布到任何流行的linux發行版上,移植很方便。

由go語言編寫,基于apache2.0協議發布。

基于linux kernel,要想在win下運行需要借助一個vm(虛擬機)來實現。

自2013年開始,近些年發展迅猛。

docker從1.13x開始,版本分為社區版ce和企業版ee,并且基于年月的時間線形式,比如18.03就是2018年3月,當前最新穩定版為18.09參考。

Docker版本變化說明:http://blog.csdn.net/chenhaifeng2016/article/details/68062414

Docker和傳統的虛擬化比較:

Docker容器的介紹和容器的使用

Docker容器的介紹和容器的使用

Docker也叫容器虛擬化,因為少了一層操作系統,所以也是輕量虛擬化。

最下面一層是服務器,硬件,往上一層是host OS,Linux操作系統,再往上,傳統的有一個Hypervisor,就比如KVM,需要安裝一個KVM的服務來驅動虛擬化,docker需要安裝一個docker的服務,第三層是類似的,再往上就不一樣了,docker不需要安裝客戶虛擬機,而傳統的安裝完KVM以后還需要新建虛擬機,在這個虛擬機上再去安裝一個操作系統。

Docker的優勢

啟動非常快,秒級實現。

資源利用率高,一臺高配置服務器可以跑上千個docker容器。

更快的交付和部署,一次創建和配置后,可以在任意地方運行。

內核級別的虛擬化,不需要額外的hypevisor支持,會有更高的性能和效率。不需要虛擬化CPU、內存等等的服務。

易遷移,平臺依賴性不強。可以在Linux下搞一個鏡像,把這個鏡像放到Windows下去運行。

下圖是docker和虛擬機的特性對比:

Docker容器的介紹和容器的使用

Docker的核心理念

鏡像,是一個只讀的模板,類似于安裝系統用到的那個iso文件,我們通過鏡像來完成各種應用的部署。

容器,鏡像類似于操作系統,而容器類似于虛擬機本身。它可以被啟動、開始、停止、刪除等操作,每個容器都是相互隔離的。

倉庫,存放鏡像的一個場所,倉庫分為公開倉庫和私有倉庫。 最大的公開倉庫是Docker hub(hub.docker.com),國內公開倉庫(dockerpool.com)


二、安裝Docker

先下載一個官方提供的yum源

# curl https://download.docker.com/linux/centos/docker-ce.repo -o  /etc/yum.repos.d/docker.repo
# yum list |grep docker-ce   可以看到最新版是19.03
docker-ce.x86_64                        3:19.03.5-3.el7                docker-ce-stable
# yum install -y docker-ce

速度比較慢,也可以直接下載rpm包

https://download.docker.com/linux/centos/7/x86_64/stable/Packages/

下載完,上傳到linux下

也需要用yum安裝,可以自動解決依賴關系

# yum install -y docker-ce-xxxx.rpm
# systemctl start docker  啟動docker

啟動以后,它會幫你自動生成一些iptables規則,但是這個規則不會自動保存,要想保存它,執行service iptables save。一般作為docker的服務器,iptables規則盡量不要去動它。

# iptables -t nat -F
# iptables -t nat -nvL
# systemctl restart docker
# iptables -t nat -nvL
清空規則再重啟docker后,規則會回來,但是得要先保存。


三、鏡像管理

類似于系統的iso鏡像文件。

# docker pull centos  //可以下載centos鏡像,速度很慢。直接到官網拉取一個鏡像。

docker pull類似于git pull。

配置docker加速器(參考 http://blog.csdn.net/xlemonok/article/details/71403534)

# vi /etc/docker/daemon.json//加入如下內容
{
  "registry-mirrors": ["https://dhq9bx4f.mirror.aliyuncs.com"]
}

說明:這個url為加速器地址,需要自行到阿里云申請。

配置完加速器,重啟docker服務,再次docker pull centos會快很多。

docker images 查看本地的鏡像
[root@fuxi01 ~]# docker images
REPOSITORY          TAG                 IMAGE ID            CREATED             SIZE
centos              latest              0f3e07c0138f        3 months ago        220MB

TAG:標簽,每個鏡像可以有很多個標簽。latest這個是版本標簽。

IMAGE ID:用來區分系統里每個鏡像的ID,區分鏡像的唯一標識。

# docker search xxx  //官方有哪些鏡像,用search搜索鏡像,其中xxx是關鍵詞,比如jumpserver,就會把jumpserver相關的docker
# docker tag centos yw_centos //給鏡像打標簽
# docker tag centos centos:111 
# docker images
REPOSITORY          TAG                 IMAGE ID            CREATED             SIZE
ubuntu              latest              549b9b86cb8d        13 days ago         64.2MB
yw_centos           latest              0f3e07c0138f        3 months ago        220MB
centos              111                 0f3e07c0138f        3 months ago        220MB
centos              latest              0f3e07c0138f        3 months ago        220MB

不加冒號,則打的標簽在第一列,加了冒號,后面打的標識在TAG那,第二列。

# docker run -itd centos  
43aae89a76aef04cab62efcf6c4ec2f24a29f69db192125b0d72b2e111af69ba

//docker run把鏡像啟動為容器,-i表示讓容器的標準輸入打開,-t表示分配一個偽終端,-d表示后臺啟動,要把-i -t -d 放到鏡像名字前面。

# docker ps  //查看運行的容器,加上-a選項后可以查看所有容器,包括未運行的,docker ps -a。
CONTAINER ID        IMAGE               COMMAND             CREATED              STATUS              PORTS               NAMES
43aae89a76ae        centos              "/bin/bash"         About a minute ago   Up 24 seconds                           serene_kare
# docker rmi centos  
# docker rmi centos:111
Untagged: centos:111

//用來刪除指定鏡像, rm就是刪除,i就是images,其中后面的參數可以是tag,如果是tag時,實際上是刪除該tag。當后面的參數為鏡像ID時,則會徹底刪除整個鏡像,所有標簽也會一同刪除。當有同名鏡像,而tag不同時,需要把tag加上才能刪除。


四、Docker通過容器創建鏡像

docker run啟動為容器后,可以通過下面命令進入容器

# docker exec -it 43aae89 bash
# docker exec -it infallible_lalande bash

//其中43aae89為容器id,這個id可以用docker ps查看,也可以不寫容器ID,寫它的names,在docker ps中可以查看到,最后面的bash為進入容器后要執行的命令,這樣就可以打開一個終端。

進入到該容器中,做一些變更,比如安裝一些東西,然后針對這個容器進行創建新的鏡像。


在容器中執行 yum install -y net-tools,然后ctrl d退出容器,ifconfig可以看到有docker0的網卡。

# docker commit -m "change somth"  -a "somebody info" container_id new_image_name

//container_id通過docker ps -a獲取,后面的new_image_name為新鏡像名字

例如:

# docker commit -m "install net-tools" -a "aminglinux" 43aae89 centos_with_net

這個命令有點像svn的提交,-m 加一些改動信息,-a 指定作者相關信息,43aae89這一串為容器id,再后面為新鏡像的名字。

# docker images
REPOSITORY          TAG                 IMAGE ID            CREATED             SIZE
centos_with_net     latest              2803335f23a6        33 seconds ago      261MB
ubuntu              latest              549b9b86cb8d        3 weeks ago         64.2MB
centos              latest              0f3e07c0138f        3 months ago        220MB
yw_centos           latest              0f3e07c0138f        3 months ago        220MB

執行docker images就可以看到新的鏡像了。

看完上述內容,你們對Docker容器有進一步的了解嗎?如果還想學到更多技能或想了解更多相關內容,歡迎關注億速云行業資訊頻道,感謝各位的閱讀。

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

黎平县| 克山县| 长海县| 屯门区| 阳高县| 隆化县| 和顺县| 红河县| 孟州市| 昆山市| 耒阳市| 含山县| 基隆市| 威远县| 陈巴尔虎旗| 晋中市| 平江县| 香港| 从化市| 江城| 开平市| 大荔县| 图们市| 富蕴县| 大化| 木里| 迭部县| 彩票| 精河县| 通榆县| 鹤峰县| 资阳市| 宁南县| 高唐县| 清水河县| 阳原县| 康乐县| 桐梓县| 句容市| 静乐县| 漳州市|