问题描述
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
.csharpcode, .csharpcode pre
{
font-size: small;
color: black;
font-family: consolas, "Courier New", courier, monospace;
background-color: #ffffff;
/*white-space: pre;*/
}
.csharpcode pre { margin: 0em; }
.csharpcode .rem { color: #008000; }
.csharpcode .kwrd { color: #0000ff; }
.csharpcode .str { color: #006080; }
.csharpcode .op { color: #0000c0; }
.csharpcode .preproc { color: #cc6633; }
.csharpcode .asp { background-color: #ffff00; }
.csharpcode .html { color: #800000; }
.csharpcode .attr { color: #ff0000; }
.csharpcode .alt
{
background-color: #f4f4f4;
width: 100%;
margin: 0em;
}
.csharpcode .lnum { color: #606060; }
然后打开SharePoint 2010 Management Shell,运行这个ps1文件(注意,是ps1,而不是psl)
我这边运行的效果如下
该脚本运行之后,我再去访问上面列出的网站,就几乎无需等待,马上可以看到页面。
上面提到的方式是手工地运行脚本,那是否有办法定时自动地运行这个脚本呢?当然可以,只要你稍微掌握一些Powershell的概念,我们可以结合Windows自带的“任务计划”组件来实现自动化调度。
首先,我们需要在这个脚本的顶部添加一句脚本:
Add-PsSnapin Microsoft.SharePoint.PowerShell
这句话的作用是将SharePoint的管理命令添加到Powershell。
然后,在控制面板中的任务计划中,添加一个定时的任务
【备注】这里的Program路径如下,请替换掉红色部分 C:\WINDOWS\System32\WindowsPowerShell\v1.0\PowerShell.exe -Version 2 "d:\training\moss2010\warmup.ps1"
另外,由于该任务是自动运行的,请将下面两个选项选中
第二个方案是结合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
如果使用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网站的预热,但实际上以上两个方案对于其他网站也是适用的。