docker基本(仅供自己参考)

一、大型项目部署的问题:

1、大型项目的组件比较多,运行环境很复杂,部署通常会遇到各种问题:

(1):依赖关系复杂,容易出现兼容性问题

(2):开发、测试、生产环境有差异(比如centos开发和测试的,上线的时候需要部署到ubutu上,那么两个linux环境的不同就会造成项目出现错误)

二、问题的解决:

1、依赖问题的解决(不同的操作系统需要的依赖不同,并且版本不同的话需要的也不同)

(1):将应该的libs(函数库)、deps(依赖)、配置与应该一起打包

(2):将打包好的每一个应该都放到一个隔离容器(沙箱机制)与运行,避免应用的互相干扰。(解决了应用之间依赖和函数的混乱,现在是每个应用都有一个容器,容器与容器之间互相隔离,就避免了混乱的问题)

2、操作系统的架构:

linux基本的操作系统都可以分为二层:

(1):系统应用:每个系统都有自己的系统,每个系统应该的命令(函数)不同(导致部署项目系统之间的不兼容)

(2):内核:内核接收到每个系统的命令之后,将这些命令转化为相应的指令,这些指令就去操作计算机硬件。

了解了这些之后我们就知道每个系统的函数库(命令库)不同,但是到内核之后就会转为相同的指令,那么这些指令就可以操作计算机硬件了。

由此可知:当我们在每个应用的容器中顺带打包了某个系统的函数库,那么我们就可以部署到任意的一台机器上,而不用管这个机器是那个操作系统了(内核相同就行)

Docke的基本:

Docker:

五、镜像和容器:

1、镜像(Image):Docker将应用程序机器所需的依赖、函数、环境、配置等文件打包在一起,称为镜像。镜像只是可读的,容器只是复制镜像中的数据,然后去运行。

2、容器(Container):镜像中国的应用程序运行后形成的进程就是容器,只是Docker会给容器做隔离,对外不可见。

六、Docker和DockerHub:

dockerHub类似于gitHub,是一个docker镜像的托管平台,这样的平台被称为DockerRegisty;

七:Docker架构:

docker是cs(客户端-服务端)架构

1、服务端(server):Docker守护进程,负责处理Docker指令,管理(创建)镜像、容器等。

2、客户端(client):通过命令或RestApi向Docker服务端发送指令。可以在本地或远程向服务端发送指令

相关推荐
跳动的世界线3 分钟前
WSL 2 + Docker 本地全栈开发环境配置指南
运维·docker·容器
We Just Keep growing29 分钟前
【MySQL运维篇】——日志、主从复制、分库分表、读写分离
java·运维·数据库·windows·学习·mysql
情绪总是阴雨天~1 小时前
基于 Docker 的 Milvus + Redis 本地开发环境部署完全指南
redis·docker·milvus
xiaogg36781 小时前
Rancher2.0搭建kubernetes(K8S)集群
云原生·容器·kubernetes
会Tk矩阵群控的小木1 小时前
小红书矩阵系统2026最新技术架构与多账号自动化运营实战
运维·矩阵·架构·自动化·个人开发
戴西软件1 小时前
戴西CAxWorks.AICrash:AI+法规驱动的行人保护自动化分析
linux·运维·网络·人工智能·安全·自动化
IT策士1 小时前
第 44篇 k8s之实战:将 Web 应用迁移到 Kubernetes(上)
前端·容器·kubernetes
CingSyuan1 小时前
Linux服务器数据盘初始化与盘符漂移解决方案:标准分区、LVM逻辑卷、XFS格式化、fstab配置与UUID持久化挂载实战
linux·运维·服务器
Dxy12393102161 小时前
DNS负载均衡:看似简单,实则暗藏玄机
运维·负载均衡
珠海西格电力2 小时前
西格电力零碳园区管理系统的技术架构是怎样的?
大数据·运维·人工智能·物联网·架构·能源