Docker容器实战思维

Docker成功的基础

  • Docker的实现用到的基础技术(cgroups, namespace,分层文件系统)在Docker之前已经存在很多年,并且 Linux Containers(LXC)也在很多企业的环境中得到了大量的应用实践,并得到明显优势。Google大规模容器集群的性能比传统虚拟机也要高很多,接近bare Metal。与传统虚拟机相比,容器集群让公司拥有秒级别而非分钟级别的弹性计算伸缩能力,同事使用更少的机器运行更多实例。
  • Docker的优势:Docker首次创造了一种简单容易运行的并且覆盖应用全生命周期的工作流,用户可以通过简单指令或者Restful API来拉取,打包,运行,维护容器。这种简单化从根本上降低了应用程序不是的难度,极大提高了应用运行时环境的不是,维护的效率。用户可以不依赖类似Ansible, Chef,Puppet这类的配置管理和发布系统,不需要再部署中同事光之基础系统与软件的安装配置,以及应用的安装调试。
  • Docker提高统一实践方法,每个服务(或应用)维护一个Dockerfile文件,即使用编排工具如Docker Compose,一个服务(或应用)也只需要维护一个docker-compose.yml文件。应用程序及其运行时环境全部打包到一个简单易读的Dockerfile或者Compose文件,开发团队和运维团队可以透明的合作维护这个文件,极大降低了沟通成本与部署成本,极大满足了研发团队与DevOps(开发运维一体化)团队,运维团队之间的沟通需求,清晰划分了责任边界。

研发人员眼中的容器

  • 快速上手新的技术:新技术起点都是从Demo开始,学习新系统标准思路:最小系统原则,从变量最少的系统开始,循序渐进的学习
  • 通过Docker使用,用户可以将精力和注意力都尽可能放在语言本生学习上,而无需折腾系统环境的各种配置。Docker官网口号就包含了以上含义:Build,Ship and Run Any App,Anywhere,即任何应用都可以构建,发布,运行与任何环境,Docker将环境的影响因素降至最低,使开发者能统一的掌握整个应用的生命周期。
容器化的代码仓库
  • 我们可以将平时积累的特定功能化的Docker容器提交到自己的容器仓库中,这样在接新的系统时候,可以快速规划所需要的资源,并在最短时间内利用积累的模块搭建起系统,从而可以快速完成任务,另外研发过程中的各种发布版本,也可以用Docker容器的方式保存,以后遇到类似需求,可以直接运行,调试并且复用代码。
面向业务编程
  • 开发工作中,除了算法之类,在本质上是解决业务问题,满足需求方的要求。所有能快速掌握新的业务需求和新的技术栈,是对一个有效技术人员迫切的要求。
  • 使用Docker快速掌握新技术要点并完成适当的技术储备。假定读者是Python技术栈后端,实现网站后台的建设,那如何快速实现移动应用的Restful Api Server? 我们可以利用Docker Hub搜索适合作API服务的Python快速开发框架,更具自身业务需求修改Dockerfile,订制符合要求的镜像,然后快速启动一套能满足相关API的系统。

容器化开发模式

  • 传统模式:开发团队在开发环境完成软件开发测试,本地完成单元测试,测试通过,则可提交代码到git管理仓库。测试团队打包进行测试。运维吧应用部署到测试环境,安抚团队或者测试团队再次测试,没问题后运维或者部署人员发布到生产。
  • 上述过程涉及到三个环境:开发,测试,生产,以及三个团队:开发,测试,运维。多个环境和多个团队之间的交互。容易出现彼此环境的不一致情况造成的各种问题。
  • 容器模式下,应用是以容器形式存在,所有和该应用相关的依赖都会在容器中,因此移植方便,不存在像传统模式那种环境不一致的情况
  • 以下比较两种流程图,左边为传统开发流程,右边容器化开发流程
    在这里插入图片描述
操作流程
  • 容器化应用中,项目架构师或者PM和开发人员的作用贯穿整个开发,测试,生产三个环节。
  • 首先,架构师或PM根据项目预期创建好需要的基础base镜像,例如nginx,tomcat,mysql镜像,或者将Dockerfile风发给所有开发人员,所有开发人员根据Dockerfile创建的容器或者从内部仓库下载镜像进行开发,达到开发环境的充分一致。若开发过程中需要添加新软件,执行要在base镜像的Dockerfile添加修改即可。
  • 接着开发结束后,架构师调整Dockerfile或者Docker镜像,然后风发给测试部门,测试部门马上可以进行测试,消除部署困难等难题。
  • 例如,用java开发语言,使用Tomcat, Weblogic作为中间件服务器,后台数据库使用Oracle,Mysql等容器开发之前开发到测试的流程如下图,
    在这里插入图片描述
  • 容器化之后开发,测试,运维工作流程如下图:
    在这里插入图片描述
注意事项
  • 开发测试环境,推荐使用-v共享文件夹来存储开发人员的代码,避免频繁打包
  • 利用基础base镜像继承特性调整镜像的轻微变更。例如当使用程序对不同版本JDK支持,只需修改base镜像JDK设置,之后其他依赖的镜像重新创建过程中就可以自动完成更新

小结

  • 以上基于公司之前使用Docker Compose实战中的一些思考,持续交付注重的是效率。一直研发流程上最让人抓狂的是研发周期的管理。无论传统模式还是款速迭代,瀑布流,都需要有完善的代码周期支持。容器化正好契合了这一需求,为产品研发带来了生产力的提升。

上一篇:Docker之Dockerfile详解
下一篇:SpringCloud Alibaba 框架下公司架构图

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/310533.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

[剑指offer]面试题35:第一个只出现一次的字符

面试题35:第一个只出现一次的字符 题目:在字符串中找出第一个只出现一次的字符。如输入"abaccdeff",则输出’b’。 代码如下: char FirstNotRepeatingChar(char *pString) {if (pString nullptr) return \0;const int tableSize…

dotNET Core 3.X 请求处理管道和中间件的理解

理解 dotNET Core 中的管道模型,对我们学习 dotNET Core 有很大的好处,能让我们知其然,也知其所以然,这样在使用第三方组件或者自己写一些扩展时,可以避免入坑,或者说避免同样的问题多次入坑。本文分为以下…

数据结构与算法--实现Singleton模式

题目:设计一个类,我们只生成该类的一个实例。 只生成一个实例的类就是实现Singleton(单例)模式的类型。本题其实主要考察我们设计模式,因为面试的时候先来一个简单的,并且喜欢面设计模式相关的题目&#x…

[剑指offer]面试题37:两个链表的第一个公共结点

面试题37:两个链表的第一个公共结点 题目:输入两个链表,找出它们的第一个公共结点。链表结点定义如下: struct ListNode {int val;ListNode *next;ListNode(int x) : val(x), next(NULL) {} };思路: 两个链表长度分别为L1C、L2C&…

了解.NET中的垃圾回收

原文来自互联网,由长沙DotNET技术社区编译。尽管这是一篇来自2009年的古老的文章,但或许能够对你理解GC产生一些作用。 了解.NET中的垃圾回收一旦了解了.NET的垃圾收集器是如何工作的,那么可能会触及.NET应用程序的一些更为神秘的问题时&…

数据结构与算法--数组:二维数组中查找

数组 数组最简单的是数据结构,占据一整块连续的内存并按照顺序存储数据,创建数组时候,我们需要首先指定数组的容量大小,然后根据大小分配内存。即使我们只在数组中存储一个元素,亚需要为所有数据预先分配内存&#xf…

[剑指offer]面试题41:和为s的两个数字VS和为s的连续正数序列

面试题41:和为s的两个数字VS和为s的连续正数序列 题目一:输入一个递增排序的数组和一个数字s,在数组中查找两个数,使得它们的和正好是s。如果有多对数字的和等于s,输出任意一对即可。 代码如下: bool FindNumbersWit…

数字化演化历史

回顾历史,帮助我们展望未来,在数字化技术出现之前,人类历史几千年的历史中,人类社会中,人类的大脑是唯一可以作信息处理的。比如我们发明了汽车,需要人来开车;发明了飞机,需要人来驾…

数据结构与算法--字符串:字符串替换

数据结构与算法–字符串:字符串替换 字符串的优化 由于字符串在编程时候使用的评率非常高,为了优化,很多语言都对字符串做了特殊的规定。下面我们讨论java中字符串的特性java中的字符数组以’\0’ 结尾,我们可以利用这个特性来找…

[剑指offer]面试题42:翻转单词顺序 VS左旋转字符串

面试题42:翻转单词顺序 VS左旋转字符串 题目一:输入一个英文句子,翻转句子中单词的顺序,但单词内字符的顺序不变。为简单起见,标点符号和普通字母一样处理。例如输入字符串"I am a student.",则输…

数据结构与算法--经典10大排序算法(动图演示)【建议收藏】

十大经典排序算法总结(动图演示) 算法分类 十大常见排序算法可分为两大类: 比较排序算法:通过比较来决定元素的位置,由于时间复杂度不能突破O(nlogn),因此也称为非线性时间比较类排序非比较类型排序&…

如何查找,修复和避免C#.NET中内存泄漏的8个最佳实践

原文来自互联网,由长沙DotNET技术社区编译。本文来源:https://michaelscodingspot.com/find-fix-and-avoid-memory-leaks-in-c-net-8-best-practices/从事大型企业项目的任何人都知道内存泄漏就像是大型酒店中的老鼠。当它们很少时,您可能不会…

[剑指offer]面试题47:不用加减乘除做加法

面试题47&#xff1a;不用加减乘除做加法 题目&#xff1a;写一个函数&#xff0c;求两个整数之和&#xff0c;要求在函数体内不得使用、-、、四则运算符号。 代码如下: int add(int num1, int num2) {int sum, carry;do{sum (num1 ^ num2);carry (num1 & num2) <&l…

ASP.NET Core技术研究-探秘依赖注入框架

ASP.NET Core在底层内置了一个依赖注入框架&#xff0c;通过依赖注入的方式注册服务、提供服务。依赖注入不仅服务于ASP.NET Core自身&#xff0c;同时也是应用程序的服务提供者。毫不夸张的说&#xff0c;ASP.NET Core通过依赖注入实现了各种服务对象的注册和创建&#xff0c;…

Redis遍历方式思考--字典扩容方式

全量遍历keys 工作中线上Redis维护&#xff0c;有时候我们需要查询特定前缀的缓存key列表来手动处理数据。可能是修改值&#xff0c;删除key。那么怎么才能快速的从海量的key中查找到对应的前缀匹配项。Redis提供了一下简单的指令&#xff0c;例如keys用来满足特定正则下的key…

[剑指offer]面试题48:不能被继承的类

面试题48&#xff1a;不能被继承的类 题目&#xff1a;用C设计一个不能被继承的类。 ❖ 常规的解法&#xff1a;把构造函数设为私有函数 很多人都能够想到&#xff0c;在 C中子类的构造函数会自动调用父类的构造函数&#xff0c;子类的析构函数也会自动调用父类的析构函数。 …

从项目到产品: 软件时代需要价值流架构师 | IDCF

译者&#xff1a;无敌哥原文地址: https://thenewstack.io/the-age-of-software-needs-value-stream-architects/ 本文翻译仅供学习交流之用。原文作者 Mik Kersten 出版了《Project to Product》本系列共四篇文章&#xff0c;分别是01 从项目到产品&#xff1a;软件需要从物理…

Redis高效性探索--线程IO模型,通信协议

Redis线程IO模型 Redis是单线程&#xff0c;这个毋庸置疑Redis单线程能做到这么高的效率&#xff1f;不用怀疑&#xff0c;还有很多其他的服务都是单线程但是也有超高的效率&#xff0c;比如Node.js&#xff0c;Nginx也是单线程。Redis单线程高效原因&#xff1a; Redis所有数…

[剑指offer]面试题45:圆圈中最后剩下的数字

面试题45&#xff1a;圆圈中最后剩下的数字 题目&#xff1a;0,1,…,n-1这n个数字排成一个圆圈&#xff0c;从数字0开始每次从这个圆圈里删除第m个数字。求出这个圆圈里剩下的最后一个数字。 ❖ 经典的解法&#xff0c;用环形链表模拟圆圈 代码如下: #include <iostream&…

Redis持久化-深入理解AOF,RDB

持久化 Redis数据全部在内存中&#xff0c;如果宕机&#xff0c;数据必然丢失&#xff0c;因此必须有一种机制保证Redis数据不会因为故障丢失&#xff0c;这就是Redis的持久化机制持久化方式两种&#xff1a;AOF&#xff0c;RDB&#xff0c;如下图 RDB快照模式是一次全量备份&…