yueming 发表于 2011-12-23 02:56

高性能WEB服务器开发心得整理(转)

<DIV>
<DIV id=blog_content class=blog_content>
<P>高并发WEB服务器处理</P>
<P><SPAN style="TEXT-DECORATION: underline">一.<STRONG>HTML</STRONG> <STRONG>静态化</STRONG> </SPAN></P>
<P>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; 效率最高、消耗最小的就是纯静态化的html页面,所以我们尽可能使我们的网站上的页面采用静态页面来实现,如使用信息发布系统CMS</P>
<P><SPAN style="TEXT-DECORATION: underline"><STRONG>二.</STRONG> <STRONG>图片服务器分离</STRONG> </SPAN></P>
<P>  对于Web服务器来说,不管是Apache、IIS还是其他容器,图片是最消耗资源的,于是我们有必要将图片与页面进行分离,</P>
<P>在处理静态页面或者图片、js等访问方面,可以考虑使用lighttpd[<SPAN style="COLOR: #99ccff"><EM>注意尽量使用linux或unix系统</EM> </SPAN>]代替Apache或IIS,它提供了更轻量级和更高效的处理能力。</P>
<P>当然也可以考虑使用CDN内容分发技术来优化,注意使用版本号来控制,使其达到即时更新. </P>
<P><SPAN style="TEXT-DECORATION: underline">三. <STRONG>数据库优化</STRONG> </SPAN></P>
<P>&nbsp; a.硬件优化</P>
<P>&nbsp;&nbsp;&nbsp;&nbsp; 数据库和应用程序分离,合理使用RAID,及增加相应内存和CPU</P>
<P>&nbsp; b. 查询优化</P>
<P>&nbsp;&nbsp;&nbsp;&nbsp; 1.增加合理索引,适当使用引起锁的操作 </P>
<P>&nbsp;&nbsp;&nbsp;&nbsp; 2.尽量使用SARG搜索参数标准,有效使用索引。[部分非SARG语句无法使用索引]</P>
<P>&nbsp;&nbsp;&nbsp;&nbsp; 3.适度使用游标,尽量考虑集合式操作。[锁]</P>
<P>&nbsp;&nbsp;&nbsp;&nbsp; 4.谨慎使用事务,事务尽量不要使用过多的查询。[锁]</P>
<P>&nbsp;&nbsp;&nbsp;&nbsp; 5.尽量使用存储过程,尽量不要使用动态执行SQL语句(重用执行计划及预编译)<STRONG></STRONG> </P>
<P><STRONG>&nbsp; c.</STRONG> 从应用程序的角度来考虑改善系统架构,</P>
<P>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; 1.不同的模块对应不同的表,如新闻中如数据量大的话,每个分类使用一个表。</P>
<P>  2.按时间对表进行划分,将表放在不同的数据库服务器,提取时从每台服务器提取,然后合并。</P>
<P>  3.按用户ID对用户数据进行划分,针对不同用户ID调用不同数据库的数据</P>
<P>  4. 读写数据库分离,如一台数据库主要负责写[不加索引],另外一台数据库主要负责读[添加索引]</P>
<P><STRONG>四</STRONG> <STRONG>、缓存</STRONG> </P><STRONG>a</STRONG>

<STRONG>.</STRONG>

asp.net用户控件缓存 OutputCache
<P>&nbsp; b.对共享数据使用cache(1:文件,2:数据库&nbsp; 3:时间限制)</P>
<P>&nbsp; c.对多台WEB应用服务器可考虑使用分布式缓存,如:memcached等</P>
<P>五、<STRONG>负载均衡终极优化手段 </STRONG></P>
<P>&nbsp;&nbsp; a. HTTP重定向实现负载均衡,</P>
<P>  常见于下载网站,点击地址由服务端决定在HTTP头上的location加入跳转地址,浏览器根据跳转地址打开相应的页面。</P>
<P>&nbsp; b.DNS负载均衡</P>
<P>&nbsp;&nbsp;&nbsp;&nbsp; 原理:利用域名到IP地址的映射可以是一对多的,利用A记录的轮询来随机挑选一个服务器来访问。</P>
<P>&nbsp;&nbsp;&nbsp;&nbsp; 缺点:当某台服务器出现故障,可能会导致部分用户无法访问,因为DNS更新不能及时,并且不能很好对服务器工作量进行均衡分配。</P>
<P>&nbsp;&nbsp; c.反向代理负载均衡</P>
<P>  使用一台专门的代理服务器来分配任务,由其决定使后端的哪台服务器,可以均衡的分配工作量,真正达到均衡。</P>
<P>  如:nginx代理服务器</P>
<P> d.IP负载均衡</P>
<P>  利用NAT服务器实现互载均衡</P></DIV>





</DIV>
页: [1]
查看完整版本: 高性能WEB服务器开发心得整理(转)