如何对SharePoint网站进行预热(warmup)以提高响应速度

问题描述

SharePoint Server是一个易于使用的协作平台,目前在越来越多的企业中被应用开来。SharePoint Server是通过网站的形式向最终用户提供服务的,而这个网站是基于ASP.NET 的技术实现的。由于ASP.NET技术的特点,网站启动之后,页面在第一个用户第一次访问的时候,会需要进行所谓的JIT 编译,而这个时间,对于该用户来说,可能会显得有点长。这也是大家普遍反映的问题,为什么第一次要比较慢,而以后就较快了。

另外,由于ASP.NET网站会使用到应用程序池的技术,而应用程序池会定时或者不定时地进行回收。回收之后的网站,如果再次访问,那么又会发生JIT编译。这就是为什么有些用户反映说,为什么之前都比较快,而突然第二天又慢了,然后又快了。

 

解决方案

对于SharePoint网站的优化,如果从系统角度来说,是有很多方面的。我在以前的一篇文章中(http://www.cnblogs.com/chenxizhang/archive/2011/11/13/2246958.html)提到过几点建议(请参考该文的结尾处)。但我今天要谈一下的是,如何在不改变网站结构和设计的前提下,采用一些辅助手段,对网站进行预热(warm up),以便能达到提高响应速度的目的。

预热的原理,其实很简单,既然说ASP.NET的页面第一次的JIT编译是无法避免的,那么能否在第一个用户第一次访问之前,就通过某种方式去请求这个页面,使得其编译过程提前发生,这样在用户真正来访问的时候,由于页面已经编译好了,所以就能直接使用。

有这样的思路之后,我们就会想怎么来做到呢?

第一个方案是通过脚本的方式来实现

请参考下面这篇文章,作者介绍了一个Powershell脚本,用来对网站

SharePoint 2007, 2010 or 2013 Application Warm-up Script

http://gallery.technet.microsoft.com/office/SharePoint-2007-2010-or-d1884b4b

 

使用这个脚本的方式,你可以将脚本保存为一个ps1文件,例如如果你是使用SharePoint 2010,则可以将下面这段保存为一个文件

cls 
 
function get-webpage([string]$url,[System.Net.NetworkCredential]$cred=$null) 
{ 
$wc = new-object net.webclient 
if($cred -eq $null) 
{ 
$cred = [System.Net.CredentialCache]::DefaultCredentials; 
} 
$wc.credentials = $cred; 
return $wc.DownloadString($url); 
} # end Function 
 

foreach ($WebApp in (Get-SPWebApplication -IncludeCentralAdministration)) 
{ 
    $sites = $WebApp | Get-SPSite | get-spweb -Limit 15   
     foreach($site in $sites) 
     { 
     write-host "Warming up " $site.Url 
     $html= get-webpage -url $site.Url -cred $cred  
     $site.Dispose(); 
     }    # end loop for each sites 
 
 }    # end foreach web app 
  

然后打开SharePoint 2010 Management Shell,运行这个ps1文件(注意,是ps1,而不是psl)

我这边运行的效果如下

image

该脚本运行之后,我再去访问上面列出的网站,就几乎无需等待,马上可以看到页面。

 

上面提到的方式是手工地运行脚本,那是否有办法定时自动地运行这个脚本呢?当然可以,只要你稍微掌握一些Powershell的概念,我们可以结合Windows自带的“任务计划”组件来实现自动化调度。

首先,我们需要在这个脚本的顶部添加一句脚本:

Add-PsSnapin Microsoft.SharePoint.PowerShell

这句话的作用是将SharePoint的管理命令添加到Powershell。

然后,在控制面板中的任务计划中,添加一个定时的任务

image

image

image

image

image

image

【备注】这里的Program路径如下,请替换掉红色部分  C:\WINDOWS\System32\WindowsPowerShell\v1.0\PowerShell.exe -Version 2   "d:\training\moss2010\warmup.ps1"

image

另外,由于该任务是自动运行的,请将下面两个选项选中

image

 

 

第二个方案是结合IIS 的一个新模块来实现

 

上面这种用脚本的方式看起来很不错,不是吗?除此之外,我们还有一种服务器端的解决方案。因为SharePoint网站是被宿主在IIS这个服务器里面的,微软也针对我们提到的这类问题改进了IIS。

在IIS 7(7.5)中,需要单独安装一个模块

Warm up your SharePoint Web Applications on Windows 2008 R2 using the IIS 7.5 Application Warm-Up module

http://sharepointgeorge.com/2010/warm-sharepoint-web-applications-windows-2008-r2-iis-75-application-warmup-module/

 

如果使用IIS 8.0,则这个模块已经内置在IIS中了,关于如何使用,请参考

IIS 8.0 Application Initialization

http://www.iis.net/learn/get-started/whats-new-in-iis-8/iis-80-application-initialization

 

需要注意的是,虽然我们这篇文章讨论的是关于SharePoint网站的预热,但实际上以上两个方案对于其他网站也是适用的。

posted @ 2013-08-21 10:07  陈希章  阅读(4941)  评论(8编辑  收藏  举报