大规模高性能Web服务器部署

大规模网站的一些性能优化技巧
服务器君一共花费了174.122 ms进行了6次数据库查询,努力地为您提供了这个页面。
试试阅读模式?希望听取您的建议

HTML静态化

效率最高、消耗最小的就是纯静态化的html页面,所以我们尽可能使我们的网站上的页面采用静态页面来实现,如使用信息发布系统CMS。

图片服务器分离

对于Web服务器来说,不管是Apache、IIS还是其他容器,图片是最消耗资源的,于是我们有必要将图片与页面进行分离, 在处理静态页面或者图片、js等访问方面,可以考虑使用lighttpd[注意尽量使用linux或unix系统]代替Apache或IIS,它提供了更轻量级和更高效的处理能力。

当然也可以考虑使用CDN内容分发技术来优化,注意使用版本号来控制,使其达到即时更新。

数据库优化

硬件优化

数据库和应用程序分离,合理使用RAID,及增加相应内存和CPU

查询优化

  1. 增加合理索引,适当使用引起锁的操作
  2. 尽量使用SARG搜索参数标准,有效使用索引。[部分非SARG语句无法使用索引]
  3. 适度使用游标,尽量考虑集合式操作。[锁]
  4. 谨慎使用事务,事务尽量不要使用过多的查询。[锁]
  5. 尽量使用存储过程,尽量不要使用动态执行SQL语句(重用执行计划及预编译)

从应用程序的角度来考虑改善系统架构

  1. 不同的模块对应不同的表,如新闻中如数据量大的话,每个分类使用一个表。
  2. 按时间对表进行划分,将表放在不同的数据库服务器,提取时从每台服务器提取,然后合并。
  3. 按用户ID对用户数据进行划分,针对不同用户ID调用不同数据库的数据
  4. 读写数据库分离,如一台数据库主要负责写[不加索引],另外一台数据库主要负责读[添加索引]

缓存

  1. asp.net用户控件缓存 OutputCache
  2. 对共享数据使用cache(1:文件,2:数据库[sql2005] 3:时间限制)
  3. 对多台WEB应用服务器可考虑使用分布式缓存,如:memcached等

负载均衡终极优化手段

HTTP重定向实现负载均衡:常见于下载网站,点击地址由服务端决定在HTTP头上的location加入跳转地址,浏览器根据跳转地址打开相应的页面。

DNS负载均衡。原理:利用域名到IP地址的映射可以是一对多的,利用A记录的轮询来随机挑选一个服务器来访问。缺点:当某台服务器出现故障,可能会导致部分用户无法访问,因为DNS更新不能及时,并且不能很好对服务器工作量进行均衡分配。

反向代理负载均衡:使用一台专门的代理服务器来分配任务,由其决定使后端的哪台服务器,可以均衡的分配工作量,真正达到均衡。如:nginx代理服务器。

IP负载均衡:利用NAT服务器实现互载均衡。

本文地址:http://www.nowamagic.net/librarys/veda/detail/1048,欢迎访问原出处。

不打个分吗?

转载随意,但请带上本文地址:

http://www.nowamagic.net/librarys/veda/detail/1048

如果你认为这篇文章值得更多人阅读,欢迎使用下面的分享功能。
小提示:您可以按快捷键 Ctrl + D,或点此 加入收藏

大家都在看

阅读一百本计算机著作吧,少年

很多人觉得自己技术进步很慢,学习效率低,我觉得一个重要原因是看的书少了。多少是多呢?起码得看3、4、5、6米吧。给个具体的数量,那就100本书吧。很多人知识结构不好而且不系统,因为在特定领域有一个足够量的知识量+足够良好的知识结构,系统化以后就足以应对大量未曾遇到过的问题。

奉劝自学者:构建特定领域的知识结构体系的路径中再也没有比学习该专业的专业课程更好的了。如果我的知识结构体系足以囊括面试官的大部分甚至吞并他的知识结构体系的话,读到他言语中的一个词我们就已经知道他要表达什么,我们可以让他坐“上位”毕竟他是面试官,但是在知识结构体系以及心理上我们就居高临下。

所以,阅读一百本计算机著作吧,少年!

《深入理解MySQL核心技术》 Sasba Pacbev (作者), 李芳 (译者), 于红芸 (译者), 邵健 (译者)

《深入理解MySQL核心技术》:从公共可用性的意义上讲,MySQL源代码是开放源代码,但如果对其不了解,则实质上,它对于您来说是封闭的。MysQL开发团队的前成员Sasha Pachev通过《深入理解MySQL核心技术》给出了MySQL 5的全面指南,揭示了这一强大数据库的内部运作。您将直奔MySQL核心技术,了解各种数据结构和各种方便的功能的运作情况,了解如何添加新的存储引擎和配置选项等。 《深入理解MySQL核心技术》从结构概况讲起,在这一部分解释了MysQL的不同组件是如何协同工作的。接着将学习设置有效的可编译代码副本的步骤,然后使用基本架构添加自己的配置变量和存储引擎。

更多计算机宝库...