企业数字化转型驱动架构升级

本文讲的是微服务,我们如何与你相处,互联网经济深刻改变了我们身边的商业环境,消费者的生活方式日益数字化,人们可以在任何时间、任何地点利用线上、线下渠道体验无缝购物,运用社交媒体表达自我,企业也在运用多种技术手段,发挥数字化潜力,改善客户联系,促进企业业务模式的转型。Gartner认为,数字化就是把人、事、物和商业联系起来,建立新的商业模式。未来的企业都将是IT企业,IT将从后台走向前台,从ERP、CRM等内部流程优化为主的业务,逐步转向内外兼修的模式,从而实现商业创新。这一变化要求IT架构更加灵活的与上下游企业协作,更加快速的响应客户的个性化需求,更加弹性的应对无时不在的客户请求并提供良好的客户体验,同时云计算、大数据等技术的出现也为上述改变提供了新的技术选择,我们正面临B/S多层架构出现后新的一次架构升级,而微服务架构就在这个架构升级过程中应运而生。

分而治之的哲学是微服务的理论基础

把大的问题分解为容易解决的小问题,找到小问题的解决办法,再来解决大问题,就是分而治之的哲学。正如万事万物由分子、原子组成一样,软件也可以分解为基本单元,以这样的基本单元进行开发、测试、维护,是解决大规模系统建设的思路。分而治之首先要解决如何分的问题,企业软件的分法应该是以业务驱动的,而不是技术驱动的,也就是分解为独立的业务逻辑,而这样的不可再分的业务逻辑就是微服务。

凡事有一利必有一弊,细分为微服务后,势必带来部署、测试、信息集成难度的提高,分而治之除了“分”之外,还需要“治”。传统恐龙型ERP是一个面向组织的软件,完备、复杂、响应变化慢,适合业务稳定的情况,而数字化时代客户个性化的要求让我们从这种面向组织的软件,逐渐演变为面向个体的软件。例如从前的EHR软件是为人力资源部门服务的,整体开发、整体实施,而现在我们会从个体的角度规划软件,可以先从招聘专员开始做一个面试管理的流程,逐步推出新的流程,完善现有的流程。这些面向个体的流程就是微应用,企业应用将由无数个微应用组成。微服务则是一个技术概念,能更好解决微应用的技术实现问题,是一个事物的不同侧面,所谓“横看成岭侧成峰,远近高低各不同”,微服务和微应用是事物的一体两面。正因为微服务实际就是一个业务逻辑,因此做好微服务需要从微应用的维度考虑,将分解开的逻辑形成一个整体,要从多渠道接入、客户体验、数据管理、应用交付、运维全方位的视角考虑,这就是分而治之中实现“治”的体验,也是微服务架构需要解决的问题。

站在SOA的肩膀上践行微服务

微服务是一个新概念,但这绝不是一个全新架构,更不是一个包治百病的架构。由于有服务二字,很容易让人联想到面向服务架构(SOA),其实微服务架构属于应用技术架构,和以B/S 为代表的三层架构相对应,强调将巨石型应用拆分为由微服务组成的应用,在数据上也视情况从集中的存储拆解为更小的存储单元。而SOA属于企业架构的范畴,从企业架构出发把业务分解为不同领域的服务,不同物理系统提供不同服务,注重系统之间通过服务互联互通的规范,对服务如何实现并不关注。因此,面向服务架构的服务应该是一个业务意义的服务,而微服务是系统中的技术服务,更关注服务的实现,虽然提供了业务意义的服务,但是不能混为一谈。微服务使用也不是无限度的,事实上由于数据一致性等问题的限制,不能无限度拆分微服务,可以把微服务分为系统对外提供的远程服务、系统内部的远程服务和系统内部的本地服务,显式声明、明确职责。事实上,在企业架构上使用SOA支撑业务,而在应用技术架构上使用微服务架构,是一个合适的选择。

黄柳青博士是我和黄勇共同的导师,他在2004年所著《软件的涅槃》一书中指出:“互联网时代的企业应用定义,正发生革命性的变化… 横向的部门互动、实时的企业间互动、多样的交互渠道、灵活的业务规则,使得原有意义上的独立应用不复存在…… 对软件设计者来说,能直观地分割,并具有最小内部耦合的软件结构是简约之美……美的软件是软件企业与软件开发者的终极目标”,那时候他把这种全新的软件生产模式称为“面向构件”。回头看来,微服务正是“面向构件”在数字化时代的解读,用微服务架构实现软件之美,加速企业数字化转型。

作者部分往期文章

让我们遇见未来——新一代数字化企业云平台缘起
数字化时代下研发模式的变革
面向微服务的企业云计算架构转型

原文发布时间为: 2016-08-23
本文作者:焦烈焱
本文来自云栖社区合作伙伴EAWorld,了解相关信息可以关注EAWorld。

微服务,我们如何与你相处相关推荐

  1. 微服务并不能修复你破碎的组织文化

    我们常常关注技术中的设计模式,而忽略了我们社会结构中也存在类似的模式.通过审视我们与别人的沟通,可以找到许多技术性问题的解决方案.让我们来谈谈当你和讨厌的人类沟通时,你需要知道的五件事. 1. 技术并 ...

  2. 小公司比较吃亏的两道微服务面试题

    其实选择工作的时候,很多技术牛人都会选择一些小而美的公司,技术全面,能够以一个更全面的视角看整个公司的运作,人和人之间的相处也很简单.但是,有两道微服务的面试题,小公司的朋友们会比较吃亏. 题一:你们 ...

  3. 系统架构升级要不要上微服务?历“久”弥新微服务——你真的需要升级微服务架构吗

    在 <微服务架构设计模式> 一书中,作者总结了关于微服务的一些"重点",原文如下: 中国企业和开发者对微服务架构的热情让我印象深刻.但如同我给所有客户的忠告一样,我想对 ...

  4. 使用feign调用注解在eureka上的微服务,简单学会微服务

    使用feign调用注解在eureka上的微服务. 首先,确保所有服务(调用方与被调用方)都被注册在同一个eureka服务上. 1. 在调用方添加依赖(万事第一步,加依赖) <dependency ...

  5. Spring cloud 微服务docker容器化最佳实践

    Spring cloud 是当下最炙手可热的微服务套件,我们将介绍如何整合Docker容器达到高效快捷的构建发布 采用了dockerfile-maven-plugin插件发布镜像到远程docker主机 ...

  6. IDEA集成Docker插件实现一键自动打包部署微服务项目

    一. 前言 大家在自己玩微服务项目的时候,动辄十几个服务,每次修改逐一部署繁琐不说也会浪费越来越多时间,所以本篇整理通过一次性配置实现一键部署微服务,实现真正所谓的一劳永逸. 二. 配置服务器 1. ...

  7. etcd 笔记(09)— 基于 etcd 实现微服务的注册与发现

    1. 服务注册与发现基本概念 在单体应用向微服务架构演进的过程中,原本的巨石型应用会按照业务需求被拆分成多个微服务,每个服务提供特定的功能,也可能依赖于其他的微服务.此时,每个微服务实例都可以动态部署 ...

  8. 微服务架构必备的几点知识

    微服务架构 网关集群:数据的聚合.实现对接入客户端的身份认证.防报文重放与防数据篡改.功能调用的业务鉴权.响应数据的脱敏.流量与并发控制等 业务集群:一般情况下移动端访问和浏览器访问的网关需要隔离,防 ...

  9. 【微服务架构】SpringCloud之断路器(hystrix)

    说在前面 在微服务架构中,根据业务来拆分成一个个的服务,服务与服务之间可以相互调用(RPC),在Spring Cloud可以用RestTemplate+Ribbon和Feign来调用.为了保证其高可用 ...

最新文章

  1. HTML封装AJAX请求,在请求里面写登录的逻辑 ajax 网络请求 post
  2. wp7——sqlite数据库操作 from:http://blog.csdn.net/wp_lijin/article/details/7370790
  3. python中的装饰器有哪些-python中的装饰器详解
  4. SAP C4C的扩展字段添加到UI之后,还需要额外的步骤,才能将其添加到OData里
  5. spring的钩子_模板方法模式——看看 JDK 和 Spring 是如何优雅复用代码的
  6. “智享未来 知行合一”,开为科技助力企业开启人工智能新时代
  7. 删除ELK中的数据。。
  8. 英文操作系统下WebBrowser控件无法显示本地页面的解决方法
  9. .Net Discovery 系列之三--深入理解.Net垃圾收集机制(上)
  10. Win10问题篇:使用微PE装机。(完整版教程)
  11. 三国杀服务器维护中进不去,三国杀网页版打不开该怎么解决?
  12. 基于秃鹰搜索算法的无线传感器网络三维覆盖优化
  13. 抖音二面:计算机网络-应用层
  14. 技术探秘:华为云瑶光何以定方向
  15. python爬取豆瓣电视剧页面
  16. BFS 巡逻机器人
  17. pip install下载一些包很慢,可-i 从豆瓣源下载
  18. 蓝牙协议规范--L2CAP
  19. Ubuntu——为软件创建菜单(桌面)图标的方法
  20. ftserver容错服务器操作手册

热门文章

  1. java开发过程中几种常用算法
  2. 教你用Python抓取百度翻译
  3. greenDao 3.0基础
  4. Highcharts在IE8中不能一次性正常显示的一种解决办法
  5. linux压缩和解压缩命令大全
  6. [原] insert into … on duplicate key update / replace into 多行数据
  7. 7,7显示选中的目标信息
  8. 【使用C语言的7的步骤】
  9. 诗与远方:无题(五十五)- 曾经写给妹子的一首诗
  10. 校验用户登录手机端还是PC端,是否微信浏览器打开