微软副总裁红衣主教Scott Gu今天的一封邮件结束了这笔软件历史上最大收购案,微软给全球开发人员的开源代码仓库GitHub投入了75亿美金,确保这一平台的持续健康发展。
GitHub为啥愿意被收购?
“软件工程这个事情,从来就不是一笔好生意!”,如果现在谁还想去靠搭建一个代码托管服务赚钱,那最好还是别了。不知道还有人记得有一家叫做GitCafe的公司么?加上Coding.net和开源中国的码云,这算是国内复制GitHub模式的三个很成功的创业公司了,结果是GitCafe被Coding.net收购,Coding.net收到腾讯投资。当然,Coding.net 算是成功的案例,但是从这个套路你也可以看出,一家以代码托管作为主要服务内容的公司,它的生存状态如何?当然,GitHub作为全球最大的代码托管平台,国内这些复制者是无法望其项背的,每年1个多亿的订阅收入也是真金白银。但是作为一家商业运作的公司,就算社区再有情怀,也还是要解决大米白面的问题。
摆在GitHub面前的问题是,趁现在热度还在,我是卖掉还是上市?GitHub为什么不选择上市呢?那我们再拿一家类似的公司来做类比,澳大利亚的Atlassian在2015年完成了IPO,而且在上市当天就大涨28%,为啥GitHub不能走这条路呢?而且bitbucket做的还远不及GitHub呢?要回答这个问题,你首先要搞清楚软件工程这件事情,到底怎样才能成为一个生意。任何的软件公司都需要软件工程工具,这些工具以代码管理为基础,加上工作跟踪,项目管理,测试,构建和发布基本上才能构成一个完整的工具链。软件工程工具要发挥作用,只有成为工具链才可以。这里面的基础组件本身是很难独立对整个研发团队产生价值的,源代码管理(VC)系统又恰恰是一个技术难度极高,运营成本也很高的基础设施类服务,这种东西是典型的“求之不得,弃之不舍”的系统,用户一般很不愿意为这个东西本身付费,其实你看看全世界还有多少用老旧的svn在管理源代码的公司就知道我在说什么了。所以,如果一家公司想要靠软件工程工具生存,就必须要打造工具链,这件事情已经被多家公司证明,IBM的Rational产品线,HP的QC产品,微软的TFS/VSTS和Altassian的全家桶都是围绕这个思路来赚钱的。
再回过头来看看GitHub你应该能明白我在说什么了,虽然GitHub有超高的人气,但是盈利能力,特别是持续的盈利能力一直是他的短板。这些年GitHub也不是没有努力过,2017年发布的Marketplace就是最好体现,但是比较一下Altassian的插件市场和VSTS的Marketplace的发展就可以看出其实GitHub一点都不努力。Altassian从一开始就坚持打造工具链和开放体系,VSTS从2015年开始打造插件生态;而GitHub的各种集成和插件其实存在许久,而GitHub直到2017年才有官方的插件市场,这足以说明GitHub的管理层对自己的发展方向其实一直不够明确也不够认真,甚至显得很任性。
微软为什么要收购GitHub?
其实微软对GitHub窥视许久,这是尽人皆知的事情。微软的生意其实是一个生态的生意,而开发者社区一直都是微软赖以生存的根本之一。微软开发者工具Visual Studio产品线一直被列为微软内部的战略级产品,这一点在微软整个的发展史上从来没有被动摇过,无论这个产品本身是否赚钱,微软都愿意为它投入大量的资源。所以你要说这个世界上谁最懂得开发者,那必须是微软。就算鲍尔默这位最近经常被大家诟病的前CEO也是一位极其推崇开发者的CEO,我本人是亲身体会过他高喊着Developer Developer Developer跳上讲台的那种气势,以及他讲起开发者的重要性的那种激情的。2014年萨提亚接过CEO一职后也一样延续微软打造开发者社区的传统,只不过他换成了一种开放的方式,与这个世界的发展趋势吻合,也成功挽救了微软。
对于这样一家生存在开发者社区上的公司来说,收购GitHub是一件太自然不过的事情,无论是完善本身的开发者工具体系,还是在Azure云计算周围打造一个更加坚固的社区土壤,这都是一笔好生意,更何况要价50亿美金的Github比起之前那些收购来说便宜多了。至于Github是否自己能赚钱,就变得不那么重要了。这样以来Github可以继续任性情怀下去,微软可以让开发者们happy,同时加强自己的云生意的来源。
至于那些叫嚣着马上删号移库的开发者来说,我觉得你们要么太现实要么太风骨,太把自己当回事,太把开源当阳春白雪了。开源闭源都只是一种商业模式,最终的目的一定是商业公司的盈利,个人开源可以全凭一时任性,公司开源就一定有套路在背后;开源公开库本来就是建立在“互相利用”的社区精神之上的,你担心个啥呢?也许你是私有库,担心微软偷了你的算法去改进自己的AI,你觉得一家美国上市公司会冒这种法律风险吗?75亿都花了,给你个零头你卖不?所以呢,如果你正忙着迁移自己的github repo,那我劝你还是别干这行了,直接去寺里面领个名号比较适合你这种要风骨不要米饭的。你的格局也就如此了。
再来说说VSTS和GitHub的关系,很多人觉得这2个产品会是对立关系,其实那只能说明太不了解它们了。VSTS是无限量免费私有库,GitHub是无限量免费公有库,他们刚好互补,微软收购了Github只会进一步加强VSTS里面其他功能对开发者的吸引力,比如提供VSTS CI/CD 与Github更为直接的集成,让敏捷看板等工具更好的支持Github的Repo和Issue系统等等。总之,软件工程工具链更加丰富和完整,对社区对微软都是利大于弊。
最后说说中国开发者,国内的开发者社区这些年有一种很恶劣的风气,就是唯互联网是从,唯谷歌苹果是从,唯Java是从,只要谈到微软那就是封闭,版权。其实我们就仅仅比较微软和谷歌,微软从1995年就在中国设立了研发和技术支持中心,在国内运作开发者社区,给高校和学生免费提供大量资源,与政府合作提供大量资源支持各地的软件产业。谷歌又做了什么呢?除了很有风骨的拍屁股走人,这么多年你有见过谷歌为中国开发者特地做过什么吗?问问那些开发Android系统的开发者就知道了,问问那些做前端的需要使用Google Fonts的开发者你也就知道了。你可以把这些都归功于GFW,但是作为一家真正懂得开发者的公司,他是有能力也是可以做出改变的 … 微软为了解决国内开发者下载nuget包的问题可以在国内搭建服务器,为了让国内开发者更好的访问VSTS,可以迅速决定在香港部署新节点。这些才是一家重视开发者的公司应该做的事情。
把一个开发者热爱的社区交给一家懂得和尊重开发者的工程师运营的公司总好过交给一家由律师运营的公司,你说是这个道理吧?
来自微软技术大会2018的几则重磅消息
2018年10月26日,上海——在2018微软技术暨生态大会(Microsoft Tech Summit)上,微软宣布围绕 Visual Studio 和 Visual Studio Code 开发平台提供一系列新功能与服务,并对 Azure DevOps 研发云进行整合升级,通过 Visual Studio 开发平台与微软研发云的相互融合,为全球开发者打造更加高效、快捷、智能化、协作化的云开发体验。
支持 Java 和 Python 的 Visual Studio Live Share 协作服务
为了进一步提升团队开发者协同工作的效率,微软在 Visual Studio 及 Visual Studio Code 中增加了 Visual Studio Live Share 服务,让多名开发者在同一个项目中进行实时协作。用户在编写代码和调试程序时只需发送一个 URL 网址,就能邀请他人参与协作,而且无需重新设置开发环境或安装任何附加包,即可在统一的环境中进行同步编程协作。这项服务在 Windows、Mac、Linux 等不同平台之间协作。
IntelliCode 人工智能辅助编程
微软推出 Visual Studio IntelliCode 智能代码辅助开发服务,能够根据开发者个人喜好,定制自动完成代码、模板,识别重构中的遗漏、误用变量、非规范变量名,还能对代码进行自动化分析和审核。
是的,作为一名微软开发者,我们只会拖拽控件儿和用AI写代码儿!!
适用于物联网和智能边缘的自动机器学习能力(Auto ML)
面对智能云与智能边缘的世界,微软为开发者提供了能够更好驾驭人工智能与物联网的工具。微软在大会现场,首次演示了第一个芯片级云+端物联网安全连接管理方案,以及用来让云端智能运行于物联网设备的 Azure IoT Edge 服务如何将自动化机器学习(Auto ML)应用于物联网的场景 —— 通过在 Azure IoT Edge 运行时上部署 AI、数据转换、数据检查筛选等服务,并借助容器注册表、Edge 部署清单等服务,将其与云端 Azure IoT Hub、Azure Functions 服务、Cosmos DB 数据库及 Web App 服务相连,微软成功通过在边缘部署智能,实现了物联网设备的大规模、自动化管理。
Azure DevOps 研发云整合升级以及Visual Studio App Center 提供一站式跨平台移动应用开发体验
面对 iOS、安卓系统移动应用的开发,Visual Studio 推出了App Center,将原来需要借助 Xamarin 的 HockeyApp、Xamarin Insights 及 Azure 应用服务完成的六项功能整合成为一项服务,显著提升了开发者面向iOS和安卓设备开发、测试、发布移动应用的自动化程度。借助 App Center,开发者可以在云端开发 Objective-C、Swift、Java、Xamarin 和 React Native 应用。App Center 能够自动对数千种设备进行适配测试、快速将应用发送给测试者或者直接发布到应用商店,并帮助开发者监测和收集故障报告,所有这些程序都能以自动化的方式高效完成。
源自 GitHub 的经验,成为微软研发云 Azure DevOps 服务学习的最佳蓝本。微软将 Azure Boards 电子看板、Azure Pipelines 流水线、Azure Test Plans 测试管理、Azure Artifacts 包管理、Azure Lab Services 实验室服务、Azure Repos 代码托管服务等六项服务整合为全新的 Azure DevOps 研发云服务,为开发者团队提供了全面覆盖计划、创建、编程、测试、部署、发布、托管、共享等各个环节,适用于任何语言、平台,并且能够与 GitHub 或者其它云平台对接部署的全套开发运维服务。
所有托管在GitHub上的开源项目均可以免费获得Azure DevOps Pipeline所提供的10条并发跨平台流水线,同时使用Windows, macOS或者Linux完成代码的自动化编译构建,自动化测试和自动化部署。
对比测试显示,Azure DevOps 服务为企业开发运维的效率带来的根本性的变革:应用的部署频率提升46倍、对项目进行更改的开发周期减少了2555倍、更改失败率降低了7倍、平均恢复速度提升了2604倍——如此巨大的改变将大大加速应用市场化的速度,进而帮助企业实实在在地降低成本、增加收入。
.NET Core 3将提供全面跨平台开发
.NET Core 为开发者提供了跨平台、云原生应用的理想开发平台,特别是即将发布的 .NET Core 3,能够全面支持从网页到云端、桌面、物联网、人工智能的全方位的跨平台部署。在大会现场,微软演示了 Windows 桌面在 .NET Core 3.0上运行的情况,充分展现了将其用于未来开发环境的无限可能。
微软宣布, Azure SignalR 服务正式商用。Azure SignalR 是一项里程碑式的全新服务,提供了 SaaS 级别的实时消息服务,能够以全托管形式提供,让用户无需为自运维及扩容等细节担心,服务原生支持 ASP.NET Core 的部署,能够与其他 Azure 服务相互整合,而且可在 Azure 全球多个区域提供。
同时.net core的性能在全球标准化测试组织的测试中超越竞争对手,20,000请求/每秒的处理速度,20倍于node.js的性能(1000请求/秒)。
DevOps魔盒(devcloudX.com) 首秀完成
leansoftX.com 研发总监周文洋在这次技术大会上也为参会的小伙伴展示了DevOps魔盒这款产品。利用微软云所提供的Infra As Code能力,配合Azure DevOps Server所提供的自动化调度能力,DevOps魔盒可以为企业研发团队提供一键式环境创建和自助的管理能力;通过集成微信,为研发团队提供持续的实时反馈能力。
同时,leansoftX.com团队还现场送出了60套Azure DevOps Server环境。
DevOps+LIVE直播
基于Azure DevOps的容器化流水线搭建
本次技术大会我们还完成 Azure DevOps Server 的动手实验,但是因为实验时间有限,很多小伙伴都没有能够完成整个实验。因此,我们将邀请leansoftX.com研发总监周文洋为我们通过DevOps+LIVE直播为大家再做一次分享。
直播时间
2018年10月31日 晚8点30分
报名方式
请扫描以下二维码进入注册页面
原文地址: https://mp.weixin.qq.com/s/t7Y8m0auU-1B46RMT6VcGQ
.NET社区新闻,深度好文,欢迎访问公众号文章汇总 http://www.csharpkit.com