1. Docker概述
1.1 Docker为很么会出现
一套产品:开发–上线 两套环境!应用环境, 应用配置!
开发–运维。问题:我在我的电脑上可以运行!版本更新,导致服务不可用!对于运维来说,考验就十分大?
环境配置是十分麻烦的,每一个机器都要部署环境(集群redis,ES,Hadoop…)!费时费力
发布一个项目(jar+(redis mysql jdk es)),项目能不能都带上环境安装打包!
之前在服务器配置一个应用的环境,redis mysql jdk es hadoop,配置超麻烦了,不能跨平台。
windows,最后发布到Linux!
传统:开发jar,运维来做!
现在:开发打包部署上线,一套流程昨晚!
java – apk – 发布(应用商店)-- 张三使用apk – 安装即可用
java – jar(环境) – 打包项目带上环境(镜像)-- (docker仓库:商店)-- 下载我们发布的镜像 – 运行即可
docker给以上的问题,提出了解决方案!
dokcer的思想来源于集装箱!
JRE – 多个应用(端口冲突)-- 原来都是交叉的!
隔离:docker 核心思想!打包装箱!每个箱子都是互相隔离的。
水果 生化武器
docker通过隔离机制,可以将服务器利用到极致!
本质:所有的技术都是因为出现了一些问题,我们需要去解决,才去学习!
1.2 Docker的历史
Docker是基于Go语言开发的!开源项目!
官网:https://www.docker.com/
文档地址:https://docs.docker.com/ Docker的文档是超级详细的!
仓库地址:https://hub.docker.com
简介
Docker 从 17.03 版本之后分为 CE(Community Edition: 社区版) 和 EE(Enterprise Edition: 企业版),我们用社区版就可以了。官网:https://docs.docker.com/
1.3 Docker能干嘛
之前的虚拟机技术
虚拟机技术缺点:
1.资源占用十分多
2. 冗余步骤多
3. 启动很慢
容器化技术
容器化技术不是模拟的一个完整的操作系统
比较docker和虚拟机技术的不同
2. Docker 安装
2.1 Docker的基本组成
2.2 安装Docker
环境准备
1、需要会一点点的Linux的基础
2、Centos7
3、我们使用xshell连接远程服务器进行操作
环境查看
查看系统内核
uname -r
系统版本
cat /etc/os-release
安装
官网安装地址:https://docs.docker.com/engine/install/centos/
非root权限,命令前加sudo
1.卸载旧版本如果有的话
yum remove docker \
docker-client \
docker-client-latest \
docker-common \
docker-latest \
docker-latest-logrotate \
docker-logrotate \
docker-engine
2.需要的安装包
yum install -y yum-utils
之前安装过
3.设置镜像仓库
yum-config-manager \
--add-repo \
https://download.docker.com/linux/centos/docker-ce.repo #国外的地址(下载慢)
# 设置阿里云的Docker镜像仓库(使用这个)
yum-config-manager \
--add-repo \
https://mirrors.aliyun.com/docker-ce/linux/centos/docker-ce.repo #国内的地址
更新yum软件包索引
yum makecache fast
4. 安装docker docker-ce 社区版 ee企业版
yum install docker-ce docker-ce-cli containerd.io
5.启动docker
systemctl start docker
开机自启动
systemctl enable docker
6.使用docker version查看是否安装成功
7.下载hello-world镜像测试
docker run hello-world
此命令下载测试映像并在容器中运行它。
8.查看一下下载的hello-world镜像
docker images
2.3 卸载docker
1.卸载 Docker Engine、CLI 和 Containerd 包
yum remove docker-ce docker-ce-cli containerd.io
2.删除资源
rm -rf /var/ib/docker
/var/ib/docker
docker的默认工作路径
2.4 阿里云镜像加速
进入阿里云,搜索容器镜像服务
执行下面四条命令
sudo mkdir -p /etc/docker
sudo tee /etc/docker/daemon.json <<-'EOF'
{
"registry-mirrors": ["https://5aleeac1.mirror.aliyuncs.com"]
}
EOF
sudo systemctl daemon-reload
sudo systemctl restart docker
回顾hello-world流程
2.5 容器运行流程图
2.6 底层原理
Docker是怎么工作的?
Docker是一个Client-Server结构的系统,Docker的守护进程运行在主机上,通过Socket从客户端访问!DockerServer接收到Docker-Client的指令,就会执行这个指令!
Docker为什么比VM快?
1、Docker有着比虚拟机更少的抽象层。
2、docker利用的是宿主机的内核,VM需要的是Guest OS。
所以说,新建一个容器的时候,docker不需要像虚拟机一样重新加载一个操作系统内核,避免引导。虚拟机是加载Guest OS,分钟级别的,而docker是利用宿主机的操作系统,省略了复杂的过程,秒级。
3. docker的常用命令
帮助命令
docker version # docker版本信息
docker info # 显示docker的系统信息,包括镜像和容器的数量
docker 命令 --help # 帮助命令,(可查看某个命令的可选参数)
命令帮助文档的地址:https://docs.docker.com/engine/reference/commandline/docker/
3.1 镜像命令
3.1.1 查看所有本地的主机上的镜像
docker images
docker images
# 解释
REPOSITORY 镜像的仓库源
TAG 镜像的标签
MAGE ID 镜像的id
CREATED 镜像的创建时间
SIZE 镜像的大小
# 可选项
-a, --all Show all images (default hides intermediate images)