日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當(dāng)前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

Docker相关概念与安装(Docker-CE)

發(fā)布時間:2024/2/28 编程问答 32 豆豆
生活随笔 收集整理的這篇文章主要介紹了 Docker相关概念与安装(Docker-CE) 小編覺得挺不錯的,現(xiàn)在分享給大家,幫大家做個參考.

Docker相關(guān)概念與安裝

  • 一、背景
  • 二、那如何實(shí)現(xiàn)應(yīng)用和應(yīng)用的隔離
  • 三、Docker是什么?
  • 四、Docker有哪些優(yōu)勢?和虛擬化比有什么優(yōu)勢
  • 五、Docker的使用場景
  • 六、Docker引擎(Docker Engine)
  • 七、Docker的核心概念
  • 八、使用YUM倉庫安裝Docker

一、背景

  • 以linux而言,linux操作系統(tǒng)會有一個主進(jìn)程pid=1派生出其他進(jìn)程來控制不同服務(wù)例如: pid=2 ——> python pid=3——>java pid4——>php ,三個服務(wù)可能會相互影響
  • 使用者期望將這三個不同的服務(wù),跑在不同的運(yùn)行時環(huán)境中實(shí)現(xiàn)相互不影響,同時不會增加服務(wù)器成本
  • 延伸出——>能否將這三種服務(wù)分別封裝起來——>KVM虛擬化技術(shù),實(shí)現(xiàn)了一個操作系統(tǒng)模擬多個操作系統(tǒng)/不同的運(yùn)行時環(huán)域隨著技術(shù)發(fā)展——>虛擬化技術(shù)開銷較大(例如:只要運(yùn)行一個py腳本,想要使用虛擬化方式實(shí)現(xiàn),還需要安裝一個操作系統(tǒng).
    并不方便/合理)
  • ——>延伸出容器技術(shù)
    虛擬化層的抽象層(用戶層)剝離,使用docker engine來替代(來賓操作系統(tǒng)去除),只要通過引擎就可以直接連接到宿主機(jī)操作系統(tǒng)中,極大減小了開銷

二、那如何實(shí)現(xiàn)應(yīng)用和應(yīng)用的隔離

應(yīng)用和應(yīng)用的隔離,如何進(jìn)行判斷

  • 以操作系統(tǒng)維度
  • 應(yīng)用與應(yīng)用隔離,在操作系統(tǒng)中,是通過namespaces實(shí)現(xiàn)的,只要實(shí)現(xiàn)以下6個空間隔離,才能認(rèn)為兩個應(yīng)用實(shí)現(xiàn)了隔離

容器隔離了6個名稱空間(namespace資源隔離-用容器化技術(shù)封裝)

  • mount:文件系統(tǒng),掛載點(diǎn)——>一個文件系統(tǒng)內(nèi),不能重復(fù)掛載一個指定目錄,例如:/mnt
  • user:操作進(jìn)程的用戶和用戶組
  • ipc:信號量、消息隊列,共享內(nèi)存(理解,不同的應(yīng)用調(diào)用內(nèi)存資源的時候應(yīng)該使用不同的內(nèi)存空間)
  • net:網(wǎng)絡(luò)設(shè)備、網(wǎng)絡(luò)協(xié)議棧、端口等

該pid命名空間:進(jìn)程隔離(PID:進(jìn)程ID) 。
該net命名空間:管理網(wǎng)絡(luò)接口(NET:網(wǎng)絡(luò))。
該ipc命名空間:管理訪問IPC資源(IPC:進(jìn)程間通信)。
該mnt命名空間:管理文件系統(tǒng)掛載點(diǎn)(MNT:mount) 。
該uts命名空間:隔離內(nèi)核和版本標(biāo)識符。(UTS: Unix時間共享系統(tǒng))。

三、Docker是什么?

  • Docker是一個用于開發(fā),交付和運(yùn)行應(yīng)用程序的開放平臺。Docker使您能夠?qū)?yīng)用程序與基礎(chǔ)架構(gòu)分開,從而可以快速交付軟件是一個開源的應(yīng)用容器引擎,讓開發(fā)者可以打包方式封裝應(yīng)用以及依賴包到一個可移植的鏡像中,然后發(fā)布到任何流行的Linux或者windows機(jī)器上,也可以實(shí)現(xiàn)虛擬化。容器是完全使用沙箱機(jī)制(隔離機(jī)制),相互之間不會有任何接口
    注:沙箱(Sandbox):在計算機(jī)安全領(lǐng)域,沙箱是一種程序的隔離運(yùn)行機(jī)制
  • Docker在2013年一炮而紅,直到現(xiàn)在,已經(jīng)成為容器技術(shù)的代名詞。
  • Docker從一開始就以提供標(biāo)準(zhǔn)化的運(yùn)行時環(huán)境為目標(biāo),真正做到"build once,run anywhere",可以將同一個構(gòu)建版本用于開發(fā)、測試、預(yù)發(fā)布、生產(chǎn)等任何環(huán)境,并且做到了與底層操作系統(tǒng)的解耦(不吃操作系統(tǒng))。在此基礎(chǔ)上還進(jìn)一步發(fā)展出了Caas(容器即服務(wù))技術(shù)。
  • Docker 從 17.03 版本之后分為 CE(Community Edition: 社區(qū)版) 和 EE(Enterprise Edition: 企業(yè)版)。

小結(jié): Dcoker是基于容器技術(shù)的輕量級虛擬化解決方案

  • docker是容器引擎,把linux的cgroup、namespaces等容器底層技術(shù)進(jìn)行完美的封裝、并抽象為用戶提供創(chuàng)建和管理容器的便捷界面(命令行cli、 api等)
    cgroup :資源管理技術(shù)

四、Docker有哪些優(yōu)勢?和虛擬化比有什么優(yōu)勢

  • docker把容器化技術(shù)做成了標(biāo)準(zhǔn)化平臺(docker統(tǒng)一/指定了容器化技術(shù)的標(biāo)準(zhǔn)化平臺)

使用docker有什么意義

  • docker引擎統(tǒng)一了基礎(chǔ)設(shè)施環(huán)境-docker環(huán)境—》image —》封裝一個簡易的操作系統(tǒng)
  • docker引擎統(tǒng)一了程序打包(裝箱)方式-docker鏡像—》images
  • docker引擎統(tǒng)一了程序部署(運(yùn)行)方式-docker 容器——》基于鏡像——》運(yùn)行為容器(可運(yùn)行的環(huán)境)
  • 要求:內(nèi)核在3.8以上(排除了centos6)
  • docker 1.30版本迭代docker-ce docker-ee 1.7版本因為企業(yè)版和社區(qū)版
特性Docker容器虛擬機(jī)
啟動速度秒級分鐘級
計算能力損耗幾乎無損耗50%左右
性能接近原生弱于
系統(tǒng)支持量(單機(jī))上千個幾十個
隔離性資源隔離/限制完全隔離

五、Docker的使用場景

  • 應(yīng)用程序(封裝/構(gòu)建鏡像)——》運(yùn)維下載,使用容器技術(shù)進(jìn)行運(yùn)行/發(fā)布
  • 打包應(yīng)用程序簡單部署
  • 可脫離底層硬件任意遷移(實(shí)現(xiàn)了應(yīng)用的隔離,將應(yīng)用拆分并進(jìn)行解耦),例如:服務(wù)器從騰訊云遷移到阿里云
  • 持續(xù)集成和持續(xù)交付(cI/CD) :開發(fā)到測試發(fā)布
  • 部署微服務(wù)
  • 提供PAAs產(chǎn)品(平臺即服務(wù)){OpenStack的云主機(jī)類似于阿里云的ECS,屬于IAAS、Docker (KBS)屬于PAAS}

六、Docker引擎(Docker Engine)

  • Docker Engine是具有以下主要組件的客戶端-服務(wù)器應(yīng)用程序:
    • 服務(wù)器是一種長期運(yùn)行的程序,稱為守護(hù)程序進(jìn)程( dockerd命令)。
    • REST API,它指定程序可以用來與守護(hù)程序進(jìn)行通信并指示其操作的接口。
    • 命令行界面(CLI)客戶端(docker命令)。

七、Docker的核心概念

鏡像

  • 一個面向Docker容器引擎的只讀模板(簡而言之,就是將一個服務(wù)已經(jīng)部署完畢的環(huán)境打包)

容器

  • 根據(jù)鏡像創(chuàng)建的運(yùn)行實(shí)例(即虛擬機(jī))

倉庫

  • 集中保存鏡像的地方(分為公有倉庫和私有倉庫,公有倉庫就是Docker官方倉庫)

八、使用YUM倉庫安裝Docker

安裝依賴包

yum install -y yum-utils device-mapper-persistent-data lvm2yum-utils提供了yum-config-manager device mapper存儲驅(qū)動程序需要device-mapper-persistent-data和lvm2 Device Mapper 是Linux2.6內(nèi)核中支持邏輯卷管理的通用設(shè)備映射機(jī)制,它為實(shí)現(xiàn)用于存儲資源管理的塊設(shè)備驅(qū)動提供了一個高度模塊化的內(nèi)核架構(gòu)。

設(shè)置阿里云鏡像源

yum-config-manager --add-repo https://mirrors.aliyun.com/docker-ce/linux/centos/docker-ce.repo

安裝Docker-CE

yum install -y docker-ce systemctl stop firewalld.service systemctl disable firewalld.service setenforce 0 vim /etc/selinux/config SELINUX=disabled systemctl start docker.service systemctl enable docker.service


鏡像加速
鏡像加速地址

可選項:配置文件修改(生產(chǎn)經(jīng)驗) #registry-mirrors 以上添加"graph":"/data/docker", #數(shù)據(jù)目錄"storage-driver":"overlay2", #存儲引擎"insecure-registries":["registry.access.redhat.com","quary.io"], #私有倉庫 #registry-mirrors #鏡像加速"bip":"172.168.50.1/24", #docker網(wǎng)絡(luò)"exec-opts":["native.cgroupdriver-systemd"], #啟動時的額外參數(shù)"live-restore":true #當(dāng)docker容器引擎掛掉的時候,使用docker跑起來的容器還能繼續(xù)運(yùn)行以上是建議的配置項 docker容器網(wǎng)絡(luò)生產(chǎn)經(jīng)驗 docker 的網(wǎng)絡(luò)建議和宿主機(jī)的IP"對照” 比如宿主機(jī) 10.2.5.6容器的地址就可以修改為172.5.6.1,這樣方便在故障發(fā)生時,更容易定位故障節(jié)點(diǎn)位置 systemctl daemon-reload systemctl restart docker

systemctl daemon-reload systemctl restart docker


網(wǎng)絡(luò)優(yōu)化

vim /etc/sysctl.conf net.ipv4.ip_forward=1 sysctl -p service network restart systemctl restart docker


總結(jié)

以上是生活随笔為你收集整理的Docker相关概念与安装(Docker-CE)的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網(wǎng)站內(nèi)容還不錯,歡迎將生活随笔推薦給好友。