企业为何需要建立统一的复用型软件平台?

近年来,互联网在中国得到了爆发式发展,越来越多的行业受到互联网的影响,开始了自主信息化的道路。虽然得益于互联网的发展,很多企业的业务增长达到了前所未有的水平,规模也越来越大,但是也由此产生了各种各样的问题,如信息化建设跟不上企业业务发展的需求,新老系统衔接不畅等。
企业为何需要建立统一的复用型软件平台?
企业信息化面临的实际问题= ~ ) H q )
在企业快速的发展过程中~ 6 = A @ $ K Q,往往会出现这样一个链条。
新增一块业务 —y S : c T {> 招聘一位高级技术人员 —> 围绕这位同事组建一支技术团队 —> 该业务基本由这只团队负责。由此便形成了一个闭环,当需要跟其他业务进行交互时,经常由技术负责人之间商定,你可能遇到过同样一个业务接口,同时提供 了RPC,; # h * / 3 W VHTTP,MQ 等多种方式,只是为了给不同的Z H 9项目提供基础服务
如果随着业务的_ R 4的发展,团队形成了一个部门,团队决策h i { S j H者通常会从自身利益考量,希望尽量减少对外部门的依赖,无论k s 3是技术S = T - Q %选型,规范建立,组件选取,运行环境都希望能进行掌控。当这样的技术氛围一 n 0 Z z N * 5 $旦形成,单个员工对单个项目的影响就会变得非常巨大,一个产品经常会因为一两个核心员工的离职难以为继,最后不得不重新开发新的产品。
另外,从成本上来说,当每个团队都在试图构建自己完整的研发流程时,中间的技术研究,产品研发,运维管理就会出现非常多的资源浪费。而且,KPI 指标也会非常难以设立,因为当每个团队都采用不同技术栈,不同的技术组件,不同的维护方式和规范时,已经无法从产出效率来判断一个团队的绩效,就像你无法衡量一个川菜厨师和一个鲁菜厨师谁更优秀一样。
企业为何需要建立统一的复用型软件平台?
解决方案
公司发展初期,为了快速的进行业务拓展,大都不考虑成本投入,运营维护以及技术沉淀等问题。所有的指标导向都是业务的快速发展,尽可能的抢占市场份额,获取足够多的用户X Q 9 , * ~ z量。
公司发展到一定阶段后,市场逐渐趋于稳定,先期快速扩展的各种问题会逐步暴露出来。从技S u . k / c术层面来讲,如果可以形成公司级别( i 3 I 8 5 V w `的统一开发框架,会在实际的生产过程中带来非常大的收益。
统一u ( J 4 J s I开发框架的优势
1.避免重复性技术研究——节约人力成本
让项目组把精力更多C I I %的投入到业务中。相信这是大多数技术公司的共识,如果让项目组把精力投入在业务中?就需要A M y /在项目组之下构建一个基础的开发架构平台,把技术的共性问题提炼出来,交L 8 ; ? : w @给这样一个团队负责处理。避免每个项目都独自去解决遇到的各种各样的技术难题,有效的把精力释放出来。
2.标准化技术规范——I R _ v X , 6 W r提升产品项目质量
要千人一面,而不要千人千面。采用统一的开发框架(平台)后,在技术栈,技术组件,技术实现方案,甚至在代码g k l规范上就能形成标准化l 0 Z J |的技术输出模式,标准化带来的最大效- p J , P果不仅仅开发效率的快速提升,还有产品质量的大幅提升,这是显而易见的。
3.进行技术沉淀——提升公司整体技术能力,避免陷入一个人的能力决定一个q C g H B w 1项目
技术E ( G l W 9 ; w的进步来源于不断的技术积累和沉淀( = : r [。每个工程师都是站在@ { = [ b别人肩膀上完成工作的。以z F S r , m =项目为导_ 5 0 ] 4 E向的技术团队,一般都会以实现业务需求为最重J E p P y要的目标,技术只不过是完成业务的一种工具而已。基于此,业务开发团队就不可能把技[ ( f术积累作为一项重要的工作。当一位核心员工构建了一些基础的平台工具后,往往随着他的离开把之前的技术积累全部丢弃掉,而更严重的情况会导致整个项目的持续运行都成了问题。
当存在公司级别的统一开发框架(平台),项目团队基于该平台进) / ] ; + * t行自身项目的研发,不再需要关注于底层( i i l E [ 8 `技术实现,只需要? 5 v关注业务即可。当存在e C F . S 1 &核心同事离职时,平台的研发同事可以对新进入项目的同事进行相关培训,不会导致青黄不接的事情发生。而且,专注于平台的同事为了更好的满足项目组的技术需求,对平台进行不断的改进,从而达到技术积累和沉淀的目标。
4.可衡量的研发投入——对x n } H = B a }研发团队的有效管理和考核
当基于同一开发框架(平台)a 9 p V 4 ; / ! [的标准化技术规范建立起来后,对业务功能的代码实现就可以进行相对有效的评估和考量,可以避免因为技术实现差异而出现的种种问题。这对 KPI 的制定和考核是一个巨大的帮助。
企业为何需要建立统一的复用型软件平台?
统一开发p ? Y框架(平台)的定位和目标
统一开发框架(平台)定位于技术层面,其主要目的是K E b 4 Y 8 u ^为统一公司内相关产品研发和项目实施使用的技术架构和开发工具,有效提高统一技术支持力度,形成持续的技术# % j f 9积累手段,提升技# _ j I ? G v -术人员的利用率并降低对人员的依赖性,最终提升软4 $ 8 % 6件的规模化、流水线式的生产能力。
统一开发框架(平台)团队的运作方式
如何在公司推进统一开z + * 4发框架(平台)的建设,并不是一件简单的事情,从分工和运作方式上来讲,我主要着重把统一开发框架(平台)j } Q ~ t的工作分成三个部分。
开发示例、技术支持和技术规范。编写完整的开发示例m 1 ) j,对很多新接触统B P 7 i一开发框架的同事来说,有2 2 G H F w q I一份完成业务开发是非常重要,不仅仅可以指导你如何进行业务代码的编写,同时还能够指导你如何编写出正确、高效的代码。还需要对很多同事进行N J f技术培训与技术支持支持,都是统一开发框架(平台)团队应该完成的工作。
服务运维。统一开发框架(平台)提供了很多公司内部的服务,比如服务注册发现中心、配置中心、监控中心、链路中心、健康监测中心5 ~ p等。这些都需要统一开发框架(平台)团队进行运维。
新组件、新产品的T H j D , p研发。前一章节提( U z K . E ;到的 API 网关、分布式任务调度框架、服务注册中心 Plus 等。都是统一开发框架(平台)团队的工作范围。
虽然建设公司级的统一开发框架(平台)会在实际的生产过程中带来非常大的收益。但未必适用于所有情况,x w (大型公司,有的一定的技术积累,在时间和成本上考虑较少,可自主开发开发;中小型公司可以选择市场上成熟的软件平台,这样,在成本方面要g @ q P低得多。
Learun. W q Q i # C (Framework.net/java软件平台演示案例:learun.cn.
原文.Windy