1 docker和虛擬化
2 docker安裝和配置
2.0 docker 中的一些概念
2.1 配置國內源(不配也可以,只是會從國外倉庫下載)
3 鏡像操作
4 容器操作
4.1 容器基本操作
4.2 run運行容器
4.3 -v目錄映射
4.4 -p端口映射
4.5 容器其他操作
1 docker和虛擬化
## 什么是虛擬化在計算機中,虛擬化(英語:Virtualization)是一種資源管理技術,是將計算機的各種實體資源,如服務器、網絡、內存及存儲等,予以抽象、轉換后呈現出來,打破【實體結構間的不可切割的障礙】,使用戶可以比原本的組態更好的方式來應用這些資源。這些資源的新虛擬部份是不受現有資源的架設方式,地域或物理組態所限制。一般所指的虛擬化資源包括計算能力和資料存儲。在實際的生產環境中,虛擬化技術主要用來解決高性能的物理硬件產能過剩和老的舊的硬件產能過低的重組重用,透明化底層物理硬件,從而最大化的利用物理硬件 對資源充分利用虛擬化技術種類很多,例如:軟件虛擬化、硬件虛擬化、內存虛擬化、網絡虛擬化(vip)、桌面虛擬化、服務虛擬化、虛擬機等等。# 什么是Docker
Docker 是一個開源項目,誕生于 2013 年初,最初是 dotCloud 公司內部的一個業余項目。它基于 Google 公司推出的 Go 語言實現。 項目后來加入了 Linux 基金會,遵從了 Apache 2.0 協議,項目代碼在 [GitHub](https://github.com/docker/docker) 上進行維護# 就是虛擬化的一種,更輕量級如果使用虛擬機---》一臺機器--》最多能運行 數量比較少的虛擬機如果使用docker--》一臺機器---》可以運行出成千上百臺docker容器# 容器與虛擬機比較
2 docker安裝和配置
# 在linux機器上安裝
0 卸載dockeryum remove docker docker-common docker-selinux docker-enginerm -rf /var/lib/docker1 yum 包更新到最新sudo yum update2 安裝需要的軟件包, yum-util 提供yum-config-manager功能,另外兩個是devicemapper驅動依賴的.sudo yum install -y yum-utils device-mapper-persistent-data lvm23 設置yum源為阿里云sudo yum-config-manager --add-repo http://mirrors.aliyun.com/docker-ce/linux/centos/docker-ce.repo4 安裝dockersudo yum install docker-ce5 安裝后查看docker版本docker -v6 啟動dockersystemctl status docker # 查看裝填systemctl start docker # 啟動systemctl stop docker # 停止7 拉取鏡像-cento7 docker pull centos:7-redis docker pull redis-mysql5.7 docker pull mysql:5.78 查看本地鏡像docker images9 運行成容器:運行centos鏡像成容器docker run -di --name=centos centos:710 查看正在運行的容器docker psdocker ps -a11 進入容器docker exec -it 容器id號 /bin/bash
2.0 docker 中的一些概念
# docker 是一個cs架構軟件c端:客戶端s端:服務端只是現在c和s都在同一臺機器上# 鏡像(Images):一堆文件---》當成 虛擬機上有個ios文件,操作系統的文件[centos7.iso,windows10.iso]-鏡像哪里來?目前是從遠程倉庫拉取的
# 容器(containers)-鏡像運行---》得到容器---》以后就把容器當成一個可以使用的操作系統即可-一個鏡像---》可以運行得到很多容器
# 遠程倉庫(Registry)-放著一個個鏡像--》一堆文件# 鏡像和容器的關系-跟 類 和 對象-一個類,可以產生很多對象,每個對象是一個獨立個體
2.1 國內源(不配也可以,只是會從國外倉庫下載)
# 遠程倉庫在國外[python 下第三方模塊:pypi上---》配置國內鏡像站]
# 使用國內源,下載鏡像時,速度會快---》阿里云
# 參照阿里云提供的筆記做:https://cr.console.aliyun.com/cn-shanghai/instances/mirrorssudo mkdir -p /etc/docker # 如果有,就不需要創建了
vim /etc/docker/daemon.json
# 加入
{"registry-mirrors": ["https://x1566319.mirror.aliyuncs.com"]
}
# 保存退出
sudo systemctl daemon-reload # 重新加載docker配置
sudo systemctl restart docker# 重啟docker
# 國外docker 倉庫:
https://hub.docker.com/# 搜索想要找的鏡像,找到固定版本# 搜到后--》下載到本地
docker pull centos:centos7
3 鏡像操作
# 1 查找鏡像-從https://hub.docker.com/直接搜-使用命令:基本不用 docker search 名字# 2 下載鏡像docker pull 鏡像名:版本號 # 官方有的的才能下下來,沒有的找不到docker pull 鏡像名 # 如果不寫版本號,下最新docker pull mysql:5.7docker pull redis # 3 查看本地鏡像
docker images # 等同于 docker image ls
鏡像名字 鏡像標簽 鏡像id,以后通過id操作
REPOSITORY TAG IMAGE ID CREATED SIZE
centos centos7 eeb6ee3f44bd 2 years ago 204MB# 4 刪除本地鏡像docker rmi 7614ae94 # 等同于docker image rm 7614ae9453d1docker rmi id號 id號一次性把本地所有鏡像都刪除docker images -q # 查詢本地所有鏡像,只列出 id號docker rmi `docker images -q`# 總結:鏡像是一堆文件---》有的叫redis,有的叫centos就把鏡像當成---》一個操作系統內裝了某個軟件---》運行成容器--》就相當于這個操作系統上裝了某個軟件
4 容器操作
# 鏡像是一堆文件
# 容器是由鏡像 運行得到的---》運行得到后---》你就把一個個的鏡像【當成】一個個虛擬機操作系統再運行即可
4.1 容器基本操作
# 把鏡像運行成容器,并且一個鏡像,可以運行出多個容器# 查看正在運行的容器docker ps
# 查看所有容器docker ps -a
# 查看最后一次運行的容器docker ps -l# 啟動停止的容器docker start id/名字# 停止運行的容器docker stop 7d5e# 停止所有在運行的容器docker stop `docker ps -q`# 一次性刪除所有容器docker rm `docker ps -a -q`# 記住四條:docker psdocker ps -adocker startdocker stop
4.2 run運行容器
#1 docker run 把鏡像運行成容器-docker run 參數-i 表示運行容器-d 以守護式容器在后臺運行,用這個參數創建出來的容器,命令行還在宿主機上,沒有進入到容器內部-t 表示容器啟動后會進入容器命令行。加入這參數后,容器創建就能登錄進去。即分配一個偽終端。--name 指定容器名字,如果不指定,會隨機一個名字-p 表示端口映射,前者是宿主機端口,后者是容器內的映射端口。可以使用多個-p做多個端口映射-v 表示目錄映射關系(前者是宿主機目錄,后者是容器的目錄),可以使用多個-v做多個目錄或文件映射。注意:最好做目錄映射,在宿主機上做修改,然后共享到容器上# 2 案例 -iddocker run -id --name=centos centos:7 # 執行完,命令在宿主機上,可以通過命令查看正在運行的容器# 3 案例 -it
docker run -it --name=centos centos:7 # 執行完,命令行在容器內,容器很干凈,幾乎啥軟件都沒有,可以exit退出到宿主機---》只要退出,容器就停了# 4 創建一個python3.9容器---》不進入docker run -id --name=python python:3.9# 5 啟動一個centos容器并且進入,名字叫mycentos,在內部裝個vim,然后退出# 6 重點:如果創建容器并進入---》只要退出---》容器就停了容器要運行,必須有個前臺進程在運行,并且是夯住(阻塞)的,否則容器就停了# 7 進入到容器內部# 在容器內執行命令docker exec 容器名字/id 命令# 利用這個特性-->進入到容器內部docker exec -it 容器名字/id /bin/bashdocker exec -it python sh# 退出,結束掉 /bin/bashexit
4.3 -v目錄映射
# 運行出一個 centos77 容器,不進入, 做目錄映射
# 把宿主機的 /root/lqz文件夾 映射到 容器內部的 /lqz文件夾
# -v可以寫多個,可以是文件或文件夾
docker run -id -v /root/lqz:/lqz --name=centos77 centos:7容器內部修改文件---》會影響外部外部修改文件---》影響內部# 目錄映射好處是,后期咱們部署django項目1 有個django容器,做好映射,代碼放在宿主機上即可,以后更新了代碼,只要重啟容器,代碼就是最新了2 運行mysql容器---》mysql配置文件放在宿主機上做好映射mysql容器---》表數據,放到容器中---》如果刪了容器---》數據庫全沒了表數據,放在宿主機上---》把容器刪除---》表數據還在----》再啟動一個容器做好映射---》數據都還在
4.4 -p端口映射
# -p參數:端口映射 容器中啟動一個mysql5.7 --》容器中的3306監聽,宿主機3306沒人監聽,做端口映射后,宿主機的3306就被docker的這個容器監聽了# 啟動的mysql的root密碼是123456# 啟動mysql容器 -p 宿主機端口:容器端口
# 以后臺守護進程運行mysql容器,mysql的root用戶密碼是123456,宿主機和容器做了端口映射
docker run -id --name=mysql -p 3307:3306 -e MYSQL_ROOT_PASSWORD=123456 mysql:5.7# netstat -nlp |grep 3307 查看本機80端口占用情況
yum install net-tools -y# 以后訪問宿主機80端口就等于訪問容器的3306端口
4.5 容器其他操作
# 啟動容器docker start 容器id
# 停止容器docker stop 容器id###mysql的容器底層的操作系統是 debian 裝軟件需要用
apt-get update
apt-get install vim -y# 文件拷貝(宿主機執行)# 容器的文件copy到宿主機上(不是在容器內執行)docker cp 容器名稱:容器目錄 需要拷貝的文件或目錄docker cp ae1759ad935:/lqz/xx.txt /root/xx.txt# 宿主機的文件copy到容器中docker cp 需要拷貝的文件或目錄 容器名稱:容器目錄docker cp /root/yy.txt ae1759ad935:/lqz/yy.txt# 查看容器IP地址 docker inspect 容器名稱 # 查看容器的詳細描述,很多docker inspect ae1759ad935 --format='{{.NetworkSettings.IPAddress}}' 容器名稱(容器ID)# 在多個容器之間是可以ping通的(容器和宿主機也可以)
# centos:172.17.0.3
# mysql:172.17.0.2# 刪除容器(刪除已停止的容器)docker rm 容器id docker rm `docker ps -a -q`# 無狀態的服務(在容器中盡量運行無狀態的服務)-mysql reids 有狀態,運行過程中產生數據,保存,容器刪除,數據就沒了-uwsgi+django 無狀態的服務