写点什么

你会如何优化应用程序的性能?

  • 2011-11-06
  • 本文字数:884 字

    阅读完需:约 3 分钟

StackExchange 是构建在 ASP.NET 和 SQL Server 基础之上的项目。最近, Sam Saffron Marc Gravell 分别撰写了博客,其中讲述了他们发现和解决性能问题的经验,在该过程中最终追踪到了.NET GC GEN-2 对象。大家可以从他们的博文中吸取很多关于优化生产环境中应用程序性能的经验。

问题是由自定义标签引擎引起的,它会在内存中存放大型对象列表。这两篇博文都值得一读,而 Sam 的文章则更详细地讲述了如何诊断问题。其中主要的应对方法包括:

  • 使用分析器。你可以使用类似于 MVC-MiniProfiler 的工具来分析方法调用,使用类似于.NET Memory Profiler 或者 Redgate ANTS Memory profiler 之类的内存分析器来跟踪内存使用情况。
  • 如果可以的话,要拥有可查询的日志——StackExchange 团队有后台执行的进程,它会解析原始的日志,并把它插入到大型的、专门的 SQL Server 实例中。如果无法查询日志,那么你就无法绘制出统计图并查看趋势或者模式。
  • 理解 GC 是如何工作的——.NET 中的垃圾回收器支持三代对象(GEN 0 到 GEN 2),而存放时间最长的数据会使用 GEN-2。GEN-2 的扫描频率最低,执行的成本最高,甚至可能会堵塞其它线程。Sam 建议阅读 Rico 的《Garbage Collector Basics and Performance Hints》一文以获得更多细节。

最后,团队采取了多项优化措施,包括针对应用程序的特定部分,从对象数组切换到索引数组,从类切换到结构体等。第一项措施是一种很常用的模式,这样数组就只针对主要的不可变列表的索引;而第二项并不常用,Sam 建议只在有超过 50 万个对象以上才使用它,这样在达到第二代垃圾回收器标准的时候就会很快释放内存。

StackExchange 团队对性能问题非常关注——比方说,你可以看到 StackOverflow 在三个不同的等级上使用caching ,从而提升反应时间,减少服务器的负载。

在InfoQ 上和MSDN 上都有很多关于性能和可伸缩性的资源可供参考,包括这篇 Rob Howard 撰写的文章。最后,引用 Sam 的话:“做很少的工作总是要比做更多工作消耗的资源少。”

你在扩展 ASP.NET 应用程序的时候,也有发现和解决瓶颈问题的类似经验和大家分享吗?

查看英文原文: How Do You Tune Your Application For Performance?

2011-11-06 02:503557
用户头像

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

关注

评论

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

PowerShell 中运行 maven 参数无法识别

HoneyMoose

如何进行秒杀场景下的异步下单实现

风铃架构日知录

Java 数据库 程序员 后端 IT

架构作业4-千万级学生管理系统的考试试卷存储方案

梁山伯

Tapdata Cloud 场景通关系列:数据入湖仓之 MySQL → Doris,极简架构,更实时、更简便

tapdata

ROS常用指令

Geek_7ubdnf

ROS

【Dubbo3终极特性】「云原生三中心架构」带你探索Dubbo3体系下的配置中心和元数据中心、注册中心的原理及开发实战(上)

码界西柚

云原生 注册中心 配置中心 Dubbo3 元数据中心

基于幂等表思想的幂等实践

小小怪下士

Java 程序员

GEAR框架: Tractian的敏捷工程文化

俞凡

敏捷 大厂实践

ETL 引擎 engine 适配 elasticsearch

weigeonlyyou

oracle Prometheus ETL Elastic Search InfluxDB Cluster

2022年终总结:今年学完的付费课程

石云升

学习 知识付费 年终总结 1月月更

2023-01-14:给定一个二维数组map,代表一个餐厅,其中只有0、1两种值 map[i][j] == 0 表示(i,j)位置是空座 map[i][j] == 1 表示(i,j)位置坐了人 根据防

福大大架构师每日一题

算法 rust Solidity 福大大

Date & Time组件(上)

芯动大师

Android Studio DATE类型 time

#46 A003-B端产品经理小A故事-你是在画猫吗?

非典型产品经理笔记

个人成长 产品经理 b端产品经理

架构训练营-模块三作业

Sam

架构实战营

拆分电商系统为微服务

闲人Eric

#架构实战营

架构训练营第10期模块四作业

Geek_4db2d5

#45 A002-B端产品经理小A故事-走进客户2

非典型产品经理笔记

个人成长 产品经理 b端产品经理

谈一谈有关 MySQL 数据库数据安全问题

风铃架构日知录

Java MySQL 程序员 后端 IT

醉爱江南,2023走进双山香山

科技大数据

天翼云第八代云主机助力企业攻克上云“大象流”加密处理业务难题

极客天地

兼容东西,贯通南北:超聚变的“四水归堂”

脑极体

科技 算力 超聚变

PyCharm创建Jupyter Notebook

IT蜗壳-Tango

Python

PyTorch指定GPU进行训练

Geek_7ubdnf

Python

SpringBoot配置文件application

Geek_7ubdnf

Java

Java中时间戳的使用

Geek_7ubdnf

Java

ROS教程(Xavier)

Geek_7ubdnf

ROS

剖析容器网络Flannel VXLAN模式工作原理

flannel #Kubernetes# #k8s

模块九-设计电商秒杀系统

李某人

架构训练营

读懂深度学习,走进“深度学习+”阶段

脑极体

深度学习 百度 #飞桨#

Design a limited-time offers e-commerce system

David

架构实战营

MASA Stack 1.0 发布会 倒计时一天

MASA技术团队

.net MASA

你会如何优化应用程序的性能?_.NET_Roopesh Shenoy_InfoQ精选文章