開發和運維之間由於環境不一樣而致使的矛盾 集羣環境下每臺機器部署相同的應用 DevOps(Development and Operations)mysql
Docker是一個開源的應用容器引擎,讓開發者能夠打包他們的應用以及依賴包到一個可移植的容器中,而後發佈到 任何流行的Linux機器上,也能夠實現虛擬化,容器是徹底使用沙箱機制,相互之間不會有任何接口。linux
Docker是世界領先的軟件容器平臺。開發人員利用 Docker 能夠消除協做編碼時「在個人機器上可正常工做」的問題。 運維人員利用 Docker 能夠在隔離容器中並行運行和管理應用,得到更好的計算密度。企業利用 Docker 能夠構建敏 捷的軟件交付管道,以更快的速度、更高的安全性和可靠的信譽爲 Linux 和 Windows Server 應用發佈新功能。sql
簡化程序: Docker 讓開發者能夠打包他們的應用以及依賴包到一個可移植的容器中,而後發佈到任何流行的 Linux 機器上,即可以實現虛擬化。docker
Docker改變了虛擬化的方式,使開發者能夠直接將本身的成果放入Docker中進行管 理。方便快捷已是 Docker的最大優點,過去須要用數天乃至數週的 任務,在Docker容器的處理下,只須要數秒就 能完成。數據庫
避免選擇恐懼症: 若是你有選擇恐懼症,仍是資深患者。Docker 幫你 打包你的糾結!好比 Docker 鏡像;Docker 鏡像中包含了運行環境和配置,因此 Docker 能夠簡化部署多種應用實例工做。好比 Web 應用、後臺應用、數據庫 應用、大數據應用好比 Hadoop 集羣、消息隊列等等均可以打包成一個鏡像部署。json
節省開支: 一方面,雲計算時代到來,使開發者沒必要爲了追求效果而配置高額的硬件,Docker 改變了高性能必然高 價格的思惟定勢。Docker 與雲的結合,讓雲空間獲得更充分的利用。不只解決了硬件管理的問題,也改變了虛擬化 的方式。vim
Docker使用C/S架構,Client經過接口與Server進程通訊實現容器的構建,運行和發佈,如圖:centos
安裝了Docker程序,並運行了Docker daemon的主機。緩存
運行在宿主機上,Docker守護進程,用戶經過Docker client(Docker命令)與Docker daemon交互。 Itomcat
將軟件環境打包好的模板,用來建立容器的,一個鏡像能夠建立多個容器。
docker鏡像就比如是一個目標,能夠經過這個目標來建立容器服務,tomcat鏡像==>run==>容器(提供服務器),經過這個鏡像能夠建立多個容器(最終服務運行或者項目運行就是在容器中的)。
鏡像分層結構:
位於下層的鏡像稱爲父鏡像(Parent Image),最底層的稱爲基礎鏡像(Base Image)。
最上層爲「可讀寫」層,其下的均爲「只讀」層。
Docker的運行組件,啓動一個鏡像就是一個容器,容器與容器之間相互隔離,而且互不影響。
Docker利用容器技術,獨立運行一個或者一組應用,經過鏡像來建立的.
啓動,中止,刪除,基本命令
目前就能夠把這個容器理解爲就是一個簡易的 Linux系統。
Docker命令行工具,用戶是用Docker Client與Docker daemon進行通訊並返回結果給用戶。也可使用其餘工具通 過Docker Api 與Docker daemon通訊。
常常會和倉庫(Repository)混爲一談,實際上Registry上能夠有多個倉庫,每一個倉庫能夠當作是一個用戶,一個用戶 的倉庫放了多個鏡像。倉庫分爲了公開倉庫(Public Repository)和私有倉庫(Private Repository),最大的公開倉庫是 官方的Docker Hub,國內也有如阿里雲、時速雲等,能夠給國內用戶提供穩定快速的服務。用戶也能夠在本地網絡 內建立一個私有倉庫。當用戶建立了本身的鏡像以後就可使用 push 命令將它上傳到公有或者私有倉庫,這樣下次 在另一臺機器上使用這個鏡像時候,只須要從倉庫上 pull 下來就能夠了。
Docker 提供了兩個版本:社區版 (CE) 和企業版 (EE)。
操做系統要求 以Centos7爲例,且Docker 要求操做系統必須爲64位,且centos內核版本爲3.1及以上。
查看系統內核版本信息:
uname -r
查看Linux系統類別與OS版本
cat /etc/os-release
卸載docker依賴
yum remove docker-ce docker-ce-cli containerd.io
刪除資源
rm -rf /var/lib/docker
step 1: 安裝必要的一些系統工具
sudo yum install -y yum-utils device-mapper-persistent-data lvm2
Step 2: 添加軟件源信息
sudo yum-config-manager --add-repo http://mirrors.aliyun.com/docker-ce/linux/centos/docker-ce.repo
Step 3: 更新並安裝 Docker-CE
這個命令是將軟件包信息提早在本地緩存一份,用來提升搜索安裝軟件的速度,yum 會把下載的軟件包和header存儲在cache中而不自動刪除。若是以爲佔用磁盤空間,可使用yum clean指令清除緩存。
sudo yum makecache fast
sudo yum -y install docker-ce
Step 4: 開啓Docker服務
sudo service docker start
使用docker version查看是否按照成功
docker version
這裏使用阿里雲的免費鏡像加速服務,也可使用其餘如時速雲、網易雲等
1.註冊登陸開通阿里雲容器鏡像服務
2.查看控制檯,招到鏡像加速器並複製本身的加速器地址
3.找到/etc/docker目錄下的daemon.json文件,沒有則直接
vim /etc/docker/daemon.json
4.加入如下配置
如圖
通知systemd重載此配置文件;
systemctl daemon-reload
重啓docker服務
systemctl restart docker
測試
docker run hello-world
查看一下下載的鏡像
docker images
Docker是一個Client-Server結構的系統,Docker的守護進程運行在主機上。經過Socket從客戶端訪問!
Docker-Server接收到Docker-Client的指令,就會執行這個命令!
一、docker有着比虛擬機更少的抽象層。因爲docker不須要Hypervisor實現硬件資源虛擬化,運行在docker容器上的程序直接使用的都是實際物理機的硬件資源。所以在CPU、內存利用率上docker將會在效率上有明顯優點。
二、docker利用的是宿主機的內核,而不須要Guest OS。
GuestOS: VM(虛擬機)裏的的系統(OS);
HostOS:物理機裏的系統(OS);
所以,當新建一個 容器時,docker不須要和虛擬機同樣從新加載一個操做系統內核。仍而避免引導、加載操做系統內核返個比較費時費資源的過程,當新建一個虛擬機時,虛擬機軟件須要加載GuestOS,返個新建過程是分鐘級別的。而docker因爲直接利用宿主機的操做系統,則省略了這個複雜的過程,所以新建一個docker容器只須要幾秒鐘。
docker run --name 容器名 -i -t -p 主機端口:容器端口 -d -v 主機目錄:容器目錄:ro 鏡像ID或鏡像名:TAG
# --name 指定容器名,可自定義,不指定自動命名
# -i 以交互模式運行容器
# -t 分配一個僞終端,即命令行,一般-it組合來使用
# -p 指定映射端口,講主機端口映射到容器內的端口
# -d 後臺運行容器
# -v 指定掛載主機目錄到容器目錄,默認爲rw讀寫模式,ro表示只讀
docker ps -a -q
# docker ps查看正在運行的容器
# -a 查看全部容器(運行中、未運行)
# -q 只查看容器的ID
docker start 容器ID或容器名
docker stop 容器ID或容器名
docker rm -f 容器ID或容器名
# -f 表示強制刪除
docker logs 容器ID或容器名
docker exec -it 容器ID或者容器名 /bin/bash
# 進入正在運行的容器而且開啓交互模式終端
# /bin/bash是固有寫法,做用是由於docker後臺必須運行一個進程,不然容器就會退出,在這裏表示啓動容器後啓動 bash。
# 也能夠用docker exec在運行中的容器執行命令
docker cp 主機文件路徑 容器ID或容器名:容器路徑 #主機中文件拷貝到容器中
docker cp 容器ID或容器名:容器路徑 主機文件路徑 #容器中文件拷貝到主機中
docker inspect 容器ID或容器名
查找鏡像:
docker search 關鍵詞 #搜索docker hub網站鏡像的詳細信息
docker search mysql
搜索出鏡像STARS大於3000的 --filter=STARS=3000 #搜索出來的鏡像就是STARS大於3000的
docker search mysql --filter=STARS=3000
下載鏡像
docker pull 鏡像名:TAG # Tag表示版本,有些鏡像的版本顯示latest,爲最新版本
docker pull tomcat:8
查看鏡像:
# 查看本地全部鏡像
docker images
刪除鏡像:
docker rmi -f 鏡像ID或者鏡像名:TAG
# 刪除指定本地鏡像
# -f 表示強制刪除
docker rmi -f 34d28186c789
docker pull mysql:5.7
#建立三個要掛載的目錄
mkdir -p /my/mysql/conf mkdir -p /my/mysql/data mkdir -p /my/mysql/logs
#複製文件 並修改字符
docker cp mysql:/etc/mysql/mysql.conf.d/mysqld.cnf /my/mysql/conf/
vi /my/mysql/conf/mysqld.conf
character-set-server=utf8
#最終啓動命令
docker run \ --name mysql \ -p 3306:3306 \ -v /my/mysql/conf:/etc/mysql/mysql.conf.d/ \ -v /my/mysql/data:/var/lib/mysql \ -v /my/mysql/logs:/logs \ -e MYSQL_ROOT_PASSWORD=root \ -d mysql:5.7