Docker简介

文章目录

1、Docker简介

Docker是以Docker容器为资源分割和调度的基本单位,封装整个软件运行时环境,为开发者和系统管理员设计的,用于构建、发布和运行分布式应用的平台。

1.1、Docker解决的问题

  1. 解决了应用程序本地运行环境与生产运行环境不一致的问题
  2. 解决了应用程序资源使用的问题,docker会一开始就为每个程序指定内存分配和CPU分配
  3. 让快速扩展、弹性伸缩变得简单

1.2、Docker技术边界

docker是容器化技术,针对的是应用及应用所依赖的环境做容器化。遵循单一原则,一个容器只运行一
个主进程
。多个进程都部署在一个容器中,弊端很多。比如更新某个进程的镜像时,其他进程也会被迫

重启,如果一个进程出问题导致容器挂了,所有进程都将无法访问。再根据官网的提倡的原则而言,
器 = 应用 + 依赖的执行环境
而不是像虚拟机一样,把一堆进程都部署在一起。

要在一个docker里面部署多个应用程序,就需要采用其他的办法,比如启动一个守护进程来指定多个应用程序。

1.3、Docker带来的改变

  1. 软件交付方式发生了变化
  2. 替代了虚拟机
  3. 改变了我们体验软件的模式
  4. 降低了企业成本
  5. 促进了持续集成、持续部署的发展
  6. 促进了微服务的发展

1.4、Docker和虚拟机的区别

  1. vm(虚拟机)与docker(容器)框架,直观上来讲vm多了一层guest OS,同时Hypervisor会对硬
    件资源进行虚拟化,docker直接使用硬件资源,所以资源利用率相对docker低
  2. 服务器虚拟化解决的核心问题是资源调配,而容器解决的核心问题是应用开发、测试和部署。
  3. 容器技术严格来说并不是虚拟化,没有客户机操作系统,是共享内核的。

1.5、Docker 架构图

  1. 镜像(Image):Docker 镜像是用于创建 Docker 容器的模板,比如 Ubuntu 系统
  2. 容器(Container):容器是独立运行的一个或一组应用,是镜像运行时的实体
  3. 客户端(client):Docker 客户端通过命令行或者其他工具使用 Docker SDK
    (https://docs.docker.com/develop/sdk/)) 与 Docker 的守护进程通信
  4. 主机(host):一个物理或者虚拟的机器用于执行 Docker 守护进程和容器,相当于docker服务端
  5. 注册中心(Registry):Docker 仓库用来保存镜像,可以理解为代码控制中的代码仓库。Docker
    Hub(https://hub.docker.com)) 提供了庞大的镜像集合供使用。
  6. Docker Machine:Docker Machine是一个简化Docker安装的命令行工具,通过一个简单的命令
    行即可在相应的平台上安装Docker。

1.6、直观感受client请求server

(1)安装socat。

bash 复制代码
sudo apt install socat

(2)socat执行监听。

bash 复制代码
socat -v UNIX-LISTEN:/tmp/dockerapi.sock UNIX-CONNECT:/var/run/docker.sock &

这条命令中,-v 用于提高输出的可读性,带有数据流的指示。UNIX-LISTEN 部分是让socat 在一个Unix套接字上进行监听,而UNIX-CONNECT 是让socat 连接到Docker 的Unix套接字。

(3)执行命令。

bash 复制代码
docker -H unix:///tmp/dockerapi.sock ps

输出:

bash 复制代码
> 2022/12/04 09:21:30.864275  length=82 from=0 to=81
HEAD /_ping HTTP/1.1\r
Host: docker\r
User-Agent: Docker-Client/20.10.12 (linux)\r
\r
< 2022/12/04 09:21:30.865645  length=281 from=0 to=280
HTTP/1.1 200 OK\r
Api-Version: 1.41\r
Cache-Control: no-cache, no-store, must-revalidate\r
Content-Length: 0\r
Content-Type: text/plain; charset=utf-8\r
Docker-Experimental: false\r
Ostype: linux\r
Pragma: no-cache\r
Server: Docker/20.10.12 (linux)\r
Date: Sun, 04 Dec 2022 09:21:30 GMT\r
\r
> 2022/12/04 09:21:30.869675  length=97 from=82 to=178
GET /v1.41/containers/json HTTP/1.1\r
Host: docker\r
User-Agent: Docker-Client/20.10.12 (linux)\r
\r
< 2022/12/04 09:21:30.870824  length=205 from=281 to=485
HTTP/1.1 200 OK\r
Api-Version: 1.41\r
Content-Type: application/json\r
Docker-Experimental: false\r
Ostype: linux\r
Server: Docker/20.10.12 (linux)\r
Date: Sun, 04 Dec 2022 09:21:30 GMT\r
Content-Length: 3\r
\r
[]
CONTAINER ID   IMAGE     COMMAND   CREATED   STATUS    PORTS     NAMES

总结

  1. Docker可以安装多个应用程序,但是Docker只有一个程序入口,也就是docker的启动命令只有一条。
  2. Docker和虚拟机不一样,Docker本身是一个软件,管理自己的进程,没有虚拟硬件设备。
相关推荐
贝锐20 小时前
Docker部署Teemii本地漫画库,并通过花生壳内网穿透实现远程访问
docker
i***22071 天前
springboot整合libreoffice(两种方式,使用本地和远程的libreoffice);docker中同时部署应用和libreoffice
spring boot·后端·docker
羑悻的小杀马特1 天前
轻量跨云·掌控无界:Portainer CE + cpolar 让远程容器运维像点外卖一样简单——免复杂配置,安全直达对应集群
运维·网络·安全·docker·cpolar
EAIReport1 天前
企业级报表自动化:基于Docker的部署实践
运维·docker·自动化
cui_win1 天前
Docker Compose 部署一个完整的Prometheus监控告警系统
docker·容器·prometheus
ALex_zry2 天前
Docker Compose运维技术实战分享:从安装到架构解析
运维·docker·架构
roman_日积跬步-终至千里2 天前
【Docker】Docker Stop 后到底发生了什么?——从信号机制到优雅停机
运维·docker·容器
z***6262 天前
Docker:基于自制openjdk8镜像 or 官方openjdk8镜像,制作tomcat镜像
docker·容器·tomcat
❀͜͡傀儡师2 天前
Docker部署视频下载器
docker·容器·音视频
热爱学习的小怪兽2 天前
docker的一些常用指令
运维·docker·容器