Docker入门基础实战

简介: Docker入门基础实战

一:需要的环境如下:

centos7,服务器

二、什么是Docker

百科:一个开源的应用容器引擎,让开发者可以打包他们的应用以及依赖包到一个可移植的容器中,然后发布到任何流行的Linux机器上,也可以实现虚拟化,容器是完全使用沙箱机制,相互之间不会有任何接口依赖,就是商品服务和订单服务各个所需要的资源是互不侵占的,你分配给它多少就是多少。只不过给它快速的分配更多或者减少,所以有沙箱/黑盒的这种机制。

基于go语言编写,在LCX(linux容器)基础上进行的封装。

简单来说:

 1):就是可以快速部署启动应用

 2):实现虚拟化,完整资源隔离

 3):一次编写,四处运行(有一定的限制,比如Docker是基于Linux 64bit,无法在32bit的linux/windows/unix环境下使用)。

三:微服务下Docker容器化技术的介绍和使用场景

①:现在的微服务中有很多的集群部署,有很多的服务拆分。

比如:一个系统是一个单体的应用,例如一个电商系统,电商系统说大可大,说小可小,因为可以细分成很多的模块。而且每个模块是集群部署的。

所以会需要很多的应用服务器。

例如下面的图中一个电商系统假如有4个服务,而且每个服务都有两个节点去部署。

A:以前部署的方式比如买一个阿里云服务器,或者自建机房,一个服务器部署一个应用,对应的上面的图的话需要买很多的服务器。

B:但是后来出现了虚拟化的技术,虚拟机(在windows系统上安装一个虚拟机,然后在里面装很多的linux系统/windwos系统),然后每一个系统跑一个服务,这个也是docker的前身,它也是基于虚拟化技术的。

C:上面的缺点是一个机器部署一个应用,缺点太浪费了,然后出现了物理机,再进行隔离,里面可以划分n个小的系统,然后给每个服务进行使用,这个时候就可以使用docker,进行隔离然后共享出来,比如物理机给商品服务4个核,这时一台机器可以提供很多的服务进行部,这时就是共享物理机的资源。

有的时候比如某个服务搞个活动这时流量进行暴涨,但是其他的服务的流量是很平稳的,这时可以把平稳流量的服务需要的资源给抽取出来给流量暴涨的服务,这时就不用去买服务器,审批的整个流程。

D:所以可以把docker看成虚拟机,但是完全不等于虚拟机,因为是在虚拟机上面更进一步延申的。

②、又比如:在linux服务器上安装一个mysql的服务器,需要注意Mysql的服务器的版本和所依赖的jar等等的一系列的问题,这时会特别的麻烦,假如系统要快速的去进行部署的话,比如依赖mysql,redis等等,突然流量过来的话,你需要快速的扩容,就是多增加几个节点,这时不用docker的话,需要把一系列的依赖要加进去,这样才能够启动,启动成功之后要验证是否通畅等等,这一系列的流程特别麻烦。

但是用docker的话,当第一次使用的时候,把这个服务的整个的依赖打包成一个镜像,然而下次需要扩容的时候,只要把镜像启动起来,就可以马上进行使用了。包括程序所有的依赖,系统。能够快速的进行拷贝一个,然后会出现一个一模一样的系统了,特别快,而不是用一个一个的去写,去生成,这就是docker带给我们的好处。

总结:一句话,开箱即用,快速部署,可移植性强,环境隔离。

相关文章
|
9天前
|
Kubernetes Cloud Native Docker
云原生时代的容器化实践:Docker和Kubernetes入门
【10月更文挑战第37天】在数字化转型的浪潮中,云原生技术成为企业提升敏捷性和效率的关键。本篇文章将引导读者了解如何利用Docker进行容器化打包及部署,以及Kubernetes集群管理的基础操作,帮助初学者快速入门云原生的世界。通过实际案例分析,我们将深入探讨这些技术在现代IT架构中的应用与影响。
37 2
|
1月前
|
Kubernetes Cloud Native 云计算
云原生入门:从Docker到Kubernetes的旅程
【10月更文挑战第2天】本文将带你走进云原生的世界,从基础的Docker容器技术开始,逐步深入到Kubernetes集群管理。我们将通过实际代码示例,探索如何利用这些工具构建、部署和管理现代云应用。无论你是初学者还是有经验的开发者,这篇文章都将为你提供宝贵的知识和技能,让你在云原生领域迈出坚实的一步。
85 5
|
1月前
|
Linux 持续交付 Docker
掌握Docker:从入门到实践
Docker 是一个开源容器引擎,允许开发者将应用及其依赖打包成可移植的容器,在任意 Linux 机器上运行。本文从基本概念入手,详细介绍 Docker 的安装、基本操作、镜像构建及 Docker Compose 的使用,并通过实战案例展示如何部署 Web 应用、构建微服务架构及实现 CI/CD。通过学习,你将掌握 Docker 的核心功能,提升应用开发和部署效率。
|
21天前
|
SQL 关系型数据库 数据库
国产数据实战之docker部署MyWebSQL数据库管理工具
【10月更文挑战第23天】国产数据实战之docker部署MyWebSQL数据库管理工具
61 4
国产数据实战之docker部署MyWebSQL数据库管理工具
|
11天前
|
Cloud Native 持续交付 Docker
Docker容器化技术:从入门到实践
Docker容器化技术:从入门到实践
|
17天前
|
运维 持续交付 虚拟化
docker入门详解!!!
本文介绍了容器技术的发展历程,从物理机到虚拟化再到容器化,重点讲解了Docker的诞生及其优势。Docker通过轻量级的容器技术,实现了资源的高效利用、快速启动、环境一致性、持续交付和部署等优点。文章还详细解析了Docker的架构和工作原理,包括Docker Daemon、REST接口、Docker Client等组件,以及容器与虚拟机的差异。
54 2
|
24天前
|
Kubernetes Cloud Native 开发者
云原生技术入门:Kubernetes和Docker的协作之旅
【10月更文挑战第22天】在数字化转型的浪潮中,云原生技术成为推动企业创新的重要力量。本文旨在通过浅显易懂的语言,引领读者步入云原生的世界,着重介绍Kubernetes和Docker如何携手打造弹性、可扩展的云环境。我们将从基础概念入手,逐步深入到它们在实际场景中的应用,以及如何简化部署和管理过程。文章不仅为初学者提供入门指南,还为有一定基础的开发者提供实践参考,共同探索云原生技术的无限可能。
35 3
|
29天前
|
Ubuntu Shell 开发者
Docker入门:轻松开始容器化之旅
【10月更文挑战第17天】Docker 是一种开源的应用容器引擎,它让开发者能够“一次构建、到处运行”。Docker 通过容器化技术将应用程序及其依赖打包在一起,从而确保应用在任何环境中都能一致地运行。本文将为新手用户提供一个全面的Docker入门指南,包括基本概念、优势、安装配置以及如何创建和管理容器。
45 2
|
1月前
|
存储 运维 云计算
探索Docker容器化:从入门到实践
在这个快速发展的云计算时代,Docker容器化技术正在改变应用的开发、部署和管理方式。本文旨在为初学者提供一个关于Docker的全面入门指南,并通过实践案例展示Docker在实际开发中的应用。我们将一起了解Docker的核心概念、基本操作、网络和存储,以及如何构建和部署一个简单的Web应用。无论你是开发者还是运维人员,本文都会帮助你快速掌握Docker的核心技能。
|
1月前
|
Kubernetes Cloud Native Docker
云原生入门:Kubernetes和Docker的协同之旅
【10月更文挑战第4天】在这篇文章中,我们将通过一次虚拟的旅行来探索云原生技术的核心——Kubernetes和Docker。就像乘坐一艘由Docker驱动的小船启航,随着波浪(代码示例)起伏,最终抵达由Kubernetes指挥的宏伟舰队。这不仅是一段技术上的旅程,也是理解现代云架构如何支撑数字世界的冒险。让我们扬帆起航,一探究竟!