PowerShell SharePoint Online ExecuteQuery Error语言 - Timed Out



这个已经让我困惑了好几天了......它工作的时间超过一半,但在调用 ExecuteQuery(( 命令时经常会给我这个错误:

使用"0"参数调用"ExecuteQuery"的异常:"操作已超时">

PowerShell:

$ctx = New-Object Microsoft.SharePoint.Client.ClientContext($webURL) 
$ctx.Credentials = New-Object Microsoft.SharePoint.Client.SharePointOnlineCredentials($Credentials.UserName,$Credentials.Password) 
$web = $ctx.Web  
$ctx.Load($web) 
#Retrieve Library
$list = $ctx.Web.Lists.GetByTitle($ITPurchaseRequestListName)
$ctx.load($list)
$files = $list.rootFolder.files
$ctx.load($files)
$ctx.executeQuery()
##########
if((test-path $tempPath) -eq $False)
{
new-item -itemtype directory -path $temppath
}
foreach($file in $files)
{
$ctx.load($file)
$ctx.executeQuery()
$fileRef = $file.ServerRelativeURL
$fileInfo = [Microsoft.SharePoint.Client.File]::OpenBinaryDirect($ctx, $fileRef);
$fileName = $tempPath + $file.Name
$fileStream = [System.IO.File]::Create($fileName)
$fileInfo.Stream.CopyTo($fileStream);
$fileStream.Close()
start-sleep -seconds 2
}

如果我终止控制台会话并启动新的 PowerShell 窗口,它将运行几次,然后再次关闭。有什么想法吗?

我认为使用 foreach 语句调用 executeQuery (( 不利于性能。 最好使用"Include"在foreach语句之外加载文件对象的属性。

参考网址

https://msdn.microsoft.com/en-US/library/office/ee539350(v=office.14(.aspx#Anchor_5

除了其他意见和建议外,6sc.com 的人还能够帮助我确定根本原因,即 for 循环中缺少 stream.close((。

foreach($file in $results)
{
$fileRef = $file["FileRef"];
$fileName = $tempPath + $file["FileLeafRef"];
$fileInfo = [Microsoft.SharePoint.Client.File]::OpenBinaryDirect($ctx, $fileRef);
$fileStream = [System.IO.File]::Create($fileName);
$fileInfo.Stream.CopyTo($fileStream);
$fileStream.Close();
$fileInfo.Stream.Close();
}

添加一个 TRY..CATCH 块到 PowerShell 脚本,它将处理服务器超时,这将提供连续性执行。

TRY的另一个好处...CATCH,您将能够获得异常的详细信息,并且可以在单独的日志文件中捕获,从而为您提供有关问题的其他线索。现在很难做出有根据的猜测,文件句柄可能正在使用中,服务器I/O,文件可能以独占模式打开,连接可能在短时间内中断,很难说。

随着TRY..捕获日期和时间+异常详细信息将帮助您打开Windows事件查看器并精确地找出发生的事情。

我宁愿使用.OpenBinaryStream(),将其下载到内存中,然后保存到光盘。

法典:

foreach($file in $files)
{
$data = $file.OpenBinaryStream();
$ctx.Load($file);
$ctx.ExecuteQuery();
$memory = new-object system.io.MemoryStream
$buffer = new-object system.byte[](1024*64)
$pos = 0;
while (($pos = $data.Value.Read($buffer, 0, $buffer.Length)) -gt 0)
{
$memory.Write($buffer, 0, $pos);
}
$memory.Seek(0, [System.IO.SeekOrigin]::Begin);   
$fileStream = [System.IO.File]::Create($fileName)
$memory.CopyTo($fileStream)
$memory.Close()
$fileStream.Close()
}

包括会施展魔法的$fileInfo.Stream.Close();

相关内容

最新更新