【转】.NET 在云原生时代的蜕变,让我在云时代脱颖而出

原创:张善友

原文:https://www.cnblogs.com/shanyou/p/12198741.html

 

.NET 生态系统是一个不断变化的生态圈,我相信它正在朝着一个伟大的方向发展。有了开源和跨平台这两个关键优先事项,我们就可以放心了。云原生对应用运行时的不同需求,说明一个.NET Core 在云原生时代所完成的蜕变:

  • 体积更小:对于微服务分布式架构而言,更小的体积意味着更少的下载带宽,更快的分发下载速度,.NET Core 的镜像体积都很小,alpine的镜像更小,带上应用程序通常80M。

  • 启动速度更快:对于传统单体应用,启动速度与运行效率相比不是一个关键的指标。原因是,这些应用重启和发布频率相对较低。然而对于需要快速迭代、水平扩展的微服务应用而言,更快的的启动速度就意味着更高的交付效率,和更加快速的回滚。尤其当你需要发布一个有数百个副本的应用时,缓慢的启动速度就是时间杀手。对于Serverless 应用而言,端到端的冷启动速度则更为关键,即使底层容器技术可以实现百毫秒资源就绪,如果应用无法在 500ms 内完成启动,用户就会感知到访问延迟。这里我拿AWS Lambda来举例,因为各大云厂商都是以AWS是模仿的目标,AWS Lambda中可用的所有语言都是高级的,而不是像Assembler,C / C ++或Objective C那样。从脚本语言到JavaScript和Python,再到像Java和C#到Go这样被编译为二进制文件的托管运行时的语言,所有语言都是他们有自己的长处。在基准测试中,最重要的.NET Core是 冠军,具体参看https://react-etc.net/entry/aws-lambda-benchmarks-node-js-python-java-c-go-dotnet-core 

  • 占用资源更少:运行时更低的资源占用,意味着更高的部署密度和更低的计算成本。.NET Core的 CLR启动速度非常快,降低启动时资源消耗,可以减少资源争抢,更好保障其他应用 SLA。

  • 支持水平扩展:.NET Core 默认更好的支持Docker资源限制,官方团队也在努力让.NET Core成为真正的容器运行时,使其在低内存环境中具有容器感知功能并高效运行。随着内存成本的下降和虚拟化的流行,大内存配比已经成为趋势。所以我们一般是采用水平扩展的方式,同时部署多个应用副本,在一个计算节点中可能运行一个应用的多个副本来提升资源利用率。

猎聘网年中报告显示,腾讯、网易、顺丰、携程、同程艺龙等大公司的一些关键业务已经在使用 .Net Core 了,随之,越来越多的企业也开始要求应聘者有 .NET Core 方面的经验和技能,尤其是在高级人才的要求上,.NET Core 和基于 Kubernetes 架构的知识更是必不可少。 对于大部分开发者来说,.NET Core 入门比较容易,但是如何用它来解决工作中的各类问题,就需要积累大量的实战经验才行了,比如:

  • 如何能够确保我们的应用适应不同的部署环境?
  • 如何设计和实现业务代码,确保其不会随着系统的发展和演进带来的复杂度提升而丧失可维护性?
  • 服务化是如何在多团队协作的大型系统中保障交付效率的?
  • 如何使用 .NET Core 技术解决服务化带来的事务一致性问题?

要回答上述问题,你就需要熟悉 .NET Core 的深层原理,并且对实际生产环境中的应用有更进一步的学习和了解,这样你才能认清技术架构的实现与团队之间的关系,具备保障系统架构可持续演进的能力,并且能够支撑更大规模团队的高效协作。说到这里,要给你推荐肖伟宇和极客时间合作开设的《.NET Core 开发实战》视频课,肖伟宇将结合实战场景,帮助你深入理解并掌握 .NET Core 的设计原理和最佳实践。
使用优惠口令「dotnet123」到手仅¥89

 

                                                                                                                 

△扫码免费试看课程

 

肖伟宇是谁?
肖伟宇,目前是校宝在线的架构师。他工作12年来,一直在从事 .NET 方向的研发和架构工作,做过各类系统的架构和研发工作,服务部署从早期自建机房物理机、到自建虚拟化,再到现在的使用云服务,经验非常丰富。

肖伟宇在 .NET Core 发布早期,就持续关注并深入了解,之后积极推动校宝在线引入 .NET Core ,并且成功实现 .NET Core 开发并运行在 Kubernetes;期间基于 .NET Core 构建了支持多环境、多语言客户端、主动推送更新的版本化配置中心系统,提升团队的交付效率。

这里特别要和你分享一件事情是2018年的11月我有幸参观访问了肖伟宇所在的公司校宝在线,当时我也是刚从腾讯离职从事.NET Core的咨询服务工作,当时他们正是在进行.NET向.NET Core迁移的关键时期,他们同时处在阿里巴巴大本营的杭州(在最近我做的一个调查中很多杭州兄弟都提到了这一点),而且当时阿里巴巴已经投资了校宝在线,坊间一直流传着这么一个梗:被阿里巴巴投资的公司都转向了Java,可想而知,校宝在线作为杭州地区最大的一家.NET技术公司 的兄弟们面临多大的压力,在经过了一年多时间的探索,肖伟宇作为校宝在线的架构师带领.NET兄弟成功走向.NET Core云原生的道路,这是非常值得分享的一件事情,而且难能可贵的是肖伟宇把这个探索道路上的艰难险阻总结提炼成这样一门视频课程。这里我非常推荐大家购买肖伟宇结合自己的经验精心提炼的视频课程。
2019年在我们.NET社区还有一件大事就是“开源、共享、创新”, 中国最具前景开发者峰会落幕魔都, 大会上邀请了肖伟宇主题分享了《用ASP.NET Core构建可检测的高可用服务》

你能获得什么?

肖伟宇会带你从头开始构建一个基于 .NET Core 的云原生微服务架构。在这个过程中,他会先带你了解 .NET Core 的依赖注入框架、配置框架、日志框架和中间件等必要的知识,然后通过实例来讲解针对不同规模的团队和项目如何设计并实现微服务架构,最后一部分,肖伟宇会讲解如何在 Kubernetes 中部署和维护微服务应用。 学完这门课程后,你将有这些收获:

  1. 掌握.NET Core重要组件框架的最佳使用实践和设计原理。
  2. 掌握在 Kubernetes 下架构 .NET Core 微服务应用的设计方法和关键点实现方案。
  3. 掌握重要的工程设计原则在 .NET Core 技术栈中的实践。

专栏目录

                                                  微信图片_20200115204202

 

posted @ 2020-01-16 18:02  阳光下的行者  阅读(302)  评论(0编辑  收藏  举报