docker和kubernetes(k8s)

docker是什么

运行程序需要环境,不同的环境,程序运行的结果就不一样。将程序打包给其它客户端使用时,客户端需要自己配置相应的环境。我们将程序和环境一起打包给其它客户端,客户端可直接运行程序。docker容器作为程序和操作系统中间层,让程序依赖dockers容器中的环境,即可正常编译运行。

dockerfile是什么

从操作系统到应用服务的命令清单就是dockerfile。

容器镜像

docker build docker软件会按照dockersfile的内容构建环境,最终将环境和程序打包成类压缩包的文件,这个文件就是容器镜像。

Registry是什么

类似github仓库,负责管理镜像仓库的推拉能力的服务就是docker Register.

官方仓库为dockersHub,清华大学的tuna。

容器

docker run 将pull下来的文件解压并运行。独立的运行环境+程序就是一个容器,一个操作系统可以跑多个容器,这些容器之间是互相独立的。使用namespace能力让他看起来就像一个独立虚拟操作系统一样。

docker容器架构

使用的经典的client-server架构, client:docker-cli,server:docker-daemon。

docker-daemon:分为docker-server和Engine,docker-server本质是http服务器,接收到API后,将任务分发给Engine,Engine生成多个job执行具体的命令。

容器部署

在部署多容器时,可以使用yaml文件部署好要执行的内容。

docker-compose up 命令解析yaml文件,将容器们一键按顺序部署,就完成一整套服务的部署。

Docker Swarm 一整套服务在多台服务器上的集群部署问题,某应用在a服务器坏了,就将该应用在服务器上重新部署一套,实现迁移还能根据需要对应用做扩缩容。

docker和k8s的关系

k8s:容器编排引擎,在多台node的服务器上调度Pod进行部署和扩缩容,每个Pod内部可以含有多个container。container可以看成一个服务进程。k8s和Docker Swarm 是竞品。Pod和docker-compose做的事情本质是一样的。

相关推荐
milo.qu5 小时前
RockyLinux9.7 docker部署Jisti Meet
linux·docker·容器
梦想与想象-广州大智汇7 小时前
自建docker加速镜像,使用 Cloudflare Workers/Pages 部署加速教程
运维·docker·容器
AI服务老曹9 小时前
架构师视角:如何构建支持GB28181/RTSP的异构AI视频平台?从Docker部署到源码交付的深度实践
人工智能·docker·音视频
用户789377339085311 小时前
Docker 部署踩坑记录:从“构建失败”到“服务跑通”,以及为什么数据被清空了
python·docker
Slow菜鸟12 小时前
Docker 学习篇(三)| Docker安装指南(Linux版)
linux·学习·docker
炸炸鱼.15 小时前
容器技术入门与 Docker 环境部署
docker
宁静@星空16 小时前
007-Docker构建 jar 包成镜像
docker·容器·jar
A-刘晨阳17 小时前
K8s之负载均衡
linux·运维·容器·kubernetes·负载均衡
xmlhcxr17 小时前
从 0 到 1 落地企业级 DevOps CI/CD 流水线:基于 GitLab+Jenkins+Harbor 的完整实践
运维·docker·gitlab·jenkins·harbor·devops
米高梅狮子18 小时前
11.Quota and Limits、健康检查和认证与授权
云原生·容器·架构·kubernetes·自动化