【导读】前端时间,一篇“从产品经理的角度算一算,做个app需要多少钱”的文章在网上疯传,可见大家对互联网创业的热情!这次,从一名技术经理的角度再给大家分析一下,如何使用跨平台开发技术为你节省上百万的开发成本。所谓“跨平台”开发技术,就是使用一种语言和一种开发工具同时支持几种不同的手机/平板设备,这样做不仅仅省钱而且开发效率高,可以让你更快的推出新版本和新功能!

作为一名软件工程顾问,我曾参与过很多的项目,主要为软件团队进行开发工具和方法论方面的咨询/培训/指导,我接触过不下100个各种类型/大小的开发团队,有传统行业,有互联网,有不差钱的,也有刚起步的创业者;其中也不乏app开发项目。开发团队遇到的问题最大共性是每个人在一个团队中的位置很大程度上决定他的判断,简而言之:视野问题!而当大家问一名IT人士那个经典的“做个app要多少钱?”的问题时,他也仅仅能根据自己的技术背景和经验给你一个答案,更加倾向于推荐那些相对稳妥的方案;而不懂技术的人更加无从判断。我想说的是:虽然互联网创业是个技术活,但技术选型一定要业务先行,ROI(投入产出比)优先。这就是为什么你首先应该从成本角度进行分析,做出判断;而不要受制于技术!

在回答完那个经典的“做个APP多少钱?”的问题后,下面这些问题就会接踵而来:

  • 应该开发iPhone版本还是Andrioid版本?
  • 可能需要聘用掌握了不同开发语言(iPhone使用Xcode/Object-C,而Android使用Android SDK和Java)和技能的团队成员,研发成本几乎翻倍
  • 产品的后台系统使用怎样的开发环境?
  • 如何在新功能上线时保证iPhone/Android的APP与后台系统的同步?
  • 从无到有开发这样一款APP到底需要多少成本?
  • 如何了解用户的使用习惯,并通过数据分析来指导后续版本的开发?

对于当前所流行的“互联网+”的众多创业者来说,如何能够以最快的速度和最小的成本来开发/运营自己的产品是决定是否能够在早期快速取得客户,获取生存空间和赢得未来机会的决定性因素。其实对于任何的软件开发来说,多快好省永远是我们的追求,当前的创业大潮使得这一原则更加凸显,也让更多的人了解到了软件开发。

DevOps(研发运维一体化)也是最近几年在软件行业非常流行的做法,DevOps通过打通开发和运维这两个原本属于不同领域的团队来为我们运营产品提供更快的价值输出,其实也是多快好省地体现。从用户的角度,使用手机/平板等移动设备的用户已经超过了PC用户,而在移动设备领域又存在着iPhone/Android/Windows三分天下的状况,这使得上面所提到的快速推出产品变得更加困难,同时由于不同的设备所使用的操作系统,开发环境和运行环境都完全不一致,让我们的研发管理变得更加的复杂,实现DevOps也是难上加难。

本篇博客将使用MyShuttle.biz这个应用来为你展示一个“互联网+”时代的创业团队如何使用跨平台开发技术来多快好省地解决以上问题。

在2014年的 Visual Studio and Azure Connect()在线发布会上,微软使用了一套名为 MyShuttle.biz的样例程序来展示Visual Studio 2015和Microsoft Azure所提供的DevOps能力,这套样例的源代码也被分享出来。其中使用了众多的技术来全面展示微软开发工具和云计算平台所提供的跨平台开发和DevOps能力。
全套样例代码可以通过以下地址下载:
https://code.msdn.microsoft.com/windowsapps/MyShuttle-demo-applications-1a4b68fe#content

跨平台移动开发白皮书 – MyShuttle.biz案例分析

这本白皮书将对当前2大主流跨平台开发技术进行详细的介绍,我将借助MyShuttle.biz这个案例,为你展示如何使用跨平台开发技术结合云计算完成一个典型“互联网+”产品的技术布局,团队组织,开发环境配置和开发流程管理,最终实现基于云的开发运维一体化(DevOps)环境。由于内容较多,我将按照以下顺序逐步发布;本系列的前一部分不会涉及过多的技术内容,适合创业者,技术管理者和普通大众阅读;后半部分会涉及较多深入的技术细节,适合对DevOps和跨平台移动开发技术本身感兴趣的朋友阅读。

  1. 案例背景:MyShuttle.biz的业务模型,应用架构
  2. 跨平台开发技术如何做到多快好省的?
  3. 跨平台开发技术的成熟度和不同方案优劣比较
  4. 跨平台开发环境配置和能力分析
    1. Apache Cordvoa HTML/JavaScript Hybrid APP 跨平台技术
    2. Xamarin 原生APP跨平台技术
    3. ASP.NET 5 跨平台开发技术
  5. 基于云端的DevOps环境配置和能力分析

案例背景

MyShuttle.biz是一套类似“滴滴出行”的互联网租车应用,可以为企业用户提供叫车,计费和后台管理能力,解决企业用户日常用车需求。虽然“滴滴出行”解决了普通民众的出行需求,但是企业用车市场仍然是空白。作为在公司中工作的人来说,有客户到访,公司团建,出游,甚至日常的跑业务,税务等活动都需要用车,而企业养车则是非常大的开销;MyShuttle.bizs就是在这样的大背景下诞生的,希望能够将租车公司的空闲车辆与企业用户相衔接,实现社会交通资源的优化和企业用车成本的降低。

大家可以通过以下视频来了解这个应用:

应用架构

MyShuttle.biz使用3套相互独立的系统来实现以上业务目标,后台系统通过云计算提供数据存储,业务逻辑处理和后台管理功能,并通过网页应用/Windows APP的形式提供给租车公司/用户企业的管理人员使用;用户APP通过各大应用市场给用户免费下载和使用,用户可以使用APP完成叫车,付费和订单管理功能;司机APP则提供给司机使用,完成叫车信息的推送,接受订单,跟踪里程等操作。

后台系统除了可以由用户通过浏览器完成各种操作外,还提供了流行的Restful接口供APP和其他第三方系统集成使用。

后台系统

  • 使用SQL Azure 提供安全的高可用数据存储服务
  • 使用ASP.NET 5 WebAPI和Azure Mobile Service 所提供的WebAPI提供数据访问服务
  • 为租车公司提供基于浏览器的SPA应用(单页面应用)来进行车辆,司机和订单管理服务
  • 为用车企业管理人员提供基于Windows APP的桌面应用来管理员工,车辆订单

用户APP

  • 使用Xamarin跨平台开发工具提供原生的App体验,同时支持iPhone/Android/Windows Phone三大移动平台

司机APP

  • 使用Apache Cordova跨平台开发工具提供基于HTML/Js的Hybrid App体验,同时支持iPhone/Android/Windows Phone三大移动平台

“跨平台”技术如何做到多快好省?

由于使用了跨平台开发技术,我们不必聘用同时具备Object-C/Java/C#能力的开发人员,只需要熟练使用C#语言和Visual Studio IDE的开发人员即可,我们的团队组成可以规划为:

– Team 1: 2名后台开发人员:
○ 熟练使用C#开发语言,ASP.NET MVC
○ 对Microsoft Azure云计算平台有所了解
○ 了解Restful接口开发
○ 负责后台系统中的数据库,WebAPI开发

– Team 2: 2名HTML/Javascript/Web/APP开发人员:
○ 熟练使用C#/HTML/JavaScript/CSS开发语言,前端框架如Jquery, AngularJS
○ 对Microsoft Azure云计算平台有所了解
○ 了解Restful接口开发
○ 负责Web SPA App及Apache Cordova Hybrid APP的开发(司机APP),同时支持iPhone/Android/Windows Phone移动平台

– Team 3: 2名原生APP开发人员
○ 熟练使用C#和Xamarin
○ 了解Restful接口开发
○ 负责原生APP开发(用户APP),同时支持iPhone/Android/Windows Phone移动平台

– Team 4: 1名设计人员
○ 熟悉移动APP和Web应用用户体验设计
○ 可以独立完成平面原型和元素切图,熟悉应用开发过程,具备与开发人员合作的经验

– 1名产品经理
○ 熟悉互联网产品和移动APP运营
○ 熟悉互联网产品开发,具备与研发团队合作经验
○ 可以独立完成用户故事的编写
○ 熟悉敏捷开发过程,熟练使用backlog来进行产品规划
○ 良好的沟通能力

– 1名技术经理
○ 熟练使用C#/ASP.NET MVC/HTML/JavaScript/CSS等开发语言
○ 熟悉主流前端开发框架和Restful接口
○ 熟悉Microsoft Azure云计算平台
○ 熟悉互联网开发,具备管理研发团队经验
○ 熟悉敏捷开发过程,数量使用backlog,sprint,burndown,kanban等工具来进行产品开发过程管理
○ 良好的沟通能力

当然,根据应用的复杂度和业务量的不同,我们也可以对以上团队结构进行简化或扩展;如果我们资源有限,可以按照以下思路简化团队

  • 将Team 1和Team 2合并,节省2名开发人员;因为大家都使用C#语言,MVC架构和REST接口的实现与前台开发关系紧密,这样做不仅仅可以节约成本,还可以提高开发效率,节约团队间的沟通成本;当前,前提是工作量和进度的要求可以满足。
  • 在Team 1/2合并的基础上,我们还可以考虑只使用一种跨平台技术(Apache Cordova或者Xamarin),这个案例中,为了能够展示不同跨平台技术的优劣而同时使用了2种技术;而在真实的项目中,我们完全可以只使用一种;这样,我们还可以考虑砍掉team 3,而由Team 1/2完成所有工作,这也是使用HTML/javascript作为统一的前端语言以及Apache Cordova提供的最大优势;让我们可以使用最少的团队实现最多的移动平台覆盖;当然,如果用户对于界面体验要求较高,使用Xamarin原生跨平台方案还是有其优势的。

随着业务的推进,我们也许需要扩展团队,使用跨平台开发技术前提下,无论简化或者扩展团队,我们的团队永远会和业务对齐,不会有多条业务线使用同一个技术团队的情况出现。在传统的开发模式下,如果你没有足够的资源给每个业务线(司机/租客等)配备独立的技术团队,而按照技术平台(iPhone/Android)来组建团队架构的话,就会出现不同的业务线需要同一个技术团队做不同的事情,这时候必然会造成资源冲突,造成内耗。而使用跨平台开发技术就很好的避免了这个问题,因为我们不必因为技术不同而割裂本应该跟随业务的团队结构。大型软件研发团队的管理中的首要原则就是团队应该和业务对齐,而不要受技术选型的影响;这样做的目的是为了我们可以根据业务线的需求,最小化外界因素对交付的影响,做到按照业务功能持续交付;而多条业务线使用同一个技术团队,不仅仅开发人员无所适从,也会大幅增加沟通成本,造成质量问题。

最后,对于团队建设和能力成长,采用跨平台技术的团队使用同样的语言,工具,开发环境;这使得团队成员的沟通变得容易,大家可以一起交流技术,互相帮助对方完成工作,这样更加有利于我们建立健康的团队氛围,培养大家互相协作的气氛。

按照以上团队能力,下表中我们看到研发成本的计算:

(以下开发人员工资的数据采集自CSDN的2013年开发者薪资调查,根据这份调查的数据我大致估算了各个类别程序员的薪资中上位水平,同时乘以1.4的系数以考虑社保等因素来计算总体月成本。调查原文:http://www.csdn.net/article/2014-03-26/2818997/1 )

需要特别提一句,这里的团队配置中我们对每个技术岗位的职位都配置了2个开发人员,同时不同技术岗位因为所使用的技术非常相似,都具备互换性。岗位的互换性对于我们避免员工生病/请假/离职所带来的影响非常重要!而且我这里的平均工资达到了18000元/月,比产品经理的那个计算方式更高!这意味着你可以聘用更高水平的开发人员。

按照以上我们也可以推算出前3年的开发成本:

如果按照以上计算,单单使用跨平台移动开发技术,就可以在第一年为你节省将超过60万元的研发成本,随着团队的扩大(因为APP团队占研发成本的大部分),节省的比例和金额会变得更加惊人!请大家注意,在“产品经理”的计算中,他所使用的“第一版”成本是按照6个月计算的,大致100万的研发成本,和我这里的“传统”计算方式基本一致,而实用“跨平台”技术的“第一版”成本比“产品经理”的计算方式低20万元!

在现实中,我遇到的朋友很多都问我怎样多快好省地开发一款app,我常常告诉他们应该用跨平台技术;但最后的结果他们还是会选择传统的各平台独立开发的方式,希望以上的分析能够帮助这些朋友可以对“跨平台”技术的成本优势有所了解。当然,你心里关于这些技术的其他疑问,比如他们和传统原生app有哪些不同,各种不同的跨平台技术间有哪些优劣,在后续的文章中我都会一一解答……

更多内容,请关注公众微信号 DevOps

从技术经理的角度算一算,如何可以多快好省的做个app的更多相关文章

  1. 10、技术经理要阅读的书籍 - IT软件人员书籍系列文章

    技术经理是项目组中的重要角色.他需要负责软件项目中的重要部分,如果项目组没有架构师的话,技术经理还需要担负起架构师的职责.同时,技术经理要对项目中的所有重要的技术问题进行处理. 但是,在项目组内部,软 ...

  2. [原创]上海好买基金招高级Java技术经理/运维主管/高级无线客户端开发等职位(内推)

    [原创]上海好买基金招高级Java技术经理/运维主管/高级无线客户端开发等职位(内推) 内部推荐职位 高级JAVA技术经理: 岗位职责: 负责项目管理(技术方向),按照产品开发流 ,带领研发团队,制定 ...

  3. IT软件管理人员的职业路线(从技术经理到总经理) - CEO之公司管理经验谈

    技术.业务和管理永远是工作的一个话题.笔者今天就根据自身的经验,通过这三个方面介绍下IT软件管理人员的职业路线.前面写过一个文(IT软件技术人员的职位路线(从程序员到技术总监) - 部门管理经验谈), ...

  4. 《java入门第一季》之Date类案例,算一算你的恋爱纪念日

    想算你和你对象谈了多久了,还在用笔算吗,是不是很头疼?写个程序算一算吧!会变得如此简单. import java.text.ParseException; import java.text.Simpl ...

  5. Atitit  技术经理职责与流程表总结

    Atitit  技术经理职责与流程表总结 1. (最重要) 理念 价值观建设  ***团队文化建设2 1.1. 加强跨项目组员沟通 ,防止重复劳动2 1.2. 活动聚餐2 2. (重要)方向建设 技术 ...

  6. 全栈技术经理——团队管理:每周问问你的团队这这些问题 V1.0

    全栈技术经理--团队管理:每周问问你的团队这这些问题 V1.0 1.本周取得了哪些进展? ​ 通过回答这个问题可以让员工庆祝甚至夸耀一些自己的成果,包括那些跟最高优先级不相干而被忽视的小事情.借此你也 ...

  7. 技术管理进阶——谁能成为Leader,大Leader该做什么

    原创不易,求分享.求一键三连 两个故事 谁能成为Leader 之前接手了一块产品业务线,于是与原Leader说了下分工,大概意思是: 我是过来学习的,也能给团队带来更多的资源,团队内的工作你继续管理, ...

  8. 转:从产品经理的角度算一算,做一个app需要花多少钱?

    http://mp.weixin.qq.com/s?__biz=MzA4NTM5MTgzNQ==&mid=400127477&idx=2&sn=6ab90b7028deed78 ...

  9. 数据挖掘概念与技术15--为快速高维OLAP预计算壳片段

    1. 论数据立方体预计算的多种策略的优弊 (1)计算完全立方体:需要耗费大量的存储空间和不切实际的计算时间. (2)计算冰山立方体:优于计算完全立方体,但在某种情况下,依然需要大量的存储空间和计算时间 ...

随机推荐

  1. 获取MS SQL TABLE列名列表

    在MS SQL Server中,想获取表的所有列名,可以使用下面SQL语句: SELECT [COLUMN_NAME] FROM [INFORMATION_SCHEMA].[Columns] WHER ...

  2. 编写CLR存储过程中使用SqlDataRecord

    温习一下这些天学习的CLR编程,存储过程,函数. 编写CLR的存储过程,运行起来的效率,果然比普通的SQL语句,存储过程或是函数均高. 以后专案需求,或是执行效率较高的SQL,得写成CLR程序,再部署 ...

  3. IIS上部署MVC网站,打开后ExtensionlessUrlHandler-Integrated-4.0解决方法IIS上部署MVC网站,打开后500错误

    IIS上部署MVC网站,打开后ExtensionlessUrlHandler-Integrated-4.0解决方法 IIS上部署MVC网站,打开后500错误:处理程序“ExtensionlessUrl ...

  4. 广义表 Head Tail

    head:取非空广义表的第一个元素 tail:取非空广义表除第一个元素外剩余元素构成的广义表 L=((x,y,z),a,(u,t,w)) head(L)为(x,y,z) head(head(L))为x ...

  5. MSSQL存储过程返回自定义标识

    比如我们要做一个登陆,要求严格的也许要进行很多的判断, 如果这时不用自定义返回变量,就会多写很多的代码判断,多次操作数据库... if  exists(select * from sysyobject ...

  6. java 小程序-- 汉诺塔

    1.code public static void main(String[] args) { ; moveDish(, 'A', 'B', 'C'); } public static void mo ...

  7. Java--Spring AOP 源码散点记录(最后整理成一篇博客)

    Spring AOP 源码记录: 1.AOP 入口ProxyFactoryBean.getObject()方法: 2.AOP实现: (1)实现InvocationHandler接口 (2)通过java ...

  8. Guava学习笔记:EventBus

    EventBus是Guava的事件处理机制,是设计模式中的观察者模式(生产/消费者编程模型)的优雅实现.对于事件监听和发布订阅模式,EventBus是一个非常优雅和简单解决方案,我们不用创建复杂的类和 ...

  9. 关于jQuery里面的选择器

    一.JQuery选择器的概述 选择器是JQuery的根基,在JQuery中,对事件处理.遍历DOM和Ajax操作都依赖于选择器. 二.选择器的优势 1.简洁的语法 2.支持CSS1.0到CSS3.0选 ...

  10. C# 7个读写Excel文件的类库

    转载自:http://www.cnblogs.com/wintersun/archive/2013/02/26/2933294.html 有时我们在项目需要操作Excel文件,读或写,导出数据等.   ...