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带给我们的好处。

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

目录
打赏
0
1
2
0
55
分享
相关文章
云原生时代的容器化实践:Docker和Kubernetes入门
【10月更文挑战第37天】在数字化转型的浪潮中,云原生技术成为企业提升敏捷性和效率的关键。本篇文章将引导读者了解如何利用Docker进行容器化打包及部署,以及Kubernetes集群管理的基础操作,帮助初学者快速入门云原生的世界。通过实际案例分析,我们将深入探讨这些技术在现代IT架构中的应用与影响。
170 2
docker入门-快速学会docker
本文介绍了Docker的基本概念,包括镜像、容器、tar文件、Dockerfile和仓库,并通过实际操作演示了如何使用Docker。从拉取Nginx镜像、运行容器、修改容器内容、保存容器为新镜像,到使用Dockerfile构建自定义镜像,最后讲解了如何保存和恢复镜像。文中还推荐了一个在线实践平台Play with Docker,方便读者快速上手Docker。
256 5
docker入门-快速学会docker
实战~如何组织一个多容器项目docker-compose
本文介绍了如何使用Docker搭建Nginx、PHP和MySQL的环境。首先启动Nginx容器并查看IP地址,接着启动Alpine容器并安装curl测试连通性。通过`--link`方式或`docker-compose`配置文件实现服务间的通信。最后展示了Nginx配置文件和PHP代码示例,验证了各服务的正常运行。
84 3
实战~如何组织一个多容器项目docker-compose
【Docker容器化技术】docker安装与部署、常用命令、容器数据卷、应用部署实战、Dockerfile、服务编排docker-compose、私有仓库
本文主要讲解了Docker的安装与部署、常用命令、容器数据卷、应用部署实战、Dockerfile、服务编排docker-compose、私有仓库以及Docker容器虚拟化与传统虚拟机比较。
2431 12
【Docker容器化技术】docker安装与部署、常用命令、容器数据卷、应用部署实战、Dockerfile、服务编排docker-compose、私有仓库
Docker容器性能调优的关键技巧,涵盖CPU、内存、网络及磁盘I/O的优化策略,结合实战案例,旨在帮助读者有效提升Docker容器的性能与稳定性。
本文介绍了Docker容器性能调优的关键技巧,涵盖CPU、内存、网络及磁盘I/O的优化策略,结合实战案例,旨在帮助读者有效提升Docker容器的性能与稳定性。
237 7
国产数据实战之docker部署MyWebSQL数据库管理工具
【10月更文挑战第23天】国产数据实战之docker部署MyWebSQL数据库管理工具
281 4
国产数据实战之docker部署MyWebSQL数据库管理工具
云原生之旅:Docker容器化实战
本文将带你走进云原生的世界,深入理解Docker技术如何改变应用部署与运维。我们将通过实际案例,展示如何利用Docker简化开发流程,提升应用的可移植性和伸缩性。文章不仅介绍基础概念,还提供操作指南和最佳实践,帮助你快速上手Docker,开启云原生的第一步。
云原生技术入门:Kubernetes和Docker的协同工作
【10月更文挑战第43天】在云计算时代,云原生技术成为推动现代软件部署和运行的关键力量。本篇文章将带你了解云原生的基本概念,重点探讨Kubernetes和Docker如何协同工作以支持容器化应用的生命周期管理。通过实际代码示例,我们将展示如何在Kubernetes集群中部署和管理Docker容器,从而为初学者提供一条清晰的学习路径。