简介Docker以及K8s

news2025/1/16 15:59:01

什么是Docker

Docker 属于 Linux 容器的一种封装,提供简单易用的容器使用接口以及操作系统级别的虚拟化。

更为直白的叙述就是,Docker可以将程序和环境(依赖库+配置+操作系统)打包并运行的工具软件。

基础镜像

总所周知,环境不同,程序运行的结果就会不同,甚至会失败。所以统一环境是十分有必要的,其中最重要的就是操作系统的统一。让所有程序都跑在同一个操作系统上,利用操作系统的用户空间构建出应用程序所需的环境。

镜像(image)就是对应用程序及其依赖进行打包,通过该文件生成Docker容器及容器实例。同一个image文件可生成多个同时运行的容器实例。

Dockerfile

在有了基础镜像后,往往为构建复杂的应用程序,需要安装各种依赖以及文件夹。Dockerfile就是可以将这些需要安装的依赖相关的命令等列个清单,从而创建出一个适合程序运行的环境。

容器

当我们用命令执行docker build的时候, docker就会按着Dockerfile的说明,一行行构建环境+应用程序。最终将这个环境+程序,打包成一个类似“压缩包”的东西,我们称之为容器镜像(container image)

基于此,当我们执行docker run命令时,就会将容器镜像给“解压缩”,获得一个独立的环境和应用程序并运行起来。也就是所谓的容器(container)

简而言之,容器就是镜像创建的运行实例,Docker利用容器来运行应用。每个容器都是相互隔离的、保证安全的平台。我们可以把容器看做是一个轻量级的Linux运行环境。

容器VS虚拟机

Docker容器:使用Docker引擎进行调度和隔离,提高了资源利用率,在相同硬件能力下可以运行更多的容器实例;每个容器拥有自己的隔离化用户空间。

VM:使用Hypervisor提供虚拟机的运行平台,管理每个VM中操作系统的运行。每个VM都要有自己的操作系统、应用程序和必要的依赖文件等。

一句话概括就是,容器本质上只是个自带独立运行环境的特殊进程,底层用的其实是宿主机的操作系统内核

什么是Docker compose

一个可以用来定义和分享多容器应用程序的工具。可以使用单一资源来运行一个有多容器的项目。在对容器部署顺序有要求的项目下使用十分便利(比如先启动数据库在启动身份验证最后启动web服务)

常见的docker操作命令

// 列出本机所有的image文件
docker image ls

// 运行指定image文件 自动抓取image文件。如果发现本地没有指定的image文件,就会从仓库自动抓取
docker container run xxx

// 列出本机正在运行的容器
docker container ls

// 列出本机所有容器,包括终止运行的容器
docker container ls --all

// 终止运行的容器文件
docker container rm [containerID]

// 启动已经生成已经停止运行的容器文件
docker container start [containerID]
	
// 查看docker容器里的输出 如果docker run命令运行容器的时候,没有使用-it参数,就要用这个命令查看输出
docker container logs [containerID]

// 将docker容器里正运行文件拷贝到本机
docker container cp [containID]:[/path/to/file]

// 本地image镜像重命名
docker tag imageName:TAG REGISTRYHOST/USERNAME/NAME:TAG
docker tag hello-world:latest registry.cn-shenzhen.aliyuncs.com/chenjinting/hello-world:v1.0.0

// 查看正在运行的容器 
docker ps

// 查看所有的容器
docker ps -a
	
// 附加到运行的容器
docker attach [name]/[containerId]

// 后台运行容器
docker run (–name xxx) -d xxx xxxx/xxx/xxx 

// 查看运行中容器的进程号
docker top xxx(name)

// 停止容器
docker kill xxx(name)

// 查看容器的具体信息
docker inspect  [name]/[containerId]

// 删除镜像文件
docker rmi 仓库名+标签名

// 删除所有标签及其镜像文件
docker rmi 【id】

// 查找镜像
docker search xxx

// 拉取镜像
docker pull xxx

// 导成tar包并使其具备可移植性:
docker save -o xxx.tar xxxx(name)

什么是K8s

一个开源的容器编排平台,可以自动化在部署、管理和扩展容器化应用过程中涉及的许多手动操作。可以轻松对服务器实现负载均衡以及弹性伸缩。

K8s与docker的关系

Docker 部署的容器,其实就是 k8s 调度的 Pod 里的 container,它们都叫容器,其实是一回事。只不过 k8s 除了支持 Docker 的容器外,还支持别人家的容器。Docker Compose 基于多个 container 创建的一整套服务,其实就是 k8s 里的 pod

Docker 主要负责容器的创建和管理,而 Kubernetes 则负责这些容器的编排和管理。简单来说,Docker 解决的是“如何运行单个容器”的问题,而 Kubernetes 解决的是“如何在大规模环境中管理和编排多个容器”的问题。

写在最后

简单介绍了下Docker,Docker常见命令以及K8s, 后面应该会继续补充(大概)

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1920600.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

搜维尔科技:《Patchwork 3D 2024》现已推出,改善用户体验的同时添加了最受欢迎的功能

《Patchwork 3D 2024》现已推出!发现我们在改善用户体验的同时添加的最受欢迎的功能。 令人兴奋的消息值得分享!Patchwork 3D 已经升级,并带来一些令人惊叹的新功能。 材料 镜面材质现在支持漫反射、镜面反射和凹凸特性,可实现精细调整的光…

防火墙安全策略练习

目录 实验拓扑 实验要求 实验思路 实验步骤 1.配置交换机,划分接口的vlan,配置ISP 2.配置防火墙 3.接下来在WEB界面进行所有安全策略操作 配置接口 创建安全区域: 创建地址: 时间段: 安全策略部分&#xff…

Java 常用的参数校验,简化参数校验,赶紧学起来!!

Java 常用的参数校验,简化参数校验,赶紧学起来!!Java中的参数校验注解主要用于简化数据验证的过程,它们允许开发者以声明式的方式指定参数的验证规则,而无需在业https://mp.weixin.qq.com/s?__bizMzkzMTY0…

LLM-向量数据库中的索引算法总结

文章目录 前言向量数据库介绍索引方法倒排索引KNN 搜索近似 KNN 搜索Product Quantization(PQ)NSW 算法搜索HNSW 前言 向量数据库是当今大模型知识库检索落地实践的核心组件,下图是构建知识库检索的架构图: 首先会将相关文档数据向量化嵌入到向量化数据…

视图库对接系列(GA-T 1400)十六、视图库对接系列(本级)通知(订阅回调)

说明 之前我们实现了订阅接口,其中有一个receiveAddr参数, 这个就是对应的回调的地址。一般情况下对应的是同一个服务。 我们推荐使用http://xxx:xxx/VIID/SubscribeNotifications接口文档 SubscribeNotificationList对象对象如下: 文档中是xml,但实际上目前使用的都是jso…

在 PostgreSQL 里如何处理数据的归档和清理策略的优化?

文章目录 在 PostgreSQL 中处理数据归档和清理策略的优化一、理解数据归档和清理的重要性二、确定归档和清理的标准三、PostgreSQL 中的数据归档方法(一)使用分区表(二)导出数据 四、PostgreSQL 中的数据清理方法(一&a…

操作系统——内存管理(面试准备)

虚拟内存 单片机没有操作系统,每次写完代码,都需要借助工具把程序烧录进去,这样程序才能跑起来。 另外,单片机的CPU是直接操作内存的物理地址。 在这种情况下,想在内存中同时运行两个程序是不可能的,如果第…

JavaFx+MySql学生管理系统

前言: 上个月学习了javafx和mysql数据库,于是写了一个学生管理系统,因为上个月在复习并且有一些事情,比较忙,所以没有更新博客了,这个项目页面虽然看着有点简陋了,但是大致内容还是比较简单的,于是现在跟大家分享一下我的学生管理系统,希望对这方面有兴趣的同学提供一些帮助 &a…

浪潮服务器内存物理插槽位置

浪潮服务器内存物理插槽位置 如下图所示

在iPhone / iPad上轻松模拟GPS位置 AnyGo for Mac

在iPhone / iPad上轻松模拟GPS位置 AnyGo for Mac AnyGo for Mac是一款专为Mac电脑用户设计的虚拟定位工具。它可以模拟你的GPS位置,让你的设备显示你在任何世界上的任何地方。无论你是想在游戏中虚拟移动,还是在社交媒体上分享虚拟的旅行照片&#xff0…

基于SpringBoot+MySQL的租房项目+文档

💗博主介绍💗:✌在职Java研发工程师、专注于程序设计、源码分享、技术交流、专注于Java技术领域和毕业设计✌ 温馨提示:文末有 CSDN 平台官方提供的老师 Wechat / QQ 名片 :) Java精品实战案例《700套》 2025最新毕业设计选题推荐…

05 以物品与用户为基础个性化推荐算法的四大策略

《易经》:“九二:见龙在田,利见大人”。九二是指阳爻在卦中处于第二位,见龙指龙出现在地面上,开始崭露头角,但是仍须努力,应处于安于偏下的位置。 本节是模块二第一节,模块二讲解传…

从业务架构到应用架构技术剖析

从业务架构到应用架构 4A架构理论,一个企业级架构框架,将企业架构(EA)划分为四大核心领域,每个领域都聚焦于组织的不同维度。该理论提供了一种结构化的设计和理解企业运作方式的方法,确保技术解决方案能…

前端面试题53(在vue中history与hash区别)

在Vue.js应用中,路由(routing)是管理应用程序中不同页面(视图)的重要部分。Vue Router提供了两种路由模式来管理URL:hash模式和history模式。下面详细介绍这两种模式的区别: 1. Hash 模式 原理…

如何在idea安装git,使用gitee?

一、什么是git,git与gitee、GitHub的关系? 1.什么是git? Git 是一个开源的分布式版本控制系统,用于企业项目中程序员协同开发。 2.git与gitee、GitHub的关系是什么? git :Git是一种版本控制系统&#x…

Linux:NFS共享存储

目录 一、NFS基本概述 二、NFS共享文件实验 2.1、安装nfs和rpcbind软件 2.2、修改配置文件设置共享 2.3、创建共享目录 ​编辑 2.4、开启服务 2.5、客户端验证共享目录可访问 三、tcpdump命令 3.1、概述 3.2、简单表达 3.3、过滤规则 ​编辑 3.4、tcpdump常见参数…

Redis分布式锁在高并发环境下的超卖问题

先看这样一段代码,购买商品,扣减库存的逻辑代码 当用户下单,并且调用扣减库存的接口时,先判断商品库存是否还有,因为是秒杀场景下,太多请求都打到数据库,可能会导致数据库崩溃,所以…

[leetcode] largest-divisible-subset 最大整除子集

. - 力扣&#xff08;LeetCode&#xff09; class Solution { public:vector<int> largestDivisibleSubset(vector<int>& nums) {int len nums.size();sort(nums.begin(), nums.end());// 第 1 步&#xff1a;动态规划找出最大子集的个数、最大子集中的最大整…

Djngo项目创建的准备工作【5】

【 一 】搭建纯净模式 核心就是 在安装完drf之后记得在app里面注册rest_framework, # django 默认很多app--》很多表auth 6个表session 表content-type表 # django很多中间件 ​ # 以后我们的项目&#xff0c;可能不用这些东西---》由于带了内置app&#xff0c;这些表就会创建…

MaxViT : 多轴Vision Transformer

本文提出了一种高效、可扩展的多轴注意力模型,该模型包括两个方面:局部注意力被阻塞和全局注意力被扩张。这些设计选择允许在任意输入分辨率下的全局-局部空间交互,只有线性复杂度。还通过有效地将注意力模型与卷积混合在一起,提出了一个新的架构元素,并相应地提出了一个简…