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

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

相关文章
|
23天前
|
Docker 容器
Docker自建仓库之Harbor高可用部署实战篇
关于如何部署Harbor高可用性的实战教程,涵盖了从单机部署到镜像仓库同步的详细步骤。
64 15
Docker自建仓库之Harbor高可用部署实战篇
|
5天前
|
运维 Cloud Native Docker
云原生技术入门:Docker容器化实战
【9月更文挑战第20天】本文将引导你走进云原生技术的世界,通过Docker容器化技术的实战演练,深入理解其背后的原理和应用。我们将一起探索如何在云平台上利用Docker简化部署、扩展和管理应用程序的过程,并揭示这一技术如何改变现代软件的开发和运维模式。
|
23天前
|
算法 Linux 调度
Docker的资源限制实战篇
本文详细介绍了如何利用Docker对容器的资源进行限制,包括内存和CPU的使用。文章首先概述了资源限制的重要性及其在Linux系统中的实现原理,并强调了不当设置可能导致的风险。接着,通过一系列实战案例展示了如何具体设置容器的内存限制,包括硬性限制、动态调整以及软限制等。最后,文章还提供了限制容器CPU访问的具体方法和示例,如指定容器使用的CPU核心数和基于`--cpu-shares`参数对CPU资源进行分配。通过这些实践,读者可以更好地理解和掌握Docker资源管理技巧。
64 14
Docker的资源限制实战篇
|
23天前
|
存储 数据管理 应用服务中间件
Docker的数据管理实战篇
关于Docker数据管理实战的教程,涵盖了Docker数据卷的使用、特点、场景以及数据卷容器的概念和应用。
48 13
Docker的数据管理实战篇
|
10天前
|
Kubernetes Cloud Native 开发者
云原生入门:从Docker到Kubernetes的旅程
【9月更文挑战第16天】 本文将带你进入云原生的世界,从理解Docker容器的基础开始,逐步深入到Kubernetes集群管理。我们将通过简单的代码示例和实际操作,探索这两个关键技术如何协同工作,以实现更高效、灵活的应用程序部署和管理。无论你是云原生新手还是希望深化理解,这篇文章都将为你提供清晰的指导和实用的知识。
44 11
|
24天前
|
Ubuntu Linux Docker
Ubuntu 18.04 安装Docker实战案例
关于如何在Ubuntu 18.04系统上安装Docker的实战案例,包括安装步骤、配置镜像加速以及下载和运行Docker镜像的过程。
127 3
Ubuntu 18.04 安装Docker实战案例
|
24天前
|
存储 Linux Docker
CentOS 7.6安装Docker实战案例及存储引擎和服务进程简介
关于如何在CentOS 7.6上安装Docker、介绍Docker存储引擎以及服务进程关系的实战案例。
83 3
CentOS 7.6安装Docker实战案例及存储引擎和服务进程简介
|
23天前
|
存储 测试技术 数据安全/隐私保护
Docker自建仓库之Harbor部署实战
关于如何部署和使用Harbor作为Docker企业级私有镜像仓库的详细教程。
49 12
|
23天前
|
运维 数据安全/隐私保护 Docker
Docker自建仓库之Docker Registry部署实战
关于如何使用Docker Registry镜像搭建本地私有Docker仓库的实战教程,包括了下载镜像、创建授权目录和用户名密码、启动Registry容器、验证端口和容器、测试登录仓库、上传和下载镜像的详细步骤。
86 5
|
26天前
|
图形学 C#
超实用!深度解析Unity引擎,手把手教你从零开始构建精美的2D平面冒险游戏,涵盖资源导入、角色控制与动画、碰撞检测等核心技巧,打造沉浸式游戏体验完全指南
【8月更文挑战第31天】本文是 Unity 2D 游戏开发的全面指南,手把手教你从零开始构建精美的平面冒险游戏。首先,通过 Unity Hub 创建 2D 项目并导入游戏资源。接着,编写 `PlayerController` 脚本来实现角色移动,并添加动画以增强视觉效果。最后,通过 Collider 2D 组件实现碰撞检测等游戏机制。每一步均展示 Unity 在 2D 游戏开发中的强大功能。
69 6