47

.NET开发者必须学习.NET Core

 4 years ago
source link: https://www.tuicool.com/articles/aAfuYvu
Go to the source link to view the article. You can view the picture content, updated content and better typesetting reading experience. If the link is broken, please click the button below to view the snapshot at that time.
neoserver,ios ssh client

很多的.NET开发者在接触.Net Core之前,对于linux系统一点也不了解,也未曾有过主动去学习的念头。在接触了.Net Core之后才会慢慢学习linux相关知识,很多同学想转Java,这个很扎心,你有很好的条件转向.NET Core为啥要转Java,据说目前市场上Java多如牛毛,两年以内的Java工作经验的都找不到工作了。

学习.Net Core最直接的好处就是培养你看英文文档和源码的习惯。你刚开始工作的时候遇到的一些问题百度一下基本上都能找到解决方案,实在找不到就去翻一翻Stack Overflow,在有道,bing翻译等一些工具的辅助下,看英文文档本身并不是一件很难的事情。包括看一些开源工具的源码也是一样,只要坚持一段时间,很多能力和习惯都是水到渠成的,最怕的就是我们会因为各种各样的原因而半途而废。

你在学习.Net Core的过程中,很自然地就会接触到一些以前所接触不到的东西,比如说linux系统,nginx反向代理和docker容器、kubernetes等等。 微软的开源与跨平台之举开阔你的视线,和开发社区的所有人一样拥有广阔的知识。现在.Net Core技术栈相关的招聘在增多,也说明了大家对于微软的开源还是保有比较积极的态度的。特别是赶上云原生应用开发这个历史进程的时候,我们要更加注重自我奋斗的重要性了。

下面这段话摘自: https://blog.csdn.net/achuan2015/article/details/86171497

在 2018 开源领袖峰会(OSLS)上,CNCF 基金会、Google Cloud 工程总监 Chen Goldberg 宣布,Kubernetes 成为第一个从 CNCF 毕业的项目。这也意味着该开源项目已经成熟并且足够灵活,可在任何行业、各种规模的公司中大规模地管理容器。Kubernetes是整个云原生计算的核心、灵魂和平台级技术,正因为Kubernetes技术、商业和生态的成熟,才导致了2019年开始全面进入云原生技术的商业化之年。

随着Kubernetes的商业化成熟,IaaS、PaaS和SaaS三层云计算技术体系将在未来几年形成全面的技术体系和供应商阵营,向上支撑起可以大规模、工业标准化运作的企业APP或SaaS开发、运营和管理能力,企业级APP时代即将全面繁荣。.NET Core是在云原生背景下诞生一个开发平台,.NET Core 3.0 在云原生时代所完成的蜕变:

  • 体积更小 :对于微服务分布式架构而言,更小的体积意味着更少的下载带宽,更快的分发下载速度,.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 3.0默认更好的支持Docker资源限制,官方团队也在努力让.NET Core成为真正的容器运行时,使其在低内存环境中具有容器感知功能并高效运行。 具体可以参看文章《 从CLR GC到CoreCLR GC看.NET Core对云原生的支持 》,随着内存成本的下降和虚拟化的流行,大内存配比已经成为趋势。所以我们一般是采用水平扩展的方式,同时部署多个应用副本,在一个计算节点中可能运行一个应用的多个副本来提升资源利用率。

最后推荐一个微软在Channel9 上云原生的系列视频推荐给大家: https://channel9.msdn.com/Shows/The-Cloud-Native-Show

ZFZfeaY.jpg!web

微软是对程序员最友好的公司了,产品文档做的非常好,特别是微软docs项目还是github上面非常受欢迎的项目, 微软的 docs网站 的内容非常全面, 涵盖所有的产品,也包括.NET ,asp.net ,xamarin等,学习起来这些资料是非常多的了,而不是缺乏资料,而且这些资料还都是免费的,你现在就动手访问下面的链接开始学习吧。


About Joyk


Aggregate valuable and interesting links.
Joyk means Joy of geeK