当前位置: 首页 > 面试题库 >

如何提高.Net动态页面响应速度?

吴建中
2023-03-14
本文向大家介绍如何提高.Net动态页面响应速度?相关面试题,主要包含被问及如何提高.Net动态页面响应速度?时的应答技巧和注意事项,需要的朋友参考一下

研究表明,页面响应速度超过5秒,90%的用户会选择关闭页面。影响页面响应速度因素很多,分别从前端,后端,数据库,运维阐述。

一、前端性能优化(引用网址 https://www.jianshu.com/p/60b715bd5d73)

思路:分析一个页面从输入 URL 到页面加载显示完成的所有步骤,采用分治法逐步优化。

1、优化DNS查询

减少域名:尽量把所有的资源放在一个域名下。一个域名同时可以发4(IE8)或8个请求(Chrome)。请求文件少,用1个域名,文件多用多个域名。与3权衡。

2、优化TCP协议

  • TCP连接复用,使用keep-alive:连接回复加上请求头:keep-alive。第一次请求不断开,第二次请求复用。
  • 使用http 2.0版本:多路复用,连接复用率会更高

3、优化发送的HTTP请求

  • 合并JS或CSS文件
  • inline image:使用data:url scheme来内连图片
  • 减小cookie体积,每个请求都会附带cookie,所以不要滥用cookie。
  • 合理使用CasheControl代替发送HTTP请求
  • 同时发送多个请求(浏览器自带)IE8可以同时请求下载4个的css文件,Chrome可以同时请求下载8个 。

4、优化接受响应

  • 设置Etags:浏览器重复与请求服务器一样的文件,ETag响应304。
  • Gzip压缩大文件 使用macos gzip,npm server gzip gzip 文件名
    其响应头为Content-Encodinging:gzip,先压缩接收到再解压缩。缺点:耗费浏览器CPU,权衡

5、优化DOCTYPE

  • 不能不写,不能写错

6、优化CSS,JS请求

  • 使用CDN:用CDN请求静态资源同时可以增大同时下载数量,内容分发网络(CDN)可以使请求总时间降低,也可以减少cookie
  • CSS放在head里:使其尽早下载,因为chrome需要下载完所有的css后才渲染页面
  • JS放在body里的最后:尽早显示整个页面,获取节点。

7、使用懒加载

  • 组件懒加载
const xxx =()=>import('./components/xxx.vue')
  • 路由懒加载

8、优化用户体验

  • 用户看到哪些内容就请求哪些内容
  • 加一个loading动画用户会感觉时间变快

9、减少监听器,使用事情委托

    <body>
        <ul>
            <li>1</li>
            <li>2</li>
            <li>3</li>
            <li>4</li>
        </ul>
        <script>
            let liList = document.querySelectorAll('li')

            // liList[0].onclick = ()=>console.log(1)
            // liList[1].onclick = ()=>console.log(2)
            // liList[2].onclick = ()=>console.log(3)
            // liList[3].onclick = ()=>console.log(4)
            //法一:监听太多

            let ul = document.querySelector('ul')

            ul.onclick = (e) => {
                if (e.target.tagName === 'LI') {
                    console.log(e.target.innerText)

                }
            }//法二:减少监听,采用事件委托
        </script>
    </body>

10、优化图片大小

  • 图片压缩网站

11、减少或合并DOM操作或使用虚拟DOM

// 不好的方式
var elem = $('#elem');
for (var i = 0; i < 100; i++) {
 elem.append('<li>element '+i+'</li>');
}

// 好的方式
var elem = $('#elem' ),
arr = [];
for (var i = 0;  i < 100; i++) {
  arr.push('<li>element ' +i+'</li>' );
}
elem.append(arr. join(''));

12、对大量数据计算使用缓存

// data.length === 100000
   for(var i = 0;i < data.length;i++){
     // do something...
   }
   //上面的代码没有下面的好
   for(var i = 0,len = data.length;i < len;i++){
     // do something...
   }

13、使用setTimeout降低调用接口频率


二、后端性能优化

1、冗长繁琐代码架构重构,精简业务

2、循环语句避免sql查询

3、大量数据查询采用分页 

4、不经常变数据保存在缓存中,从缓存中读,如Redis,Cache等

5、无关显示的业务用异步处理,如埋点数据

6、数据库增删改查尽可能批量,削峰处理

三、数据库

1、合理利用索引,定期维护索引

2、大表数据水平或垂直分库分表

3、一定时间以前的数据移植到历史库中

4、读写分离

5、耗时统计数据放在统计表中,利用Schedule维护

6、正确使用sql语句,避免用法不当消耗数据库性能

7、使用存储过程,但需衡量可维护性

四、运维

1、利用负载均衡部署网站

2、利用监控工具维护硬件资源,合理升级降级



 类似资料:
  • 嗨,有没有什么方法可以提高滚动速度。我找到了一些解决方案,但都不适合我。这就是我尝试的: 或者使用css: 还有别的办法吗?编辑:上面的解决方案都不起作用,我试图使用大得离谱的数字,但滚动速度还是一样

  • 我正在项目的中添加。 所有工作都很好,但在JPanel中使用鼠标滚轮滚动鼠标存在一个问题。滚动时速度很慢。如何让它更快? 我的代码是:

  • 我正在使用来使我的中的项目在屏幕上“对齐”(我的卡片占据了屏幕的大部分,所以我希望它们在每次刷/抛/滚动时都对齐并填充屏幕)。 我在苦苦思索如何让卡片更快地卡入位。我已经尝试创建自定义的(并编辑或中的方法),以及自定义的(并编辑fling方法)。但没有任何东西影响卡“卡”入位的速度。 我想问题是我真的不明白是如何将卡片“滚动”到正确的位置的。它似乎没有使用的或方法。

  • 问题内容: 我正在具有8个核心CPU和6 GB内存的Linux 64bit上运行应用程序服务器。 服务器必须具有高响应能力。 经过检查,我发现服务器上运行的应用程序会创建大量的短期对象,并且只有大约200〜400 MB的长期对象(只要没有内存泄漏) 阅读http://java.sun.com/javase/technologies/hotspot/gc/gc_tuning_6.html之后, 我使

  • 本文向大家介绍如何提高javascript加载速度,包括了如何提高javascript加载速度的使用技巧和注意事项,需要的朋友参考一下 方法如下: 1、将所有<script>标签放在尽可能接近<body>标签底部的位置,以保证页面在脚本运行之前完成解析尽量减少对整个页面下载的影响 2、限制页面的<script>总数也可以改善性能。每当页面解析碰到一个<script>标签时, 紧接着有一段时间用于代

  • 我是一名电商从业者,在用shopify平台进行我的业务,但是我发现我的网页加载速度实在是太慢了,有什么可以提高网页加载速度的方法吗?