目录
一、Docker概述(开源的应用容器引擎)
1.1 什么是虚拟化?
在计算机中,虚拟化(英语:Virtualization)是一种资源管理技术,是将计算机的各种实体资源,如服务器、网络、内存及存储等,予以抽象、转换后呈现出来,打破实体结构间的不可切割的障碍,使用户可以比原本的组态更好的方式来应用这些资源。这些资源的新虚拟部份是不受现有资源的架设方式,地域或物理组态所限制。一般所指的虚拟化资源包括计算能力和资料存储。
在实际的生产环境中,虚拟化技术主要用来解决高性能的物理硬件产能过剩和老的旧的硬件产能过低的重组重用,透明化底层物理硬件,从而最大化的利用物理硬件 对资源充分利用。
虚拟化技术种类很多,例如:软件虚拟化、硬件虚拟化、内存虚拟化、网络虚拟化(vip)、桌面虚拟化、服务虚拟化、虚拟机等等。
1.2 Docker的出现
一款产品:开发--上线 两套环境!应用环境,应用配置!
开发--------运维,问题:我在我的电脑上可以运行!版本更新,导致服务不可用,对于运维来说,考验十分的大的!
配置环境是十分麻烦的,每一个机器都要部署环境(集群Redis、ES、Hadoop......)费时费力!
发布一个项目(jar+(Redis MySQL jdk ES)),项目能不能带上环境安装打包!
之前在服务器配置的一个应用的环境Redis MySQL jdk ES Hadoop,配置超麻烦了,不能够跨平台。
Windows,最后发布到Linux。
传统:开发jar,运维来做;
现在:开发打包部署上线,一套流程做完!
java -- apk -- 发布(应用商店) -- 小明使用apk -- 安装即可使用!
java -- jar(环境)-- 打包项目带上环境(镜像)-- Docker仓库:商店 -- 下载我们发布的镜像 -- 直接运行即可让!
Docker给以上问题,提出了解决!
Docker的思想来自于集装箱!
JRE -- 多个应用(端口冲突)-- 原来都是交叉的!
隔离:Docker核心思想,打包装箱,每一个箱子是互相隔离的。
Docker通过隔离机制,可以将服务器利用到极致!
本质:所有的技术都是因为出现了一些问题,需要去解决,才去学习。
1.3 Docker历史
2010年,几个搞IT的年轻人,在美国成立了一家公司dotCloud,做一些pass的云计算服务,LXC有关的容器技术。他们将自己的技术(容器化技术)命名就是Docker。
Docker刚诞生的时候,没有引起行业的注意,dotCloud就活不下去!
开源
开发源代码!
2013年,Docker开源!
Docker越来越多的人发现了Docker的优点!火了,Docker每个月都会更新一个版本!
2014年4月9日Docker1.0发布!
Docker为什么这么火?十分的轻巧!!
在容器技术出来之前,我们都是使用虚拟机技术。
虚拟机:在windows中装一个Vmware,通过这个软件我们可以虚拟出来一台或者多台电脑,笨重。
虚拟机也是属于虚拟化技术,Docker容器技术,也是一种虚拟化技术!
vm:linux centos原生镜像(一个电脑) 隔离,需要开启多个虚拟机!! 几个G 几分钟!!
docker:隔离,镜像(最核心的环境4m+jdk+mysql)十分轻巧,运行镜像就可以了!小巧!几个M KB 秒级启动!!
到现在,所有开发人员都必须会Docker!
聊聊Docker
Docker是基于Go语言开发的!开源项目!
Docker官网:Docker: Accelerated, Containerized Application Development
Docker文档地址:Docker Docs: How to build, share, and run applications | Docker Documentation,
Docker的文档是超级详细的!
Docker仓库地址:https://hub.docker.com/
1.4 Docker能做什么
和之前的虚拟机进行对比
虚拟机技术缺点:
1、资源占用十分多
2、冗余步骤多
3、启动很慢!
容器化技术
容器化技术不是模拟的一个完整的操作系统。
比较Docker和虚拟机技术的不同:
-
传统的虚拟机,虚拟出一条硬件,运行一个完整的操作系统,然后在这个系统上安装和运行软件。
-
容器内应用直接运行在宿主机的内容,容器没有自己的内核的,也没有虚拟我们的硬件,所以就轻便了;
-
每个容器间是互相隔离的,每个容器都有一个属于自己的文件系统,互不影响。
DevOps(开发、运维)
四个特点:
1、应用更快速的交付和部署;
传统:一堆帮助文档,安装程序。
Docker:打包镜像发布测试,一键运行
2、更便捷的升级和扩缩容;
使用了Docker之后,部署应用就和搭积木一样!
项目打包为一个镜像,扩展服务器A!服务器B!
3、更简单的系统运维;
在Docker(容器化)之后,开发,测试环境都是高度一致的!
4、更高效的计算资源利用。
Docker是内核级别的虚拟化,在一个物理机上可以运行很多的容器实例!服务器的性能被压榨到极致。
二、Docker安装
2.1 Docker的基本组成
镜像(image):
Docker镜像就好比是一个模板,可以通过这个模板来创建容器服务,tomcat镜像-->run-->tomcat容器(提供服务器),通过这个镜像可以创建多个容器(最终服务运行或者项目运行就是在容器中的)。
容器(container):
Docker利用容器技术,独立运行一个或者一个组应用,通过镜像来创建的。启动,停止,删除,基本命令在,目前就可以把这个容器理解为就是一个简易的Linux系统。
仓库(repository):
仓库就是存放镜像的地方;
Docker Hub(默认是国外的);
阿里云...都有日期服务器(配置镜像加速)。
2.2 安装Docker
环境准备
Docker支持64位版本的CentOS 7和CentOS 8及更高版本,它要求Linux内核版本不低于3.10,使用Xshell连接远程服务器进行操作!
环境查看(查看Linux版本的命令)
lsb_release -a
cat /etc/redhat-release
查看内核版本命令
# 系统内核是3.10以上的
cat /proc/version
uname -a
uname -r
[root#liudl /]# uname -r
3.10.0-1062.12.1.e17.x86_64
1.安装
Docker官网install on Linux帮助文档:
1.1 卸载旧版本
较旧的Docker版本称为docker或docker-engine。
sudo yum remove docker \
docker-client \
docker-client-latest \
docker-common \
docker-latest \
docker-latest-logrotate \
docker-logrotate \
docker-engine
1.2 需要的安装包
sudo yum install -y yum-utils
1.3 设置镜像的仓库
sudo yum-config-manager --add-repo https://download.docker.com/linux/centos/docker-ce.repo # 默认是从国外的
sudo yum-config-manager --add-repo http://mirrors.aliyun.com/docker-ce/linux/centos/docker-ce.repo #推荐使用阿里云的,十分的快
1.4 更新yum软件的索引
yun makecache fast
1.5安装docker相关的依赖 docker-ce 社区 ee 企业版
yum install docker-ce docker-ce-cli containerd.io
1.6 启动docker
sudo systemctl start docker
1.7 使用docker version 查看是否安装成功
docker version
1.8 hello-world
sudo docker run hello-world
1.9 查看一下下载的这个hello-world镜像
docker images
2.卸载docker
2.1 卸载依赖
sudo yum remove docker-ce docker-ce-cli containerd.io
2.2 删除资源
sudo rm -rf /var/lib/docker
# /var/lib/docker docker默认的工作路径!
2.3 阿里云镜像加速
1、登录阿里云找到容器服务
2、找到镜像加速器的位置
鉴于国内网络问题,后续拉取 Docker 镜像十分缓慢,我们可以需要配置加速器来解决。
可以使用阿里云的docker镜像地址:https://bcrrfx0y.mirror.aliyuncs.com
3、配置镜像加速器
针对Docker客户端版本大于 1.10.0 的用户
可以通过修改daemon配置文件/etc/docker/daemon.json来使用加速器
sudo mkdir -p /etc/docker
sudo tee /etc/docker/daemon.json <<-'EOF'
{
"registry-mirrors": ["https://bcrrfx0y.mirror.aliyuncs.com"]
}
EOF
# 重启docker
sudo systemctl daemon-reload
sudo systemctl restart docker
检查加速器是否生效
配置加速器之后,如果拉取镜像仍然十分缓慢,请手动检查加速器配置是否生效,在命令行执行 docker info
,如果从结果中看到了如下内容,说明配置成功。
Registry Mirrors:
https://7qyk8phi.mirror.aliyuncs.com/
下载docker-compose
#运行此命令以下载 Docker Compose 的当前稳定版本
sudo curl -L "https://github.com/docker/compose/releases/download/1.29.2/docker-compose-$(uname -s)-$(uname -m)" -o /usr/local/bin/docker-compose
#对二进制文件应用可执行权限
sudo chmod +x /usr/local/bin/docker-compose
#测试安装docker-compose --version
#若有docker-compose version 1.29.2, build 5becea4c,则安装成功
2.4 回顾HelloWorld流程
run的运行流程图
2.5 底层原理
Docker是如何工作的?
Docker是一个Client-Server结构的系统,Docker的守护进程运行在主机上。通过Socket从客户端访问!
DockerServer接收到Docker-Client的指令,就会执行这个命令。
Docker为什么比vm快?
1、Docker有着比虚拟机更少的抽象层。
2、Docker利用的是宿主机的内核,vm需要是Guest OS。
所以说,新建一个容器的时候,Docker不需要像虚拟机一样重新加载一个操作系统内核,避免引导。虚拟机是加载Guest OS,分钟级别的,而Docker是利用宿主机的操作系统的,省略了这个复杂的过程,秒级。