写点什么

关于服务端性能、.NET 4.5 和 Bing

  • 2012-08-16
  • 本文字数:1481 字

    阅读完需:约 5 分钟

支持 Bing 和 Yahoo 的服务器占据美国网络搜索市场超过 33% 的份额,这是.NET 4.5 RC 应用程序最大型的持续正式使用。微软的 Bing 和.NET 团队紧密合作,做出了一系列改善,这对于运行大规模.NET 服务器的人们非常有用。

在一次 Channel 9 的采访中,“.NET GC 开发者 Maoni Stephens、性能架构师 Vance Morrison 和 Bing 的前端开发者 Mukul Sabharwal 参与进来,一起讨论实践中的.NET 4.5。” 最有趣的重点特性是多线程的 JIT 编译器。我们不会认为 JIT 对于服务器很重要,因为它可能会在很长时间保持在线。但是由于 ASP.NET 框架的原因,像 Ngen 之类的技术无法很好地工作。可能会有上百甚至上千个使用 Razor 或者 Web 表单编写的视图,而 NGen 无法查看。每次重启服务器或者进程被回收的时候,所有这些程序都需要重新编译。

有了.NET 4.5 和多线程的 JIT,我们发现 Bing 的启动时间减少了一半。这种成果大多数来自于保留了之前 JIT 编译过组件的列表。这个列表会用于在启动时在后台提前处理 JIT 代码。为了避免干扰实际运行代码的线程,即便有更多内核可用,JIT 线程能够使用的也被限制在二到三个。

.NET 4.5 中主要的重点就是对Windows 的事件跟踪(Event Tracing for Windows),或者叫做ETW。这种支持的一部分来自于新引入的 EventSource 类,它让.NET 应用程序可以创建自己的 ETW 事件。另一项改进在于堆栈跟踪领域。在之前的版本中,ETW 无法在 64 位服务器上对于没有预编译的代码(例如,.NET 或 JavaScript)提供精确地堆栈跟踪信息。有了.NET 4.5 和 Windows Server 2012,现在就可以提供堆栈跟踪信息,而不需要附加调试器。

不幸的是,随着异步编程的增多,引入了新的问题。在异步模型下面,处理请求的线程不一定是创建请求的线程。这会产生新的堆栈跟踪信息,难于和资源请求的发出者相匹配。除了在这个领域增加了更多工具之外,微软还开始使用 PrefView 对可视化工具创建原型,期望可以阐明这种问题。最终,微软会把该项支持移动到 Visual Studio 中。

采访的下一部分涉及到后台垃圾回收器(GC),那在.NET 4.5 服务器应用程序中会默认开启。他们谈到了关于固定内存(pinned memory)经常出现的问题。为了决定固定内存真正的消耗有多少,现在每次创建或者修改固定处理器(pinning handler)的时候都会触发 ETW 事件。

.NET 中的固定对象并不一定很昂贵。只有它们恰好位于垃圾回收器想要移动的内存块中的时候,才会导致问题。所以微软现在建议,经常需要固定的对象(例如,异步缓存)应该被重用。如果你那么做,只是在必要的时候才固定,最终它们就会生成两个带有其他长期存在对象的堆,并且不需要移动。

另外一种方法是,只分配非托管的缓存,把它交给操作系统,而不是固定托管的缓存。这里的取舍是,你需要付出每次把缓存复制到托管内存中的代价,这样就不需要付出针对固定内存运行垃圾回收器的代价。

长期以来微软想要提供某种框架支持,来创建可重用的缓冲池。

关于.NET 的垃圾回收器还提到了以下内容:

  • 在 32 位的操作系统下,.NET 堆大约是 2GB。而使用 64 位的操作系统,微软认为使用 10GB 的堆都不常见,甚至有些客户报告使用 50GB 的堆。但是,如果你想要使用大于 2GB 的单个数组,就需要启用 gcAllowVeryLargeObjects 设置。
  • 在.NET 服务器垃圾回收器中,有一种每个堆一个逻辑处理器的方式。小对象堆会在必要的时候重新平衡,但是在.NET 4.5 之前大对象堆不会这么处理。
  • 当使用具有多个 CPU 组的 NUMA 架构时,应该开启 GCCpuGroup 设定。
  • 在性能很重要的操作中,可以使用 SustainedLowLatency 模式临时关闭垃圾回收器

查看英文原文: On Server-Side Performance, .NET 4.5, and Bing

2012-08-16 22:112400
用户头像

发布了 340 篇内容, 共 133.1 次阅读, 收获喜欢 13 次。

关注

评论

发布
暂无评论
发现更多内容

InfoQ专访 | 联邦学习将会带来数据价值挖掘的下一个爆发点

Jessica@数牍

联邦学习

干货|语义网、Web3.0、Web3、元宇宙这些概念还傻傻分不清楚?(上)

Orillusion

开源 WebGL 元宇宙 Metaverse webgpu

HTTP的前世今生

技术小生

HTTP 7月月更

【C 语言】进阶指针 Five

謓泽

7月月更

一、What's API

忠厚

API API Explorer平台 api 网关

跟着官方文档学 Python 之:基础语法

甜甜的白桃

Python 数据类型 7月月更

带你认识数仓的“规格变更”

华为云开发者联盟

数据库 后端 集群 数仓

数据仓库与大数据挖掘技术调度平台- TASKCTL

敏捷调度TASKCTL

数据仓库 国产开源 TASKCTL 大数据仓库 DevOps工具

华为云GaussDB两大数据库通过中国信通院多项评测

华为云开发者联盟

数据库 后端 华为云

体验SRCNN和FSRCNN两种图像超分网络应用

华为云开发者联盟

人工智能 图像 图像超分

全面掌控!打造智慧城市建设的"领导驾驶舱"

华为云开发者联盟

云计算 后端 智慧城市 智慧屏

万字多图,搞懂 Nginx 高性能网络工作原理!

C++后台开发

nginx 中间件 后端开发 高性能网络 C++开发

卷是真的卷,“粗心马虎”也是真的要扣分

图灵教育

数学 小学 初中

React + Node.js 全栈实战教程 - 手把手教你搭建「文件上传」管理后台

蒋川

node.js react.js mongodb Express axios

IPA应用探索:基于客户意图交互让业务受理更有“温度”

鲸品堂

运营商

一个月后,我们又从 MySQL 双主切换成了主 - 从!

悟空聊架构

MySQL 悟空聊架构 征文活动 7月月更

企业知识管理过程中常见的误区与解决方法

Baklib

AIRIOT物联网平台助力油库自动化升级 实现业务场景全覆盖

AIRIOT

低代码 物联网 低代码,项目开发

Spring Security用户定义

急需上岸的小谢

7月月更

CloudBees CI使用Velero进行灾备(DR)概念验证

龙智—DevSecOps解决方案

ci 停机时间 灾难恢复计划

Klocwork部署的安全最佳实践

龙智—DevSecOps解决方案

klocwork 静态代码分析 SAST工具

影响分析:RubyGems未授权访问漏洞(CVE-2022-29176)

龙智—DevSecOps解决方案

rubygems 漏洞

LeaRun快速开发平台:企业供应链管理系统解决方案

力软低代码开发平台

P4Python:合并实践指南之如何脚本化integrate流程

龙智—DevSecOps解决方案

文件合并 P4 Perforce Helix Core

知乎基于 Apache Doris 的 DMP 平台架构建设实践|万字长文详解

SelectDB

Apache 数据库 数据仓库 广告系统 Doris

都有哪些较好用的项目管理软件?

爱吃小舅的鱼

项目管理 项目管理软件

关于FAQ页面的一些制作技巧

Baklib

基础设施 NFTScan 正式发布 Solana 网络 NFT 浏览器

NFT Research

区块链 NFT

Hive表类型

五分钟学大数据

hive 7月月更

从工程师到技术leader的思维升级

阿里技术

技术成长

DevOps工具链:开放、自由地选择最适合团队和业务需要的工具

龙智—DevSecOps解决方案

DevOps DevOps工具 DevOps工具链

关于服务端性能、.NET 4.5和Bing_架构_Jonathan Allen_InfoQ精选文章