作者:孤独烟

来自:打杂的ZRJ

引言

早在2013年的时候,docker就已经发行,然而那会还是很少人了解docker。一直到2014年,Martin Fowler提出了微服务的概念,两个不相干的技术终于走在了一起,创造了今天的辉煌!

近几年来,很多互联网关系开始跟风,构建docker+微服务的架构体系。然而,根据笔者观察发现,有些童鞋在使用过程中,只是会用,而根本不了解为什么使用docker,反正对他们来说,公司让用就用!而某些公司呢,虽然用上了docker,然而运维方式并没有发生改变,白白浪费了docker的大好性能!

因此,才有了本文的诞生。本文不会教你怎么去用什么docker的api,毕竟官网document很全面,而是去讲解docker的优点,进而说明为什么适合微服务的架构!

正文

这里必须要先说明物理机、虚拟机、容器三者的优缺点。笔者不想去列一堆的概念,直接借用知乎的一个回答,回答地址为:
https://www.zhihu.com/question/48174633/answer/229253704
这里借用一下这位大神的三张图,他的回答就三张图!

基本概念

所谓的物理机就是下面这样的别墅

那么虚拟机机就是下面这样的套房

最后就是我们的容器,就是下面这样的胶囊公寓

那么,专业的说法就是,容器是一种轻量级、可移植、自包含的软件打包技术,使应用程序可以在几乎任何地方以相同的方式运行。容器之间是共享同一套操作系统资源的,由于容器是共享主操作系统的内核,因此就无法在服务器上运行与主服务器不同的操作系统,也就是说不能再Linux的服务器上运行Windows。就如上面哪个图一样,每个胶囊容器是公用一个厕所,厨房,每个胶囊内无法再构建出自己的厕所和厨房!

容器的优势

隔离强

过去:曾记得12年那会,部门要上一个项目。那会,我是这么干的。直接去线上服务器,拷贝一个tomcat,然后改端口号,然后部署应用到webapps文件夹下,重启就好。而且我可以摸着良心说,现在还有很多传统企业是这么做的。

那么这么做的缺点?

很明显,应用之间相互影响。一个应用出现问题,CPU100%了,这个服务器上的其他应用一起凉凉。一个大型应用拆分为几十个微服务,分别交由不同的团队开发,不同团队之间水平参差不齐。如果还采用这种部署方式,你的应用和某个坑爹团队的应用部署在了同一台服务器上,至于结果,我相信你懂的。

现在:用上了docker容器后,将Docker可以将我们的应用程序打包封装到一个容器中,该容器包含了应用程序的代码、运行环境、依赖库、配置文件等必需的资源。容器之间达到进程级别的隔离,在容器中的操作,不会影响道宿主机和其他容器,这样就不会出现应用之间相互影响的情形!

可移植性

过去:曾几何时我们和测试MM之间聊天内容是这样的

开发:"你去测试环境上,按照开发环境一样,再去搭三套一样的测试环境!"    

测试:"我….."    

几个小时过去了…    

测试:"你帮我看看,为什么启动报错,是不是漏配了什么参数?"    

开发:"我…."

于是接下来几个小时就这么愉快的和测试mm一起聊天中过去了!!嗯,我相信有些公司是为了解决开发的单身问题,才不使用docker,用心良苦!

然而,和运维GG之间聊天一般是这样的

运维:"开发这群脑残,发布的新war包,又把生产搞挂了!"   

开发:"这帮运维傻叉么,我本地好好的,怎么一上生产就不行了!"   

于是接下来的几个小时,就在和运维之间的撕逼中过去了!嗯,最终苦的是用户啊!

现在:自从用上docker容器后,可以实现开发、测试和生产环境的统一化和标准化。镜像作为标准的交付件,可在开发、测试和生产环境上以容器来运行,最终实现三套环境上的应用以及运行所依赖内容的完全一致。
在现在微服务的架构中,一个应用拆成几十个微服务,每个微服务都对应有开发、测试、生产三套环境需要搭建。自己算算,如果采用传统的部署方式,有多少环境需要部署。曾听闻某公司在新建一个项目的时候,要花整整一个礼拜来搭建环境,简直是惨不忍睹!

什么,你和我说,你们用上了docker,却还存在这些问题?
笔者曾见过某些公司是这么用docker的。确实虚拟化出容器了,然后在容器上建立ssh server。接下来就厉害了,部署方式完全没变,直接连上容器,一切部署照旧!对此,我也是一言难尽啊!你们这是给领导搭的docker么?

轻量和高效

过去:在2016年的时候,那会在另一家大厂工作。这家稍微规范一点了,一个应用部署在一个虚拟机上!当时最大的体会就是一个,虚拟机非常重,构建速度慢,且占用资源多,一台物理机上只能起十来个虚拟机!

现在:
和虚拟机相比,容器仅需要封装应用和应用需要的依赖文件,实现轻量的应用运行环境,且拥有比虚拟机更高的硬件资源利用率。在微服务架构中,有些服务负载压力大,需要以集群部署,可能要部署几十台机器上,对于某些中小型公司来说,使用虚拟机,代价太大。如果用容器,同样的物理机则能支持上千个容器,对中小型公司来说,省钱!

笔者注:笔者一直觉得这个特性只是一个障眼法。
比如,你说容器启动速度快?难道你工作中吃饱了撑着没事干,一直重启虚拟机么?

你说虚拟机消耗资源多?绝大部分公司的服务器资源利用率应该都不到 50%,大量的CPU、内存、本地磁盘都是常年浪费的,所以 VM 的额外开销不过是浪费了原本就在浪费的资源罢了。所以笔者认为,对于传统应用来说,使用和不使用Docker可能并不能直接给企业带来好处,相反使用中遇到了问题肯定会给企业带来麻烦,对于传统企业来说,不要盲目跟风,VM虚拟机其实够用了!。

总结

在技术演进中,docker只是趋势,并不是结果。相信在未来,一定有更高大上的部署架构出现!

长按订阅同类文章

架构师小秘圈

陛下,赐我一个赞↓

微服务为什么一定要用docker ?相关推荐

  1. 微服务为什么一定要用docker

    引言 早在2013年的时候,docker就已经发行,然而那会还是很少人了解docker.一直到2014年,Martin Fowler提出了微服务的概念,两个不相干的技术终于走在了一起,创造了今天的辉煌 ...

  2. Java微服务之Spring Boot on Docker,java开发面试笔试题

    我总结出了很多互联网公司的面试题及答案,并整理成了文档,以及各种学习的进阶学习资料,免费分享给大家. 扫描二维码或搜索下图红色VX号,加VX好友,拉你进[程序员面试学习交流群]免费领取.也欢迎各位一起 ...

  3. python 微服务架构实战_名师讲坛——Java微服务架构实战(SpringBoot+SpringCloud+Docker+RabbitMQ)...

    内容简介 作者简介 前言 第一部分 SpringBoot篇 第1章 SpringBoot编程起步 1.1 传统开发中痛的领悟 1.2 SpringBoot简介 1.3 SpringBoot编程起步 1 ...

  4. 十分钟搭建微服务框架(SpringBoot +Dubbo+Docker+Jenkins源码)

    这套系统搭建完之后,那可就厉害了: 微服务架构 你的整个应用程序将会被拆分成一个个功能独立的子系统,独立运行,系统与系统之间通过RPC接口通信.这样这些系统之间的耦合度大大降低,你的系统将非常容易扩展 ...

  5. Docker容器及Spring Boot微服务应用

    2019独角兽企业重金招聘Python工程师标准>>> Docker容器及Spring Boot微服务应用 1 什么是Docker 1.1 Docker的出现 问题一:项目实施环境复 ...

  6. 微服务项目部署在docker容器运行

    昨天的一篇微服务项目中涉及到docker部署,今天写一篇关于微服务项目部署在docker容器中运行,使用github上另外一个比较经典的微服务项目piggyMetric,项目的github地址:htt ...

  7. Docker——使用docker工具管理软件/组件的运行,镜像、容器、数据卷的基本概念,常用指令,使用docker搭建Java微服务运行环境

    Docker--使用docker工具管理软件/组件的运行,镜像.容器.数据卷的基本概念,常用指令,使用docker搭建Java微服务运行环境 一.docker的安装和卸载 1.卸载 2.安装 3. 导 ...

  8. 基于阿里云容器服务的微服务实践 - Part 1. 微服务与Docker

    基于阿里云容器服务的微服务实践 基于阿里云容器服务的微服务实践 - Part 1. 微服务与Docker 作者:chszs,未经博主允许不得转载.经许可的转载需注明作者和博客主页:http://blo ...

  9. 容器化技术与微服务结合---docker(一)

    目录 系列 微服务 docker场景 mac上docker安装 系统要求 安装 linux上docker安装 Docker的一些命令 springcloud结合docker部署 docker buil ...

最新文章

  1. IIS7.5 错误代码0x8007007e HTTP 错误 500.19
  2. java8 jni_Java中JNI的使用详解第八篇:重载的实现
  3. 山东大学计算机考博难度,山大博士发11篇SCI,坦言刚读研时自己也很迷茫
  4. Python hashlib 无法打印
  5. 2020-07-14 CVPR2020 i3DV论文讨论(4) 笔记
  6. ASP.NET MVC 环境配置,从1.0到2.0的转换和学习资源等
  7. Java 中 10 大坑爹功能!
  8. 马化腾怒怼张一鸣;中兴产品下架;微信整改小程序 | CSDN 极客头条
  9. LINUX 游戏服务器之旅4_mongodb环境
  10. MySQL建表(那些字段必须)命令详解
  11. 转载:ie6,ie7兼容性总结
  12. 本周Asp.net源码更新(6.25-6.29)
  13. Puppet常用资源使用详解
  14. Latex slide中添加算法流程图
  15. centos系统 -官网下载mysql
  16. publish nacos metadata failed
  17. mysql对韵母分组,复合元音韵母练习.ppt
  18. mysql统计去重记录数量_MySQL分组后,如何统计记录条数
  19. Python爬取酷狗音乐歌手信息
  20. 带分页存储管理系统中计算机应用自考,全国2012年4月高等教育自学考试计算机应用技术试题...

热门文章

  1. java 用程序代码解释继承_关于初级java程序员笔试题
  2. 不使用乘法、除法或mod,实现两数相除
  3. nginx代理响应报文体不全解决思路
  4. 捷讯技术分享SSH 无法远程登录问题的处理办法汇总
  5. 高招攻略 领英助你清晰解读大数据专业
  6. Timer 和TimerTask 的定时任务入门
  7. Java中静态关键字的使用方法介绍一
  8. 开源中国git关联xcode操作步骤
  9. 高级特性(4)- 数据库编程
  10. Eclipse编辑jsp、js文件时,经常出现卡死现象解决汇总