如何制定.NET网站应对高访问压力的长期解决方案?
- 内容介绍
- 文章标签
- 相关推荐
本文共计1004个文字,预计阅读时间需要5分钟。
开年相比空余时间,抽空写了一篇博文。总结下自己工作中应对网站访问压力的技术方案。
一、前端页面
1. 优化静态资源加载: - 使用CDN加速静态资源分发; - 压缩图片、CSS、JavaScript等文件; - 使用浏览器缓存策略。
2. 减少HTTP请求: - 合并CSS、JavaScript文件; - 使用图片懒加载技术; - 避免重定向。
3. 异步加载: - 使用Ajax异步加载页面内容; - 利用iframe实现局部页面异步加载。
二、后端处理
1. 负载均衡: - 使用Nginx、LVS等负载均衡技术; - 分散请求到多个服务器。
2. 数据库优化: - 使用缓存技术,如Redis、Memcached; - 优化SQL语句,减少查询时间; - 分库分表,提高查询效率。
3. 服务端限流: - 使用令牌桶算法、漏桶算法等限流技术; - 防止恶意攻击。
4. 缓存策略: - 使用本地缓存,如Redis、Memcached; - 使用分布式缓存,如Tair、Mycat。
三、项目现状
目前项目使用50W的PV,以下是前端页面和后端处理的一些技术方案:
1. 前端页面: - 使用Vue.js框架,实现组件化开发; - 优化页面渲染,提高页面加载速度。
2. 后端处理: - 使用Spring Boot框架,简化开发; - 使用MyBatis实现数据库操作,提高效率。
总结:通过以上技术方案,有效应对了网站访问压力,提高了用户体验。
开年比较空,抽时间写个博文,总结下自己工作里的一些应对网站访问压力的技术方案。
自己项目现在大概一天50W的pv。已从前端到后端的顺序总结下自己用的一些方案。
一. 前端页面:
1.首先减少资源的大小,能用小图,就用小图。引用第三方js用mini 压缩版的js。
2.用CDN减少服务器访问的压力,将图片,css,js文件放到CDN上。用户从cdn缓存获取资源的速度远快与访问服务器获取的速度。(还有网络关系,cdn网络快)
3.耗时长的js可以异步请求后加载。
二.服务器负载均衡:
负载均衡解决方案有很多,不差钱有不差钱的,屌丝有屌丝的方案。我用的是nginx负载均衡。
准备一台专用的nginx负载均衡服务器,用它来负载均衡,转发给5台业务服务器。(开发需要单台调试时,用hosts指向单台)
三.服务器缓存
因为是分布式架构,服务器缓存主要用了memcached和redis(各配置2台,一台主服务,一台备用)。memcached和redis都有各自的.net版本,用起来也不复杂。
具体选择看业务需求,我基本上70%用memcached,需要长时间缓存的用redis。
memcached对于中文支持不好,要存中文数据,先将中文base64编码在存入,读取时候做base64解码。
四.数据库
我主要使用sqlserver,少量项目用mysql。50W访问量单台sqlserver服务器完全可以支持的住。尽量减少事务,业务需要用消息队列后补处理。
大任务网站不处理,用其他程序处理(响应要求高的修改操作,先修改redis缓存,然后由异步程序操作数据库。)
操作时候记录日志,数据库崩溃或网站崩溃可以读日志文件回补数据操作。(一般服务器挂了不会很久,超过一天不能恢复日子基本没法活了。。真这样在看具体情况找解决方案)
以上就是本文的全部内容,希望本文的内容对大家的学习或者工作能带来一定的帮助,同时也希望多多支持易盾网络!
本文共计1004个文字,预计阅读时间需要5分钟。
开年相比空余时间,抽空写了一篇博文。总结下自己工作中应对网站访问压力的技术方案。
一、前端页面
1. 优化静态资源加载: - 使用CDN加速静态资源分发; - 压缩图片、CSS、JavaScript等文件; - 使用浏览器缓存策略。
2. 减少HTTP请求: - 合并CSS、JavaScript文件; - 使用图片懒加载技术; - 避免重定向。
3. 异步加载: - 使用Ajax异步加载页面内容; - 利用iframe实现局部页面异步加载。
二、后端处理
1. 负载均衡: - 使用Nginx、LVS等负载均衡技术; - 分散请求到多个服务器。
2. 数据库优化: - 使用缓存技术,如Redis、Memcached; - 优化SQL语句,减少查询时间; - 分库分表,提高查询效率。
3. 服务端限流: - 使用令牌桶算法、漏桶算法等限流技术; - 防止恶意攻击。
4. 缓存策略: - 使用本地缓存,如Redis、Memcached; - 使用分布式缓存,如Tair、Mycat。
三、项目现状
目前项目使用50W的PV,以下是前端页面和后端处理的一些技术方案:
1. 前端页面: - 使用Vue.js框架,实现组件化开发; - 优化页面渲染,提高页面加载速度。
2. 后端处理: - 使用Spring Boot框架,简化开发; - 使用MyBatis实现数据库操作,提高效率。
总结:通过以上技术方案,有效应对了网站访问压力,提高了用户体验。
开年比较空,抽时间写个博文,总结下自己工作里的一些应对网站访问压力的技术方案。
自己项目现在大概一天50W的pv。已从前端到后端的顺序总结下自己用的一些方案。
一. 前端页面:
1.首先减少资源的大小,能用小图,就用小图。引用第三方js用mini 压缩版的js。
2.用CDN减少服务器访问的压力,将图片,css,js文件放到CDN上。用户从cdn缓存获取资源的速度远快与访问服务器获取的速度。(还有网络关系,cdn网络快)
3.耗时长的js可以异步请求后加载。
二.服务器负载均衡:
负载均衡解决方案有很多,不差钱有不差钱的,屌丝有屌丝的方案。我用的是nginx负载均衡。
准备一台专用的nginx负载均衡服务器,用它来负载均衡,转发给5台业务服务器。(开发需要单台调试时,用hosts指向单台)
三.服务器缓存
因为是分布式架构,服务器缓存主要用了memcached和redis(各配置2台,一台主服务,一台备用)。memcached和redis都有各自的.net版本,用起来也不复杂。
具体选择看业务需求,我基本上70%用memcached,需要长时间缓存的用redis。
memcached对于中文支持不好,要存中文数据,先将中文base64编码在存入,读取时候做base64解码。
四.数据库
我主要使用sqlserver,少量项目用mysql。50W访问量单台sqlserver服务器完全可以支持的住。尽量减少事务,业务需要用消息队列后补处理。
大任务网站不处理,用其他程序处理(响应要求高的修改操作,先修改redis缓存,然后由异步程序操作数据库。)
操作时候记录日志,数据库崩溃或网站崩溃可以读日志文件回补数据操作。(一般服务器挂了不会很久,超过一天不能恢复日子基本没法活了。。真这样在看具体情况找解决方案)
以上就是本文的全部内容,希望本文的内容对大家的学习或者工作能带来一定的帮助,同时也希望多多支持易盾网络!

