Docker概述

1.Docker为什么会出现

一款产品:开发--上线 两套环境!应用环境,应用配置

开发--运维。问题:我在我的电脑上可以运行!版本更新,导致服务不可用!对应运维来说,考验十分大

开发即运维!

环境配置是十分的麻烦,每一个机器都要部署环境(集群Redis、es、Hadoop)!费事费力

发布一个项目jar war,项目能不能带上环境安装打包!

之前我们在服务器配置一个应用的环境 Redis、MySQL jdk es Hadoop 配置超麻烦,不能够跨平台

Windows, 最后发布到Linux

传统:开发jar 运维来做

现在:开发部署上线,一套流程做完!

Docker 给以上的问题,提出了解决方案!

image-20230311010045067

Docker的思想就来自于集装箱

JRE --多个应用(端口冲突)原来是交叉的

隔离:Docker核心思想!打包装箱!每个箱子是互相隔离的

Docker 通过隔离机制,可以将服务器利用到极致

本质:所有的技术都是因为出现了一些问题,我们需要去解决,采取解决

2.Docker的历史

2010年,几个搞IT的年轻人,就在美国成立了一家公司 dotCloud

做一些 pass 的云计算服务!

他们将自己的技术(容器化技术)命名就是Docker!

Docker刚诞生的时候,没有引起行业的注意 !

开源

2013 年,Docker开源!

Docker越来越多的人发现了Docker的优点!火了 Docker每个月更新一个版本

2014年4月9日,Docker 1.0发布!

Docker为什么这么火?十分的轻巧!

在此之前,我们都是使用虚拟机技术

虚拟机:在windows中装一个Vmware,通过这个软件我们可以虚拟出来一台或多台电脑

虚拟机也是属于虚拟化技术,Docker容器技术,也是一种虚拟化技术

聊聊Docker

Docker是Go语言开发的,开源项目

www.docker.com

3.Docker能干啥

虚拟机技术缺点:

1、资源占用十分多

2、冗余步骤多

3、启动很慢

容器换技术

容器化技术不是模拟的一个完整的操作系统

比较Docker和 虚拟机技术的不同:

  • 传统虚拟机,虚拟出一条硬件,运行一个完整的操作系统,然后在这个操作系统上安装和运行软件
  • 容器的应用直接运行在宿主机的内核,容器是没有自己的内核的也没有虚拟我们的硬件,所有就轻便了
  • 每个容器都是互相隔离的,每个容器内都有一个属于自己的文件系统,互不影响

DevOps(开发,运维)

应用更快速的交付和部署

传统:一堆帮助文档,安装程序

Docker: 打包镜像发布测试,一键运行

更便捷的升级和扩缩容

使用了Docker之后,我们部署应用就和搭积木一样!

SpringBoot

项目打包为一个镜像,扩展 服务器A 服务器B

更简单的系统运维

在容器化之后,我们的开发,测试环境都是高度一致的。

更高效的计算资源利用

Docker是内核级别的虚拟化,可以在一个物理机上可以运行很多的容器实例!服务器的性能可以被压榨到极致