查看原文
其他

张大胖的docker之路

2017-04-26 老刘 码农翻身
1 悲催的开发环境配置


张大胖如愿跳到了这家新公司的研发部门,他摩拳擦掌,准备大显身手。


按照入职的惯例, 配置一个本地的开发环境必不可少。 兴冲冲的大胖看到组长发过来的配置文档,不仅倒吸了一口凉气 :竟然有几十页之多 !  


细细一看, 足足有48个步骤, 我的天呐!


组内的老人们对新人投来了怜悯的目光, 其中不乏夹杂着幸灾乐祸, 似乎想起了本人刚入职时配置环境那惨不忍睹的时光。


大胖做了一次深呼吸,定了定神,正式开始苦难的历程。 


从SVN上下载代码, 解决编译错误, 咦,怎么缺少这么多的jar 文件? 


好心老梁赶紧说: 我把jar文件发给你,  那个配置文档太老了, 有 两年都没人更新了。 


大胖心里一声叹息,但是他很细心,一边配置环境,还一边修改文档。  


他立志要搞一个最新版的出来: 从我开始, 后面的新人再也不用受折磨了。


可是谈何容易, 缺失的jar 文件还好办, 设置好Build Path以后把他们都commit到SVN上, 下次再有人下载,编译的依赖就自动解决了。


其他的就有点麻烦了,安装nginx , tomcat ,mysql, redis ....  哪个都不是省油的灯, 安装路径的选择、配置文件的修改,端口的设定, 最后还得把它们连起来。 


经过九九八十一难, 终于到了文档的最后一步: 运行。 


不过所料, 控制台一大堆错误信息触目惊心, 似乎在嘲笑每个新人的无能。 


大胖心中一万只神兽奔腾而过, 他感到了强烈的无助感。


老梁坐着那高档的程序员专用椅滑了过来: “怎么样? 滋味不好受吧, 要不要我帮你一下?”


张大胖还能说什么, 老将出马,一个顶俩。


可是这一次老司机也翻车了, 老梁折腾了很久, 满头大汉 , 总是有一个运行时错误解决不了。 


临近中午, 老梁说: 算了, 先去填饱肚子吧。 


大胖下午继续抖擞精神,把上午安装的系统删掉,重新再来一遍, 小样, 不信我搞不定你。 


3个小时过去了, 到了运行的时候,还是同样的错误。 


第二天再来一遍, 还是同样错误! 难道是人品问题?  本来想大显身手,展示自己深厚的编程功底, 没想到在这个小阴沟里一直出不来了。


第三天,大胖干脆把机器格式化了, 看成败,人生豪迈,  只不过是从头再来。  


这一回老梁也在旁边盯着, 结对配置, 每一条配置命令都被仔细检查了100遍,  到了中午时分, 大胖热泪盈眶的看到 : 系统终于可以跑起来了!


2  配置一次,到处运行


所有的坑都找到了, 所有的坑都被填上了。  


张大胖也陷入了沉思: 这个过程是在是太痛苦了, 怎么才能改进一下? 


这么多步骤,这么多配置, 要是事先都弄好了, 直接拿过来用该多好!


大胖灵机一动 :把这些配置好的Tomcat, Mysql, Redis...... 之流搞到一个虚拟机中不行吗? 新人来了, 直接下载一个配置好的虚拟机, 开箱即用,  再也不用理会这么多啰里啰嗦的细节了。


张大胖是个实干家,马上卷起袖子实验, 可是结果却不尽如人意。 一是虚拟机太大,二是慢的要死, 这都喝了3杯咖啡了还没启动完。 


一次偶然的机会, 张大胖听到同事们在聊Docker,  简单的看了下相关的资料,他马上联想到, 既然虚拟机这么笨重, 何不用轻量级的Docker来解决问题呢? 



和虚拟机一样, 把Tomcat, Mysql , Redis这些软件先配置好,形成一个项目特有的docker的镜像, 任何人只要得到这个镜像就可以用docker 引擎运行起来,形成一个容器,对外提供服务。  


张大胖迅速尝试了一下,果然是轻量级, 运行起来像闪电一般,起身倒茶的功夫就启动完成了。


老梁很赞赏大胖这种实干的精神,把外界流行的技术引入项目中来,  既学了新技术, 又提高了生产效率, 一举两得,双赢。


老梁自告奋勇做了第一个测试用户,也是异常的顺利,真是Build Once, Run Anyware啊,  于是docker 慢慢的在项目组中流行开来。 


3 稳定压倒一切


在项目的周例会上,张大胖又提出了一个新想法 : “既然我们开发都开始用docker了, 能不能把测试环境甚至生产环境也都改变成docker ? 这样以来部署应用程序就很方便了,  直接把镜像运行起来就可以了。”


开发组的人纷纷赞同,想想将来只需要把一个镜像放到生产环境就可以部署了,多么美好的前景啊。


但是负责运维的老王表示反对: “这没必要吧?  三年前我们已经把生产环境给搭好了,  一直以来都没什么变化,  你说的那些本地的配置问题,在生产环境上根本就不存在, 为什么要用docker 这个新技术?  搞坏了生产环境谁负责?”


看来老王是很抵触啊, 张大胖想,不过也难怪,生产环境,稳定压倒一切。  


想想也是,生产环境都配置好了,现在升级应用无非就是把web代码,数据库的sql 交由老王去执行,大部分情况下还是自动化的, 改动配置的机会寥寥无几,必要性确实不太大。


不过老王也是很开明的, 他接着说: “你们不是在搞一个新的项目吗, 可以拿它来尝试一下啊, 开发,测试,生产全部都用docker, 如果确实是可以平滑的过渡, 那以后我们就推而广之。 ”


老梁说:“ 没错, 新技术尝试,慢慢来吧。"


虽然没有争取到生产环境也使用docker,  但张大胖对docker是越来越喜欢了, 他还额外发现了docker 的另外一个好处,那就是可以轻松地尝试新的技术。


原来想折腾一个新玩意, 在遇到依赖的情况下,特别麻烦,一个包接一个包的下载, 如果遇到被墙,那更是痛不欲生。  现在只需要下载一个包含新技术/新工具的镜像,运行起来即可, 实在是太体贴了!


不仅如此,有一次客户要求演示正在开发中的新项目, 往日按照项目经理的要求,搞一个可用的演示系统那可是费了劲了,现在只需要把镜像copy给项目经理,直接就可以用了, 真是方便。


Build once , run anyware,  张大胖算是体会到了。


后记:本文主要讲了docker的一个应用场景: 简化环境的配置,docker 还有很多其他优点,例如docker和微服务就是一对好基友, 感兴趣的同学可以看一看。


此外,当你试图引入一个新技术到项目的时候, 一定要看看新技术能解决什么问题, 能给项目组带来什么价值, 这样更容易成功。

你看到的只是冰山一角, 更多精彩文章,请移步《码农翻身文章精华


有心得想和大家分享? 欢迎投稿 ! 我的联系方式:微信:liuxinlehan  QQ: 3340792577




优秀人才不缺工作机会,只缺适合自己的好机会。但是他们往往没有精力从海量机会中找到最适合的那个。


100offer 会对平台上的人才和企业进行严格筛选,让「最好的人才」和「最好的公司」相遇。


扫描下方二维码,注册 100offer,谈谈你对下一份工作的期待。一周内,收到 5-10 个满足你要求的好机会!


您可能也对以下帖子感兴趣

文章有问题?点此查看未经处理的缓存