1. 程式人生 > >系統學習Docker踐行DevOps理念(一)

系統學習Docker踐行DevOps理念(一)

一、容器技術簡介

0x1.傳統應用運維的弊端
* 部署非常慢成本非常高資源浪費
* 難於遷移和擴充套件可
* 能會被限定硬體廠商

0x2.虛擬化技術優點
* 一個物理機可以部署多個app
* 每個app獨立執行在一個VM裡

* 資源池——一個物理機的資源分配到了不同的虛擬機器裡
* 很容易擴充套件——加物理機器或者加虛擬機器
* 很容易雲化一亞馬遜AWS,阿里雲等

0x3.虛擬化技術侷限性
* 每一個虛擬機器都是一個完整的作業系統,要給其分配資源,當虛擬機器數量增多時,作業系統本身消耗的資源勢必增多

0x4.容器技術

* 解決了開發和運維之間的矛盾
* 在開發和運維之間搭建了一個橋樑,是實現 devops 的最佳解決方案
* 對軟體和其依賴的標準化打包
* 應用之間相互隔離
* 共享同一個 OS Kernel
* 可以執行在很多主流作業系統上

0x5.容器與虛擬化的區別

二、映象與容器

0x1 映象(Image)——一個特殊的檔案系統
  作業系統分為核心和使用者空間。對於 Linux 而言,核心啟動後,會掛載 root 檔案系統為其提供使用者空間支援。而Docker 映象(Image),就相當於是一個 root 檔案系統。
  
  Docker 映象是一個特殊的檔案系統,除了提供容器執行時所需的程式、庫、資源、配置等檔案外,還包含了一些為執行時準備的一些配置引數(如匿名卷、環境變數、使用者等)。 映象不包含任何動態資料,其內容在構建之後也不會被改變。
  
  Docker 設計時,就充分利用 Union FS的技術,將其設計為 分層儲存的架構 。 映象實際是由多層檔案系統聯合組成。
  
  映象構建時,會一層層構建,前一層是後一層的基礎。每一層構建完就不會再發生改變,後一層上的任何改變只發生在自己這一層。 比如,刪除前一層檔案的操作,實際不是真的刪除前一層的檔案,而是僅在當前層標記為該檔案已刪除。在最終容器執行的時候,雖然不會看到這個檔案,但是實際上該檔案會一直跟隨映象。因此,在構建映象的時候,需要額外小心,每一層儘量只包含該層需要新增的東西,任何額外的東西應該在該層構建結束前清理掉。
  
  分層儲存的特徵還使得映象的複用、定製變的更為容易。甚至可以用之前構建好的映象作為基礎層,然後進一步新增新的層,以定製自己所需的內容,構建新的映象。
  
0x2 容器(Container)——映象執行時的實體
  映象(Image)和容器(Container)的關係,就像是面向物件程式設計中的 類 和 例項 一樣,映象是靜態的定義,容器是映象執行時的實體。容器可以被建立、啟動、停止、刪除、暫停等 。
  
  容器的實質是程序,但與直接在宿主執行的程序不同,容器程序運行於屬於自己的獨立的 名稱空間。前面講過映象使用的是分層儲存,容器也是如此。
  
  容器儲存層的生存週期和容器一樣,容器消亡時,容器儲存層也隨之消亡。因此,任何保存於容器儲存層的資訊都會隨容器刪除而丟失。
  
  按照 Docker 最佳實踐的要求,容器不應該向其儲存層內寫入任何資料 ,容器儲存層要保持無狀態化。所有的檔案寫入操作,都應該使用資料卷(Volume)、或者繫結宿主目錄,在這些位置的讀寫會跳過容器儲存層,直接對宿主(或網路儲存)發生讀寫,其效能和穩定性更高。資料卷的生存週期獨立於容器,容器消亡,資料卷不會消亡。因此, 使用資料卷後,容器可以隨意刪除、重新 run ,資料卻不會丟失。
 

0x3 倉庫(Repository)——集中存放映象檔案的地方
  映象構建完成後,可以很容易的在當前宿主上執行,但是, 如果需要在其它伺服器上使用這個映象,我們就需要一個集中的儲存、分發映象的服務,Docker Registry就是這樣的服務。

  一個 Docker Registry中可以包含多個倉庫(Repository);每個倉庫可以包含多個標籤(Tag);每個標籤對應一個映象。所以說:映象倉庫是Docker用來集中存放映象檔案的地方類似於我們之前常用的程式碼倉庫。

  通常,一個倉庫會包含同一個軟體不同版本的映象,而標籤就常用於對應該軟體的各個版本 。我們可以通過<倉庫名>:<標籤>的格式來指定具體是這個軟體哪個版本的映象。如果不給出標籤,將以 latest 作為預設標籤.。

這裡補充一下Docker Registry 公開服務和私有 Docker Registry的概念:

  Docker Registry 公開服務 是開放給使用者使用、允許使用者管理映象的 Registry 服務。一般這類公開服務允許使用者免費上傳、下載公開的映象,並可能提供收費服務供使用者管理私有映象。

  最常使用的 Registry 公開服務是官方的 Docker Hub ,這也是預設的 Registry,並擁有大量的高質量的官方映象,網址為:https://hub.docker.com/ 。在國內訪問Docker Hub 可能會比較慢國內也有一些雲服務商提供類似於 Docker Hub 的公開服務。比如 時速雲映象庫、網易雲映象服務、DaoCloud 映象市場、阿里雲映象庫等。

  除了使用公開服務外,使用者還可以在 本地搭建私有 Docker Registry 。Docker 官方提供了 Docker Registry 映象,可以直接使用做為私有 Registry 服務。開源的 Docker Registry 映象只提供了 Docker Registry API 的服務端實現,足以支援 docker 命令,不影響使用。但不包含圖形介面,以及映象維護、使用者管理、訪問控制等高階功能。

0x4 Build, Ship, and Run

- Build(構建映象) : 映象就像是集裝箱包括檔案以及執行環境等等資源。
- Ship(運輸映象) :主機和倉庫間運輸,這裡的倉庫就像是超級碼頭一樣。
- Run (執行映象) :執行的映象就是一個容器,容器就是執行程式的地方。

Docker 執行過程也就是去倉庫把映象拉到本地,然後用一條命令把映象執行起來變成容器。所以,我們也常常將Docker稱為碼頭工人或碼頭裝卸工,這和Docker的中文翻譯搬運工人如出一轍。

三、Dockerfile最佳實踐

0x1 FROM
- FROM scratch //製作base images
- FROM centos //使用base images
- 為了安全儘量使用官方的image作為base image!

0x2 LABLE
- LABEL maintainer= “geekmubai’
- LABEL version=”1.0”
- LABEL description= “This is description”
- Metadata 不可少!

0x3 RUN
- 為了美觀,複雜的RUN請用反斜線換行!
- 避免無用分層,合併多條命令成一行!

RUN yum update && yum install -y vim \
python-dev #反斜線換行

RUN apt-get update && apt-get install -y perl \
pwgen --no-install-recommends && rm -rf \ /var/lib/apt/lists/* 
#注意清理 cache

RUN /bin/bash -C 'source $HOME/. Bashrc; echo $HOME'

0x4 WORKDIR 設定當前目錄
- 用WORKDIR,不要用RUN cd!
- 儘量使用絕對目錄,不要使用相對目錄!

WORKDIR /root
WORKDIR /test #如果沒有會自動建立test目錄 
WORKDIR demo 
RUN pwd #輸出結果應該是/test/demo

0x5 ADD & COPY
- 大部分情況,COPY優於ADD!
- ADD除了COPY還有額外功能(解壓)!
- 新增遠端檔案/目錄請使用curl或者wget!

ADD hello /  #將檔案新增到根目錄
ADD test.tar.gz/ #新增到根目錄並解壓
WORKDIR /root 
ADD hello test/ # /root/test/hello
WORKDIR /root 
COPY hello test/

0x6 ENV
- 增加可維護性

MYSQL_ VERSION 5.6 #設定常量
RUN apt-get install -y mysql-server= "${MYSQL_ VERSION}" \
&& rm -rf /var/lib/apt/lists/* #引用常量

0x7 RUN CMD Entrypoint
RUN:執行命令並建立新的 Image Layer
CMD:設定容器啟動後預設執行的命令和引數
- 容器啟動時預設執行的命令
- 如果 docker run 指定了其它命令,CMD 命令被忽略
- 如果定義了多個 CMD,只有最後一個會執行
ENTRYPOINT:設定容器啟動時執行的命令
- 讓容器以應用程式或者服務的形式執行
- 不會被忽略,一定會執行
- 最佳實踐:寫一個 shell 指令碼作為 entrypoint

Shell格式和Exec格式

Shell 格式
RUN apt-get install -y vim
CMD echo "hello docker" 
ENTRYPOINT echo "hello docker"

Exec 格式
RUN ["apt-get""install""-y", "vim"]
CMD["/bin/echo", "hello docker" ]
ENTRYPOINT [ "/bin/echo""hello docker"]

0x8 Dockerfile實戰
製作一個Flask執行環境

FROM python:2.7
LABEL maintainer="Python flask container"
RUN pip install flask
COPY app.py /app/  #複製app.py到app的目錄下,注意不要少最後的/
WORKDIR /app  #設定執行目錄
EXPOSE 5000
CMD ["python", "app.py"]  #執行

後臺執行Docker需要加一個引數-d
docker run -d xxx

製作一個stress並傳參

FROM ubuntu
RUN apt-get update && apt-get install -y stress
ENTRYPOINT ["/usr/bin/stress"]
CMD []  #這裡傳入需要執行的引數

0x9 Docker容器的操作

命令 作用
-it 互動式執行,不會執行完就終止
docker ps (-a) 檢視正在執行的容器(所有容器)
docker exec 進入容器裡
ip a 檢視容器的IP地址
docker stop ID 停掉容器
docker rm 刪除容器
–name=xxx 給容器起別名
docker inspect 檢視容器詳細資訊
docker logs 檢視容器日誌

0x9 容器的資源限制
- 預設容器沒有資源的限制,Docker提供了控制方法;
- 記憶體,CPU、IO
- docker run + 標誌符來設定
- 主要引數
- 記憶體
- -m 容器能使用的最大記憶體
–memory–reservation
比-m的值要小,在docker檢測到主機的記憶體較少時啟用
- CPU
- –cpu-period, –cpu-quota
- 允許容器使用50%的CPU
–cpu-period = 10 ,–cpu-quota=5
- 允許容器使用主機4核中的兩核
–cpu-period = 10 , –cpu-quota=20
- IO
- 控制每秒的位元組數或每秒的IO操作來限制頻寬
- 限制從/dev/sda 每秒1000次的IO讀取操作
docker run -ti –device-read-iops /dev/sda:1000 ubuntu

相關推薦

系統學習Docker踐行DevOps理念

一、容器技術簡介 0x1.傳統應用運維的弊端 * 部署非常慢成本非常高資源浪費 * 難於遷移和擴充套件可 * 能會被限定硬體廠商 0x2.虛擬化技術優點 * 一個物理機可以部署多個app * 每個app獨立執行在一個VM裡 * 資源

系統學習Docker 踐行DevOps理念無密教程

系統學習Docker 踐行DevOps理念(無密)教程 連結:https://pan.baidu.com/s/17op6x9Lr2gEvRr8wdSrUlA 提取碼:lpt3 一、容器技術簡介 0x1.傳統應用運維的弊端 部署非常慢成本非常高資源浪費 難於遷移和擴充套件

系統學習Docker踐行DevOps理念

eight 集群 自己 調整 開發 作者 管理 過去 性能 感謝大家的支持,這套教程發布的有點兒晚了,希望對大家的工作有所幫助! 學習要趁早,點滴記錄,學習就是進步! 不要到處找了,抓緊提升自己。 下載地址:版權保護,不再提供網絡下載地址。 請聯系本文作者或

系統學習Docker 踐行DevOps理念

dev 區塊鏈 docker 學習 部署 區塊 容器技術 優秀 人工智 Docker代表的容器技術是近兩年的大熱技術,和人工智能、區塊鏈等熱點不同,容器技術的門檻並不高,每一個開發、測試、運維人員都能在日常工作中掌握和使用,是當今IT從業人員的必備技能之一。本課程會帶大家系

【視訊分享】系統學習Docker 踐行DevOps理念

Docker代表的容器技術是近兩年的大熱技術,和人工智慧、區塊鏈等熱點不同,容器技術的門檻並不高

系統學習Docker,CI/CD踐行DevOps理念筆記

what is docker what’s the difference between docker and VM? Docker功能 簡化配置 整合伺服器 程式碼流水線管理 調適能力 提高開發效率 多租戶 隔離應用 快速部

學習Docker 下載與安裝

Docke Docker 是一個開源的應用容器引擎,讓開發者可以打包他們的應用以及依賴包到一個可移植的容器中,然後釋出到任何流行的 Linux 機器上,也可以實現虛擬化。容器是完全使用沙箱機制,相互之間不會有任何介面。 我用的是windows系統 安裝包 連結:h

圖書管理系統總結——數據庫操作

set 結果集 static () block csdn .com oid 取數據 由於經常在晚上回宿舍寫代碼,沒有網,故而沒用老師提供的Oracle數據庫服務器,在自己電腦上裝了一個MySQL。而且JAVA配MySQL還是很方便的。 數據庫連接: 參考了http://b

方便大家學習的Node.js教程:理解Node.js

圖形 -1 iter pri attribute set run 相對 mage 理解Node.js 為了理解Node.js是如何工作的,首先你需要理解一些使得Javascript適用於服務器端開發的關鍵特性。Javascript是一門簡單而又靈活的語言,這種靈

學習Opencv 2.4.9 ---Opencv + vs2012環境配置

-a class targe 貝爾 waitkey ron ini win font 作者:咕唧咕唧liukun321來自:http://blog.csdn.net/liukun321首先獲得最新的Opencv 2.4.9源代碼:opencv源代碼下載一、Opencv環

JavaSE 學習筆記之Java概述

environ 電子 6.0 run javase 有一點 架構 spa form 一、Java的三種技術架構: JAVAEE:Java Platform Enterprise Edition,開發企業環境下的應用程序,主要針對web程序開發; JAVASE:Java P

設計模式學習筆記 C#代碼

內容 編程 繼承 color 模式 c# 派生類 ive spa 《深入淺出設計模式》學習筆記第一章 原始需求和設計 事情是這樣開始的,公司需要做一套程序,鴨子,設計如下: 一個鴨子父類,多個派生類,三個可override的方法。 第一次需求變更 我們要會飛的鴨子!!!!

FPGA軟硬協同設計學習筆記及基礎知識

擴展性 產生 新的 pll 多個 分配 每次 調用 span 一、FPGA軟件硬件協同定義: 軟件:一般以軟件語言來描述,類似ARM處理器的嵌入式設計。硬件定義如FPGA,裏面資源有限但可重配置性有許多優點,新的有動態可充配置技術。

Spring aop學習整理(spring in action):了解AOP

進入 一起 table return 問題 匹配 核心 before cti   切面能幫助我們模塊化橫切關註點。簡而言之,橫切關註點可以被描述為影響應用多處的功能。例如,安全就是一個橫切關註點,應用中的許多方法都會涉及到安全規則。圖4.1直觀呈現了橫切關註點的概念。  

多線程編程學習筆記——線程同步

als 執行 homepage auto using 發的 進行 read 函數 接上文 多線程編程學習筆記-基礎(一) 接上文 多線程編程學習筆記-基礎(二) 接上文 多線程編程學習筆記-基礎(三) 就如上一篇文章(多線程編程學習筆記-基礎(三))

我們一起學習Spring之Spring簡介

邏輯 style 發的 nfa 不同的 構建 john 局限 認識   首先聲明,我是一個spring初學者,寫這篇blog的目的是為了能和大家交流。文中不當之處還望大佬指出,不勝感激!   好了,現在我們開始進入正題。   很多小夥伴在學習Java的時候都會有人建議你去學

matlab學習筆記之常用命令

plot 我們 all 查看 學習 ear tla clear 但是 一.清除命令。   1.clear all;%清除所有變量,通常在matlab的工作區;另外斷點也會被清除掉   2.close all;%關閉所有窗口(除了編輯器窗口、命令窗口、幫助窗口)   3.cl

小白的java學習之路 “ 選擇結構

測試 exti 邏輯運算符 main system 有一個 學習 並且 oid if選擇結構: if選擇結構是根據條件判斷之後再做處理的一種語法結構。 1.if選擇結構的語法: public class Demo{ public static void main(

Docker簡介與安裝

TP width Go src apache container 資源利用率 代碼托管 docker Docker簡介 Docker 是 Docker.Inc 公司開源的一個基於 LXC技術之上構建的Container容器引擎, 源代碼托管在 GitHub 上, 基於Go

Docker基礎入門實戰

art The 開機自啟動 inf 應用程序 51cto 管理 x86 正在 Docker基礎入門實戰第1章 docker簡介1.1 what is DockerDocker是一個開源的應用容器引擎,基於Go語言並遵從Apache2.0協議開源,源代碼部