什么是容器

简介: 什么是容器

1.概述
什么是容器?容器,也叫Docker,是一个开源的容器化平台,用于开发、测试和部署应用程序。通过将软件打包为标准化的单元(容器),使得应用程序可以在任何地方一致地运行,不论是在开发者的本地机器上,还是在云计算平台上。Docker容器包含了应用程序运行所需的一切,包括代码、运行时、系统工具、系统库等,从而解决了“在我这里可以正常工作,但在服务器上不行”的问题。
2.产生背景
Docker诞生于2013年,由一个名为dotCloud(现已更名为Docker Inc.)的公司推出。其背后的主要驱动力是解决在现代分布式和微服务架构中应用程序的分发与部署问题。传统的虚拟机由于过重且启动慢,不太适合快速迭代的开发流程。基于容器的技术提供了一种轻量级的解决方案,允许更加灵活和高效的资源利用。

3.版本历史

  1. 2013年3月:Docker初次发布。
  2. 2014年6月:Docker 1.0发布,这是Docker的重要里程碑,标志着其进入生产环境准备就绪。
  3. 2015年11月:Docker 1.9发布,增加了Docker网络插件和多主机网络支持。
  4. 2016年6月:Docker 1.12发布,推出Docker Swarm,集群编排功能。
  5. 2017年6月:Docker 17.06发布,推出多阶段构建,从Dockerfile增强了构建过程中效率和便利性。
  6. 2018年2月:Docker 18.02发布,推出支持Kubernetes的功能。
  7. 2019年9月:Docker 19.03发布,加入了GPU加速和插件管理的改进。
  8. 2020年12月:Docker 20.10发布,进一步改善了安全性和操作便捷性。
  9. 2021年:持续改进和推出多个小版本,重点在性能和安全性上。
  10. 2023年:Docker通过Docker Desktop和Docker Hub继续提升开发者体验和生态集成。

4.应用场景
4.1.十个应用场景

  1. 持续集成和交付 (CI/CD):通过容器化的方式自动化构建、测试和部署流程。
  2. 微服务架构:每个微服务在独立的容器中运行,易于管理和扩展。
  3. 跨平台开发:开发人员可以在本地容器中搭建一致的开发环境,不再担心环境差异。
  4. 批处理任务:使用容器来运行短期的大规模批处理任务,按需使用资源。
  5. 研发测试:快速创建孤立的、可重复的测试环境。
  6. 现代化改造传统应用:把遗留的单体应用拆分成多个容器,以实现更易维护和扩展。
  7. 数据科学和机器学习:创建包含所需依赖的容器,便于复现性和协作。
  8. 物联网 (IoT):部署轻量级的边缘计算应用。
  9. 视频流媒体服务:容器可用来部署带有依赖的流媒体服务,确保一致性和效率。
  10. 高校教学:创建标准化的实验环境,让学生在同样的起跑线进行实践操作。

4.2.物联网
我们选取物联网领域来具体展开说明。物联网 (IoT)领域的复杂性以及规模的增长,促使开发者和工程师越来越多地采用边缘计算来处理数据和执行计算任务。使用 Docker 部署轻量级边缘计算应用是一种常见的方法,Docker 提供了灵活、可扩展和高效的容器化技术,能够简化应用程序的部署和管理。以下是如何在实际中使用 Docker 部署轻量级边缘计算应用的详细描述。

  1. 环境准备

硬件与软件要求
硬件设备:边缘设备可以是单板计算机(如树莓派)、网关、工控机或其他计算节点。
操作系统:支持 Docker 的操作系统(如 Linux,Windows Server 等)。

  1. Docker 安装与配置

在边缘设备上安装 Docker
2.1. 更新现有的软件包:

sudo apt-get update

2.2. 安装 Docker:
curl -fsSL https://get.docker.com -o get-docker.sh
sh get-docker.sh

2.3. 验证 Docker 安装:
sudo docker --version

相关实践学习
钉钉群中如何接收IoT温控器数据告警通知
本实验主要介绍如何将温控器设备以MQTT协议接入IoT物联网平台,通过云产品流转到函数计算FC,调用钉钉群机器人API,实时推送温湿度消息到钉钉群。
阿里云AIoT物联网开发实战
本课程将由物联网专家带你熟悉阿里云AIoT物联网领域全套云产品,7天轻松搭建基于Arduino的端到端物联网场景应用。 开始学习前,请先开通下方两个云产品,让学习更流畅: IoT物联网平台:https://iot.console.aliyun.com/ LinkWAN物联网络管理平台:https://linkwan.console.aliyun.com/service-open
相关文章
|
2月前
|
C# 容器
39.c#:groupbox容器
39.c#:groupbox容器
51 1
|
2月前
|
运维 Kubernetes Serverless
阿里云容器服务
小陈在大刘的指导下学习Kubernetes,发现搭建和维护Kubernetes集群有一定难度。大刘建议小陈考虑使用阿里云的容器服务ACK,它基于Kubernetes,但进行了云原生优化,简化了集群管理和运维工作。ACK有三种形态:专有版、托管版和Serverless版。小陈认为ACK Serverless更适合,因为它无需运维,开箱即用,适合专注于业务开发。ACK Serverless基于弹性容器实例ECI,提供无服务器的容器运行环境,支持Kubernetes兼容,降低了使用门槛。
|
2月前
|
存储 安全 测试技术
|
11月前
|
Java 容器
JMenuBar容器
JMenuBar容器
53 0
|
12月前
|
存储 算法 Java
什么是容器
什么是容器
122 0
|
Kubernetes 监控 Cloud Native
k8s容器
容器
279 0
|
Kubernetes 安全 Java
当我们谈容器的时候,我们在谈什么
Docker 在当下很火,那么,当我们谈 Docker ,谈容器的时候,我们在谈什么?或者说,你对 Docker ,对容器了解吗?容器,到底是怎么一回事儿?
当我们谈容器的时候,我们在谈什么
|
Ubuntu 安全 网络协议
|
存储 容器
|
Docker 容器