Docker学习
Docker 概述
Docker 是一个开源的应用容器引擎,让开发者可以打包他们的应用以及依赖包到一个可移植的镜像中,然后发布到任何流行的 Linux或Windows 机器上,也可以实现虚拟化。容器是完全使用沙箱机制,相互之间不会有任何接口
为什么要用Docker?
由于开发人员的环境和运维人员的环境不一致,导致服务不可用!对于运维来说,考验就十分大了,环境配置十分的麻烦。
现在有了Docker开发打包部署上线,一套流程做完!非常的方便。
容器化技术
比较Docker 和 虚拟机的不同:
- 传统虚拟机,虚拟出一条硬件,运行一个完整的操作系统,然后在这个系统上安装和运行软件
- 容器内的应用直接运行在宿主机,容器是没有自己的内核,没有虚拟我们的硬件,所有就轻便了
- 每个容器间是互相隔离,每个容器内都有一个属于自己的文件系统,互不影响
Docker的优点:
应用更快速的交付和部署
更便捷的升级和扩缩容
更简单的系统运维
更高效的计算资源利用
Docker的基本组成
镜像(image):docker镜像好比是一个模板,通过这个模板来创建容器服务,tomcat镜像===>run==>tomcat01容器(提供服务器),通过这个镜像可以创建多个容器
容器(container):Docker利用容器技术,独立运行一个或者一组应用,通过镜像来创建的。
启动,停止,删除,基本命令
仓库(repository):仓库就是存放镜像的地方,仓库可以分为公用仓库和私有仓库,Docker Hub(默认是国外的),默认下载比较慢,可以配置阿里云镜像加速
安装Docker
docker官网:https://www.docker.com/
环境准备
CentOS 7
环境查看
#系统内核是3.10以上的
[root@localhost /]# uname -r
3.10.0-327.el7.x86_64
安装
#卸载旧版本
yum remove docker \
docker-client \
docker-client-latest \
docker-common \
docker-latest \
docker-latest-logrotate \
docker-logrotate \
docker-engine
#需要的安装包
yum install -y yum-utils
#设置镜像仓库
yum-config-manager \ #默认是国外的
--add-repo \
https://download.docker.com/linux/centos/docker-ce.repo
#推荐使用阿里云的镜像地址
yum-config-manager --add-repo http://mirrors.aliyun.com/docker-ce/linux/centos/docker-ce.repo
#更新yum软件包索引
yum makecache fast
# 安装docker docker-ce 社区 ee企业版
yum install docker-ce docker-ce-cli containerd.io
#启动docker
systemctl start docker
#使用docker version 看是否安装成功
# 测试运行 hello-world
docker run hello-world
了解卸载docker
# 1、卸载依赖
yum remove docker-ce docker-ce-cli containerd.io
# 2、删除资源
rm -rf /var/lib/docker
# /var/lib/docker docker的默认工作路径
阿里云镜像加速
1、登录阿里云账号,找到容器镜像服务
2、找到镜像镜像加速地址
3、配置使用
sudo mkdir -p /etc/docker
sudo tee /etc/docker/daemon.json <<-'EOF'
{
"registry-mirrors": ["https://sg1swo2o.mirror.aliyuncs.com"]
}
EOF
sudo systemctl daemon-reload
sudo systemctl restart docker
回顾docker run Hello-world
docker run 的执行流程
底层原理
docker是什么工作的?
Docker是一个Client - Server结构的系统,Docker的守护进程运行在主机上,通过Socket从客户端访问!
DockerServer接收到Docker-Client的指令,就会执行这个指令[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传
Docker为什么比虚拟机快?
1.Docker有着比虚拟机更少的抽象层,由于Docker不需要Hypervisor实现硬件资源虚拟化,运行在Docker容器上的程序直接使用的都是实际物理机的硬件资源,因此在Cpu、内存利用率上Docker将会在效率上有明显优势。
2.Docker利用的是宿主机的内核,而不需要Guest OS,因此,当新建一个容器时,Docker不需要和虚拟机一样重新加载一个操作系统,避免了引导、加载操作系统内核这个比较费时费资源的过程,当新建一个虚拟机时,虚拟机软件需要加载Guest OS,这个新建过程是分钟级别的,而Docker由于直接利用宿主机的操作系统则省略了这个过程,因此新建一个Docker容器只需要几秒钟