【云原生-Docker篇】之 Docker入门精讲

简介: 容器是一种轻量级、可移植、自包含的软件打包技术,使得应用程序及其需要的支持环境

@[TOC](目录导航)



# 前言


> 写了几篇云原生之Docker篇的文章,发现没有写Docker入门篇,所以来补一下,希望能帮助更多刚入门Docker的同志。


# 一、容器3W介绍

## 1.1 什么是容器

容器是一种轻量级、可移植、自包含的软件打包技术,使得应用程序及其需要的支持环境一起打包,以相同的方式运行在几乎任何地方。


## 1.2 为什么需要容器

对开发人员来说 :Build Once, Run Anywhere (一次构建,随处运行)


对运维人员来说:Configure Once, Run Anywhere(配置一次,随处运行)


## 1.3 容器是如何工作的

Docker主要架构包含如下要素:


- Client,客户端包含多种形式,除了常用的Docker命令行之外,还可以通过REST API的形式,客户端的作用就是为了发送指令给到Docker Host,进行一系列的操作。Client可以和Docker Host运行在一台或者不同的机器上。

- Docker Host:

 - Docker Daemon,Docker的守护线程,通过接受Client的指令来对容器和镜像进行具体的操作事宜。默认情况下,只接受本地Host的Client指令。

 - Image,镜像是只读属性的,通过本地制作或者从Registry拉取获得,用来生成一个或者多个容器实例,是容器的模板 。

 - Container,容器实例,通过镜像运行而来,对容器的任何修改都不会影响镜像,真正对外提供服务的就是容器实例。

- Registry,镜像仓库,可以本地搭建、通常推荐使用国内大厂的镜像库,或者使用官方的DockHub镜像仓库。



它们之间的关系可用如下图表示:


*Docker架构图*

![Docker架构图](https://ucc.alicdn.com/images/user-upload-01/0350a9d3f5324ba69e3aa401eec36f86.webp#pic_center)

一个完整的工作流程如下:


1. 打开Docker Client客户端,连接上Docker Host;

2. 通过docker pull命令从Registry拉取镜像到本地;

3. 运行docker run命令从镜像实例化一个或者多个容器实例;


# 二、容器技术与虚拟机技术

*容器与虚拟机的比较*

![容器与虚拟机的比较](https://ucc.alicdn.com/images/user-upload-01/cf271ee0b7e34c55b8b879559af52d7e.webp#pic_center)


## 2.1 相同

都是一种虚拟技术,给应用提供相对独立的运行环境。它们都摆脱了对物理资源的直接依赖,相互之间以共享地方式高效地使用计算资源。


## 2.2 不同

虚拟机通常需要依赖Hypervisor技术,该技术可以为虚拟机分配独立的物理环境和操作系统,而容器则是基于Docker Engine直接使用宿主机的操作系统来进行虚拟资源的分配,无需再为每个虚拟单位安装Guest OS,大大减少了镜像的构建成本和运行成本。


因此,相同的物理资源下,容器能比虚拟机运行更多的虚拟单位,更加的轻量和高效。

相关文章
|
6月前
|
Ubuntu Linux Docker
Docker 入门全攻略:安装、操作与常用命令指南
Docker 的世界非常广阔,这只是一个开始,请继续探索和学习 Docker 的高级特性和最佳实践。后续也会继续更新相关的理论与实践内容。 只有锻炼思维才能可持续地解决问题,只有思维才是真正值得学习和分享的核心要素。如果这篇博客能给您带来一点帮助,麻烦您点个赞支持一下,还可以收藏起来以备不时之需,有疑问和错误欢迎在评论区指出~
|
9月前
|
存储 Kubernetes 开发者
容器化时代的领航者:Docker 和 Kubernetes 云原生时代的黄金搭档
Docker 是一种开源的应用容器引擎,允许开发者将应用程序及其依赖打包成可移植的镜像,并在任何支持 Docker 的平台上运行。其核心概念包括镜像、容器和仓库。镜像是只读的文件系统,容器是镜像的运行实例,仓库用于存储和分发镜像。Kubernetes(k8s)则是容器集群管理系统,提供自动化部署、扩展和维护等功能,支持服务发现、负载均衡、自动伸缩等特性。两者结合使用,可以实现高效的容器化应用管理和运维。Docker 主要用于单主机上的容器管理,而 Kubernetes 则专注于跨多主机的容器编排与调度。尽管 k8s 逐渐减少了对 Docker 作为容器运行时的支持,但 Doc
376 5
容器化时代的领航者:Docker 和 Kubernetes 云原生时代的黄金搭档
|
9月前
|
Ubuntu 应用服务中间件 nginx
docker入门-快速学会docker
本文介绍了Docker的基本概念,包括镜像、容器、tar文件、Dockerfile和仓库,并通过实际操作演示了如何使用Docker。从拉取Nginx镜像、运行容器、修改容器内容、保存容器为新镜像,到使用Dockerfile构建自定义镜像,最后讲解了如何保存和恢复镜像。文中还推荐了一个在线实践平台Play with Docker,方便读者快速上手Docker。
836 5
docker入门-快速学会docker
|
9月前
|
Kubernetes Cloud Native API
云原生入门:从理论到实践的探索之旅
本文旨在为初学者提供一个关于云原生技术的全面介绍,包括其定义、核心原则、关键技术组件以及如何将这些概念应用于实际项目中。我们将通过一个简易的代码示例,展示如何在云原生环境下部署一个简单的应用,从而帮助读者更好地理解云原生技术的实践意义和应用价值。
|
9月前
|
运维 Cloud Native 开发者
云原生技术入门与实践
在云计算的浪潮中,云原生技术以其独特的优势和魅力吸引了越来越多的开发者和企业。本文将从云原生技术的基本概念、核心组件以及实际应用三个方面进行详细介绍,帮助读者更好地理解和掌握这一新兴技术。同时,文章还将分享一些实际案例和经验教训,让读者能够更深入地了解云原生技术的应用场景和发展趋势。
183 5
|
10月前
|
Kubernetes Cloud Native 微服务
云原生入门与实践:Kubernetes的简易部署
云原生技术正改变着现代应用的开发和部署方式。本文将引导你了解云原生的基础概念,并重点介绍如何使用Kubernetes进行容器编排。我们将通过一个简易的示例来展示如何快速启动一个Kubernetes集群,并在其上运行一个简单的应用。无论你是云原生新手还是希望扩展现有知识,本文都将为你提供实用的信息和启发性的见解。
|
10月前
|
运维 Cloud Native 云计算
云原生之旅:Docker容器化实战
本文将带你走进云原生的世界,深入理解Docker技术如何改变应用部署与运维。我们将通过实际案例,展示如何利用Docker简化开发流程,提升应用的可移植性和伸缩性。文章不仅介绍基础概念,还提供操作指南和最佳实践,帮助你快速上手Docker,开启云原生的第一步。
|
10月前
|
Kubernetes Cloud Native 开发者
云原生入门:从容器到微服务
本文将带你走进云原生的世界,从容器技术开始,逐步深入到微服务架构。我们将通过实际代码示例,展示如何利用云原生技术构建和部署应用。无论你是初学者还是有经验的开发者,这篇文章都将为你提供有价值的信息和启示。
|
10月前
|
运维 Kubernetes Cloud Native
云原生技术入门:Kubernetes和Docker的协同工作
【10月更文挑战第43天】在云计算时代,云原生技术成为推动现代软件部署和运行的关键力量。本篇文章将带你了解云原生的基本概念,重点探讨Kubernetes和Docker如何协同工作以支持容器化应用的生命周期管理。通过实际代码示例,我们将展示如何在Kubernetes集群中部署和管理Docker容器,从而为初学者提供一条清晰的学习路径。
|
10月前
|
Kubernetes Cloud Native 云计算
云原生入门:Kubernetes 和容器化基础
在这篇文章中,我们将一起揭开云原生技术的神秘面纱。通过简单易懂的语言,我们将探索如何利用Kubernetes和容器化技术简化应用的部署和管理。无论你是初学者还是有一定经验的开发者,本文都将为你提供一条清晰的道路,帮助你理解和运用这些强大的工具。让我们从基础开始,逐步深入了解,最终能够自信地使用这些技术来优化我们的工作流程。