- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我开发了这个脚本,将 Sitecore 工作流程应用于整个项目,而无需手动单击 GUI。我对它的效果非常满意,但速度很慢。这是脚本:
Import-Module 'C:\Subversion\CMS Build\branches\1.2\sitecorepowershell\Sitecore.psd1'
# Hardcoded IDs of workflows and states
$ContentApprovalWfId = "{7005647C-2DAC-4C32-8A09-318000556325}";
$ContentNoApprovalWfId = "{BCBE4080-496F-4DCB-8A3F-6682F303F3B4}";
$SettingsWfId = "{7D2BA7BE-6A0A-445D-AED7-686385145340}";
#new-psdrive *REDACTED*
set-location m-rocks:
function ApplyWorkflows([string]$path, [string]$WfId) {
Write-Host "ApplyWorkflows called: " $path " - " $wfId;
$items = Get-ChildItem -Path $path;
$items | foreach-object {
if($_ -and $_.Name) {
$newPath = $path + '\' + $_.Name;
$newPath;
} else {
Write-host "Name is empty.";
return;
}
if($_.TemplateName -eq "Folder" -or $_TemplateName -eq "Template Folder") {
# don't apply workflows to pure folders, just recurse
Write-Host $_.Name " is a folder, recursing.";
ApplyWorkflows $newPath $wfId;
}
elseif($_.TemplateName -eq "Siteroot" -or $_.TemplateName -eq "InboundSiteroot") {
# Apply content-approval workflow
Set-ItemProperty $newPath -name "__Workflow" $ContentApprovalWfId;
Set-ItemProperty $newPath -name "__Default workflow" $ContentApprovalWfId;
# Apply content-no-approval workflow to children
Write-Host $_.Name " is a siteroot, applying approval workflow and recursing.";
ApplyWorkflows $newPath $ContentNoApprovalWfId;
}
elseif($_.TemplateName -eq "QuotesHomePage") {
# Apply settings workflow to item and children
Write-Host $_.Name " is a quotes item, applying settings worfklow recursing.";
Set-ItemProperty $newPath -name "__Workflow" $SettingsWfId;
Set-ItemProperty $newPath -name "__Default workflow" $SettingsWfId;
ApplyWorkflows $newPath $SettingsWfId;
}
elseif($_.TemplateName -eq "Wildcard")
{
Write-Host $_.Name " is a wildcard, applying workflow (and halting).";
Set-ItemProperty $newPath -name "__Workflow" $ContentApprovalWfId;
Set-ItemProperty $newPath -name "__Default workflow" $ContentApprovalWfId;
}
elseif($_ -and $_.Name) {
# Apply passed in workflow and recurse with passed in workflow
Write-Host $_.Name " is a something else, applying workflow and recursing.";
Set-ItemProperty $newPath -name "__Workflow" $WfId;
Set-ItemProperty $newPath -name "__Default workflow" $WfId;
ApplyWorkflows $newPath $wfId;
}
}
}
ApplyWorkflows "sitecore\Content\" $ContentNoApprovalWfId;
它在不到一秒的时间内处理一个项目。其进程中有一些暂停 - 证据表明这是 Get-ChildItem
返回大量项目的时候。我想尝试很多事情,但它仍在我们的一个网站上运行。大约过了 50 分钟,看起来可能完成了 50%,也可能更少。看起来它的工作广度优先,因此很难确切地了解已完成的内容和未完成的内容。
那么是什么让我放慢了脚步?
是路径构建和检索吗?我尝试通过 $_
或 $_.Name
获取当前项目的子项,但它总是在当前工作目录(即根目录)中查找,并且找不到该项目。每次递归时更改目录会更快吗?
是输出让它陷入困境吗?没有输出,我不知道它在哪里,也不知道它是否仍在工作。有没有其他方法可以让我知道它在哪里、已经完成了多少次等等?
有没有更好的方法,我只需将 Get-ChildItem -r
与过滤器集一起使用并循环这些过滤器集?如果是这样,我们将非常感谢您第一次尝试将第一个脚本中的一些条件合并到过滤器集中。我是 PowerShell 新手,因此我确信我的代码中需要进行不止一两个改进。
即使没有子项,我是否总是调用递归位?这里的内容树非常广泛,有很多没有子节点的叶子。什么是检查子项目是否存在的好方法?
最后,我们拥有的 PowerShell 提供程序 (PSP) 并不完整。它似乎没有 Get-Item 的有效实现,这就是为什么所有内容几乎完全用 Get-ChildItem 编写的原因。我们的 Sitecore.Powershell.dll 说它是版本 0.1.0.0。升级会有帮助吗?有更新的吗?
编辑:终于完成了。我对输出进行了计数,得出了 1857 个项目,运行时间约为 85 分钟,平均每分钟 21 个项目。比我想象的要慢,甚至...
编辑:我的第一次运行是在 PowerShell 2.0 上,使用 Windows PowerShell ISE 。我还没有尝试过 Sitecore PowerShell 插件模块或社区。直到昨天我什至都不知道它的存在:-)
升级到 PowerShell 3.0 后我尝试了另一次运行。从本地启动 - 从我的笔记本电脑运行脚本,连接到远程服务器 - 没有明显的差异。我在托管箱上安装了 PowerShell 3.0 并从那里运行脚本,发现速度可能提高了 20-30%。所以这不是我所希望的 Elixir ——我需要一个或两个数量级的改进才能使我不必照顾和批量运行。我现在正在尝试下面的详细答案所建议的一些实际脚本改进。我会回复对我有用的内容。
最佳答案
我个人认为,如果您开始使用社区 PowerShell 实现而不是 Rocks 实现,您将获得最大的提升。
让我解释一下原因。
您正在遍历整个树,这意味着您必须访问分支中的每个节点,这意味着它必须被读取并通过 Rocks Web 服务至少传输一次。然后,每个属性保存都是另一个 Web 服务调用。
我已经在社区控制台中运行了您的脚本,大约花了 25 秒才处理了 3724 个项目。(我删除了修改,因为这些值与我的系统无关)。
简单
Get-ChildItem -recurse
我的 3724 项目树在社区控制台中花费了 11 秒,而在 Rocks 实现中花费了 48 秒。
您可以在脚本的社区实现中使用的其他调整是使用 Sitecore 查询,例如:
get-item . -Query '/sitecore/content/wireframe//*[@@TemplateName="Template Folder"]'
并且仅将这些项目发送到您的函数中
这并不意味着Rocks控制台写得不好,它只是意味着Rocks控制台的设计选择和他们的目标不同。
您可以在此处找到社区控制台: http://bit.ly/PsConScMplc
关于powershell - 为什么这个 PowerShell 脚本这么慢?我怎样才能加快速度?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/18006050/
我想使用 ffmpeg 框架更改视频速度。我为此使用了这个命令: ffmpeg -y -i /storage/extSdCard/Video/1.avi -filter_complex [0:v]fp
我有以下数据数组,有 200 万个条目: [20965 1239 296 231 -1 -1 20976 1239 299 314 147 337 255
我正在使用 Oracle 数据库,并且想获取一个包含 3000 万条记录的表。 library(RODBC) ch <- odbcConnect("test", uid="test_user",
我在 android 上使用 FFmpeg 来: 1- 合并 3 个视频 2-添加音频 3-添加标志 4-修剪 3 个视频之一 5-改变输出的fps 我已经实现了正确的代码,但花了 30 分钟。对于(
我使用 GLPKMathProgInterface 和 JuMP 编写了一个程序来解决 Julia 中的线性程序。 Julia 代码由 python 程序调用,该程序通过多个命令行调用运行多个 Jui
我们使用 POV-Ray 每次运行生成大约 80 张图像,我们将这些图像拼接在一起形成两个移动的 GIF 文件(一个场景的两个 360 度 View )。我们正在寻找尽可能加快此镜像创建的方法(在 h
就目前情况而言,这个问题不太适合我们的问答形式。我们希望答案得到事实、引用资料或专业知识的支持,但这个问题可能会引发辩论、争论、民意调查或扩展讨论。如果您觉得这个问题可以改进并可能重新开放,visit
我将数据从一个数据库插入到另一个数据库,所以我有 2 个连接(Conn1 和 Conn2)。下面是代码(使用pypyodbc)。 import pypyodbc Conn1_Query = "SE
在我的应用程序中,我显示 EKEvents 列表,我想在 UITableView 中显示一个月的所有事件,每个部分包含各自的日期。嗯,这可行,我得到了我需要的所有数据,但获取速度非常慢。 问题在于事件
我有一个移动速度非常慢的传送带。我不知道什么JS脚本控制速度,我需要它来加速。无法从主题制作者那里获得任何帮助。任何建议都会非常有帮助。谢谢 页面: http://krankgolf2017.wpen
有没有办法加快这段代码的速度?我需要它来删除相同的内容并将其写入单元格,以强制其他 VBA 代码运行另一列上的代码。这就是它的作用,只是 super 慢。有时此表上有 2000 个条目/行。每个单元大
我正在开发一个相当大的程序,它再次从一个相当大的 Excel 电子表格中获取数据。由于一些奇怪的原因,加载这个大的 Excel 文件需要很长时间,我希望能以某种方式加快速度。我做了自己的研究并尝试了
我有下面的代码,将所有按钮(有 10 个)着色为灰色,以清除任何先前着色的按钮,然后将所选按钮着色为蓝色。基本上充当当前选择哪个按钮的指示器。我注意到代码现在需要一些时间才能通过这种修饰添加来运行,我
我有一个 LINQ 查询,它正在搜索包含大约 250,000 条记录的 SQL 表,并且仅搜索 2 个字段。这两个字段都已建立索引,但我发现它的运行速度仍然相当慢。 下面是代码,有人可以提出任何建议来
对于相对较大的 Pandas DataFrame(几十万行),我想创建一个应用函数结果的系列。问题是该功能不是很快,我希望它能以某种方式加快速度。 df = pd.DataFrame({ 'valu
这个问题在这里已经有了答案: Faster weighted sampling without replacement (3 个答案) 关闭 9 年前。 如何在 R 中加快概率加权采样。 # Let
在运行 PhantomJS 提供的 rasterize.js 示例时,我发现我必须等待 20 秒或更长时间才能生成网页图像。 有没有可能在不消耗大量资源的情况下加快速度的方法?我基本上希望快速生成从加
我正在开发一个相当大的程序,它再次从一个相当大的 Excel 电子表格中获取数据。由于一些奇怪的原因,加载这个大的 Excel 文件需要很长时间,我希望能以某种方式加快速度。我做了自己的研究并尝试了
我有下面的代码,将所有按钮(有 10 个)着色为灰色,以清除任何先前着色的按钮,然后将所选按钮着色为蓝色。基本上充当当前选择哪个按钮的指示器。我注意到代码现在需要一些时间才能通过这种修饰添加来运行,我
我有一个 Excel 工作簿,用户通过单击按钮导入文本文件。我的代码完全按照我的需要工作,但是在填写 H 列“阅读日期”时速度非常慢。将文本文件导入 Excel 工作表后,我的 Excel 工作簿如下
我是一名优秀的程序员,十分优秀!