多快好省的做个app开发

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

【导读】前端时间,一篇“从产品经理的角度算一算,做个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

时间: 2024-10-20 14:11:45

多快好省的做个app开发的相关文章

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

[导读]前端时间,一篇“从产品经理的角度算一算,做个app需要多少钱”的文章在网上疯传,可见大家对互联网创业的热情!这次,从一名技术经理的角度再给大家分析一下,如何使用跨平台开发技术为你节省上百万的开发成本.所谓“跨平台”开发技术,就是使用一种语言和一种开发工具同时支持几种不同的手机/平板设备,这样做不仅仅省钱而且开发效率高,可以让你更快的推出新版本和新功能! 作为一名软件工程顾问,我曾参与过很多的项目,主要为软件团队进行开发工具和方法论方面的咨询/培训/指导,我接触过不下100个各种类型/大小

app开发外包注意事项,2017最新资讯

我们见过很多创业者,栽在这app外包上.很多创业者对于app外包这件事情不是特别重视,以为将事情交给app外包公司就完事了,实际上不是的.无论是从选择app外包公司还是签订合同.售后维护等各方面都有许多地方需要注意的.下面51开发app官网(外包潜规则揭秘网)将创业者在 app开发外包上容易犯的错误一一列举出来. ◆ 以为开发一个app软件和简单,自己需求不明确就开始让app外包公司开发了,若你找的app外包公司是不负责任的,那么你悲剧就开始了 ◆ 在需求没有明确之前急着要报价.这是一个常见的错

【Smobiler企业APP开发之一】开发环境部署

最近研究了下Smobiler-.net移动开发,对于做企业APP开发Smobiler还是够用的,况且是完全使用C#进行编程,对于使用C#进行程序设计的程序员来说还是很容易上手的. 本章节主要介绍Smobiler开发环境部署问题 由于Smobiler是.net移动开发,那么开发工具首选当然是Visual Studio了,Smobiler的最低要求是Visual Studio 2010及以上版本,.net framework 3.5以上,所以需要先确保电脑上已经安装了Visual Studio和.n

手机APP开发自己做,还是找专业的团队

随着移动互联网时代迅速发展,许多企业发展或者个人创业,纷纷将目光转向手机APP开发领域.在这种大的市场趋势下,APP开发迎来了新的发展高潮.而提到手机APP开发,始终在自己组建团队,还是交给专业的公司做这个问题上徘徊不开. 许多创业公司想要自己组件团队,却大多会面临这样一个问题:在初始启动阶段,资金有限,相关技术人员难找,并且如果需要开发的APP功能比较复杂,工作量增多,投入的技术开发人员也会增多,这样开发费用当然也就越高,开发工期会加长:即使做一个最简单的APP开发也至少需要2-3个月,更别提

App开发定制前需要做哪些规划?

很多企业在不断发展的过程中,都会有一个APP的梦.但是做一个APP可不是一件容易的事情,要想运营好APP更不是一个简单的事情,那么选择定制APP的企业应该如何制定合理的计划?作为移动应用开发专家,APICloud总结上万家企业定制开发经验,明确企业在开发一款APP之前应该做一个具体的规划,其内容包含以下几点: 1.转换思维,将传统的营销思维转换成互联网思维 互联网思维这个概念喊了好几年,真正能摸透它的人早已经成功了.APP就是典型的属于互联网市场下的产物.APICloud发现,随着智能手机的普及

盘点国内外在线app开发平台:分分钟做款app

随着智能手机的飞速发展,现在各类型的App数不胜数,几乎覆盖了工作.生活.学习的方方面面.在你使用别人开发的app时,有没有想过我自己能不能做一款牛叉牛叉的app?我估计很多朋友们有很好的idea,但是因为技术问题,美工问题总是望而却步. 于是今天王哥给你挖掘出以下4款国内外知名度较高的在线App应用开发平台,据说他们能让毫无编码技术知识,美工基础的小白能在极短的时间内做一款属于自己的app应用.究竟是否如传言所说?接下来,就让我们一起来一睹为快吧,当然,自己亲身体验一番更是再好不过的了. 1.

史上最简单的个人移动APP开发入门--jQuery Mobile版跨平台APP开发

书是人类进步的阶梯. ——高尔基 习大大要求新新人类要有中国梦,鼓励大学生们一毕业就创业.那最好的创业途径是什么呢?就是APP.<构建跨平台APP-jQuery Mobile移动应用实战>就是一本写给没钱没身份没资历的创业小白看的APP书,看完这本书你可以拥有自己的一个APP,不用花钱就能移植到其他移动平台,支持iOS,Android,Windows Phone!!!!!!!!找个最便宜的来练手吧!  小白APP交流Q群:  348632872 清华大学出版社推出的<构建跨平台APP:j

北京APP开发,你得这么玩

全网时代,大家都习惯了在便捷的网络中交流和解惑,快捷迅速的同时,网上繁杂的信息量也造成了我们的困扰:更集中.更专业.分类更明确的应用APP开始应运而生,受到欢迎.北京APP开发APICIoud,提供平台,深入简出,给你更专业,更好用的APP. APICIoud是北京专业APP开发平台,在开发APP方面使用标准Web技术开发iOS.Android原生App,各类功能一站聚合.一键接入,方便易懂,操作简洁,即使是新手也不用犯难.在APP管理运营当中APICIoud涵盖App推送.云修复.版本更新.大

北京APP开发培训

企业看到移动互联网发展的潜力,也开始把眼光朝向了APP开发.企业与用户对APP开发的需求和智能手机的不断在增加,使得APP开发培训不断增多,APP开发人才需求也在不断增加.大量的APP开发培训班也涌现出来. 截至2015年6月底,中国网民规模已经达到6.68亿,其中手机网民规模为5.9357亿,在整体网民中占比88.9%,用户规模还在不断增长.而移动用户的增长,就必然会带动APP开发的发展.面对如此大的市场,APP开发培训成为了众多择业者的**. 据统计,APP开发工程师薪金待遇在IT行业中属于