高性能开发规范
- 减少请求数量
- 静态文件采用HTTP缓存,避免反复请求
- 合并请求:小图片,小JS,小CSS,多次AJAX,CSS内联图片
- 静态内容分离:
- 少量变化的页面,可采用静态页(缓存页)+ AJAX方式实现
- 合理使用缓存
- HTTP缓存:Response.Cache
- 页面缓存:OutputCache指令
- 数据&中间结果缓存:局部变量,静态变量,ASP.NET Cache,memcache
- 控制响应长度
- 分页&按需加载:限制数据库查询结果大小,树控件按层级加载
- 控制Cookie长度:Cookie会随每次请求发送,会占用上传时间。
- 合理利用304:如果请求结果没有变化,建议使用304响应
- 压缩结果:利用浏览器支持的解压缩功能将结果压缩返回。
- 利用索引避免表扫描
- 针对经常需要筛选的字段,创建必要的索引(参考数据库设计规范)
- WHERE过滤条件要符合SARG原则(参考数据库设计规范)
- 如果使用查询库,在表名后增加 with(nolock) 选项
- 从字典取值,必须使用 TryGetValue 方法。
- 字符串转数字,必须使用 TryParse 方法,例如:int.TryParse
- 多次操作数据库时,要共用连接,避免反复打开连接,尤其是在循环中操作数据库。
- 尽量给各种集合指定初始容量,避免运行时动态调整容量。
- 禁止使用 ViewState,Session
- 避免创建不必要的对象
- 多用局部变量缓存中间结果。例如下面这个错误的写法会让执行二次集合查找:
- 少用弱类型的设计,尽量使用泛型类型避免装箱拆箱。
- 用StringBuilder完成字符串的拼接操作(不要直接拼接)。
- 减少请求数据(合并请求,资源文件缓存)
- CSS的引入放在页头,JS的引用放在页尾。
- JavaScript,CSS尽量采用外部文件来保存,便于缓存请求。
- 避免一次加载大量数据,应该采用分页分层方式加载数据(树,网格)。
- 确保引用的资源文件都是存在的,避免产生404错误。
- 不要依赖于目录的默认文件名,应该在URL中写出全路径,避免无谓的重定向。
- 避免反复查找DOM元素,或者执行重复计算,应该多用变量保存计算结果(或者DOM对象)
- 避免使用CSS表达式
- 块元素以及图片应该尽量指定高度,减少页面重绘。
- 图片格式优先使用PNG扩展名,建议使用Photoshop优化图片大小。
- 在负载均衡环境中,静态变量之类的内存数据不能在多台机器之间共享。因此,只适合存放临时缓存或者能保证多台服务器一致的数据。
- 给数据表增加索引时,应该检查是否存在冗余索引。