《Docker技术革命:从虚拟机到容器化,全面解析Docker的原理与应用-上篇》(一)

简介: 《Docker技术革命:从虚拟机到容器化,全面解析Docker的原理与应用-上篇》(一)

Docker为什么会出现

对于互联网公司的产品研发,通常有两个环境,一个是开发环境,一个是上线环境。

产品从研发到上线,两个环境的应用配置要对齐,这个时候容易出现这样的问题:

这段代码在我的电脑上能运行,在你的电脑上不能运行了?这个时候开发和运维就会因为这个问题陷入焦灼。

后端程序员需要掌握:

  • 开发
  • 运维
  • 架构

这个时候开发运维一体化了,所以要学习Docker了,要去把运维的工作也干了!运维的工作难度,复杂度主要体现在环境配置这个方面,那我们这帮程序员要去卷运维该怎么卷?

环境的配置十分繁琐,每一个机器都要部署环境(集群Redis、ES、Hadoop)耗时费力。

过去程序员发布一个jar包出来,运维工程师就去配置环境,把这个jar包跑在服务器上。现在的情况变成了:程序员发布jar包的时候,把环境也带上了,把项目+环境一起打包。

总结

传统:开发jar包,运维来做。

  • Java–apk–发布(应用商店)–张三使用apk–安装即可

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

  • Java–jar(环境)–打包项目带上环境(镜像)–(Docker仓库:商店)—下载我们发布的镜像—直接运行即可,

Docker的思想

Docker 的思想来源于集装箱!Docker的核心思想是: 隔离

打包箱子,每个箱子是互相隔离的!

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

Docker历史

Docker出现之前还是虚拟机的天下,虚拟机技术就是我们在VM中用Linux编程搞环境那套东西。但是后来出现了容器技术,这个容器技术就是我们今天谈的Docker!

Docker 的出现是为了解决虚拟机技术带来的笨重!

总结

虚拟机用的是虚拟化技术,虚拟软件、硬件需要的环境。Docker用的是容器技术,但这种容器技术也是虚拟化技术,只是一种轻量级的虚拟化技术罢了。

传统的虚拟机搞隔离要开很多个虚拟机才能实现分布式集群。这是一种非常笨重的方法。

Docker用了一个叫镜像的东西,把应用需要的环境,比如jdk+mysql等等环境安装打包到镜像里面,你直接运行镜像即可,非常快,非常小巧方便。

Docker能干嘛

虚拟机技术

之前的虚拟机技术:

虚拟机技术的缺点
  • 资源占用多
  • 冗余步骤多
  • 启动很慢

容器化技术

现在的容器化技术:

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

Docker和虚拟机技术的区别

比较docker和虚拟机技术的不同

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

DevOps(开发、运维)

应用更快速的交付和部署

传统:

  • 一堆帮助文档、安装程序

Docker:

  • 打包镜像发布测试、一键运行

更便捷的升级和扩容

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

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

更简单的系统运维

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

更高效的计算资源利用

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

Docker概念

Docker的基本组成

镜像(image)

Docker镜像好比是一个模板,可以通过这个模板来创建容器服务,Tomcat镜像===>run===>Tomcat01容器(提供服务),通过这个镜像可以创建多个容器(最终服务运行或者项目运行就是在容器中的)。

容器(container)

Docker利用容器技术,独立运行一个或者一组应用,通过镜像来创建的。

启动、停止、删除、基本命令!

目前就可以把容器理解成一个简易的Linux系统

仓科(repository)

仓库就是存放镜像的地方!仓库分为公有仓库和私有仓库!

安装Docker

卸载旧版本

$ sudo yum remove docker \
                  docker-client \
                  docker-client-latest \
                  docker-common \
                  docker-latest \
                  docker-latest-logrotate \
                  docker-logrotate \
                  docker-engine

需要的安装包

sudo yum install -y yum-utils \
  device-mapper-persistent-data \
  lvm2

设置镜像仓库

sudo yum-config-manager \
    --add-repo \
    https://mirrors.aliyun.com/docker-ce/linux/centos/docker-ce.repo

安装docker

sudo yum install docker-ce docker-ce-cli containerd.io docker-compose-plugin

启动docker

$ sudo systemctl start docker
验证docker
docker version

测试Helloworld

docker run hello-world

Helloworld执行流程

上面的执行Helloworld流程如下:

查看镜像文件

docker images

阿里云镜像加速

1、登录阿里云官网

用自己的手机号进行注册即可。

2、找到镜像加速器配置

这里选择CentOS!

sudo mkdir -p /etc/docker
sudo tee /etc/docker/daemon.json <<-'EOF'
{
  "registry-mirrors": ["https://kjrexsxz.mirror.aliyuncs.com"]
}
EOF
sudo systemctl daemon-reload
sudo systemctl restart docker

《Docker技术革命:从虚拟机到容器化,全面解析Docker的原理与应用-上篇》(二)+https://developer.aliyun.com/article/1625019

目录
相关文章
|
11月前
|
运维 持续交付 虚拟化
深入解析Docker容器化技术的核心原理
深入解析Docker容器化技术的核心原理
228 1
|
jenkins Java Shell
使用 Docker 安装 Jenkins 并实现项目自动化部署
Jenkins 是一款开源的持续集成(DI)工具,广泛用于项目开发,能提供自动构建,测试,部署等功能。作为领先的开源自动化服务器,Jenkins 提供了数百个插件来支持构建、部署和自动化任何项目。
35250 3
使用 Docker 安装 Jenkins 并实现项目自动化部署
|
安全 Java Linux
|
Kubernetes 容器 Perl
【kubernetes】解决: kubelet Failed to create pod sandbox: rpc error: code = Unknown desc = faile...
【kubernetes】解决: kubelet Failed to create pod sandbox: rpc error: code = Unknown desc = faile...
16376 0
|
JSON 数据格式 Docker
docker load导入镜像报错:open /var/lib/docker/tmp/docker-import-970689518/bin/json: no such file or directo...
docker load导入镜像报错:open /var/lib/docker/tmp/docker-import-970689518/bin/json: no such file or directo...
6454 0
|
11月前
|
消息中间件 中间件 Kafka
分布式事务最全详解 ,看这篇就够了!
本文详解分布式事务的一致性及实战解决方案,包括CAP理论、BASE理论及2PC、TCC、消息队列等常见方案,助你深入理解分布式系统的核心技术。关注【mikechen的互联网架构】,10年+BAT架构经验倾囊相授。
分布式事务最全详解 ,看这篇就够了!
|
Kubernetes 应用服务中间件 nginx
史上最全干货!Kubernetes 原理+实战总结(全文6万字,90张图,100个知识点)(上)
史上最全干货!Kubernetes 原理+实战总结(全文6万字,90张图,100个知识点)
51522 30
|
12月前
|
Linux 虚拟化 开发者
一键将CentOs的yum源更换为国内阿里yum源
一键将CentOs的yum源更换为国内阿里yum源
16475 31
|
12月前
|
Linux Docker 容器
Centos安装docker(linux安装docker)——超详细小白可操作手把手教程,包好用!!!
本篇博客重在讲解Centos安装docker,经博主多次在不同服务器上测试,极其的稳定,尤其是阿里的服务器,一路复制命令畅通无阻。
18993 5
Centos安装docker(linux安装docker)——超详细小白可操作手把手教程,包好用!!!
|
Docker 容器
Docker安装及镜像源修改
本文介绍了Docker的安装过程和如何修改Docker镜像源以加速下载。包括更新系统包、安装所需软件包、设置yum源、安装Docker以及验证安装是否成功。接着,提供了修改Docker镜像源的步骤,包括创建配置文件、编辑配置文件以设置镜像加速地址,并提供了几个常用的国内镜像源地址。最后,通过重启Docker服务和检查配置是否生效来完成镜像源的修改。
Docker安装及镜像源修改