Adobe Experience Manager桌面应用程序v1.x疑难解答 troubleshoot-aem-desktop-app
对AEM桌面应用程序进行故障排除,以解决与安装、升级、配置等相关的偶然问题。
Adobe Experience Manager桌面应用程序包括实用工具,可帮助您将AEM Assets存储库映射为桌面上的网络共享(macOS上的SMB共享)。 网络共享是一种操作系统技术,它使远程源可以被视为计算机本地文件系统的一部分。 对于桌面应用程序,远程文件源是远程AEM实例的数字资产管理(DAM)存储库结构。 下图描述了桌面应用程序拓扑:
利用此架构,桌面应用程序会截获对挂载的网络共享的文件系统调用(打开、关闭、读取、写入等),并将这些调用转换为对AEM服务器的本机AEM HTTP调用。 文件缓存在本地。 有关详细信息,请参阅使用AEM桌面应用程序v1.x。
AEM桌面应用程序组件概述 desktop-app-component-overview
该桌面应用程序包含以下组件:
- 桌面应用程序:应用程序作为远程文件系统装载或卸载DAM。 它转换本地挂载的网络共享与其连接的远程AEM实例之间的文件系统调用。
- 操作系统WebDAV/SMB客户端:处理Windows资源管理器/查找器与桌面应用程序之间的通信。 如果检索、创建、修改、删除、移动或复制了文件,操作系统(OS) WebDAV/SMB客户端会将此操作与桌面应用程序进行通信。 收到通信后,桌面应用程序会将其转换为本机AEM远程API调用。 例如,如果用户在已装载的目录中创建文件,则WebDAV/SMB客户端会发起请求,桌面应用程序会将该请求转换为在DAM中创建文件的HTTP请求。 WebDAV/SMB客户端是操作系统的内置组件。 它未以任何方式与桌面应用程序、AEM或Adobe相关联。
- Adobe Experience Manager实例:提供对AEM Assets DAM存储库中存储的资源的访问权限。 此外,它代表与挂载的网络共享交互的本地桌面应用程序执行桌面应用程序请求的操作。 目标AEM实例应运行AEM版本6.1或更高版本。 运行早期AEM版本的AEM实例可能需要安装额外的功能包和热修复程序才能完全正常工作。
AEM桌面应用程序的预期用例 intended-use-cases-for-aem-desktop-app
AEM桌面应用程序使用网络共享技术将远程AEM存储库映射到本地桌面。 但是,它并非旨在替代网络共享资产,即用户直接从本地桌面执行数字资产管理操作。 这些功能包括移动或复制多个文件,或直接在Finder/Explorer中将大型文件夹结构拖动到AEM Assets网络共享。
AEM桌面应用程序提供了一种在AEM Assets触屏UI和本地桌面之间访问(打开)和编辑(保存)DAM资产的便捷方式。 它将AEM Assets服务器中的资产链接到基于桌面的工作流。
以下示例用例说明了应如何使用AEM Desktop:
- 用户登录到AEM并使用Web UI来查找资产。
- 使用AEM Web UI的桌面操作功能,用户可根据需要打开、显示或编辑桌面上的资产。
- AEM Desktop在资产文件类型的默认编辑器中打开资产。
- 用户对资源进行所需的更改。
- 修改文件后,用户可以使用AEM Desktop的后台同步状态窗口查看文件的同步状态。
- 使用AEM Desktop的上下文菜单,用户可签入/签出资产,或返回到DAM用户界面。
- 完成对文件的更改后,用户返回到AEM Web UI
此方案不是唯一的用例。 但是,它说明了AEM Desktop如何成为一种便于在本地访问/编辑资产的机制。 我们建议您尽可能多地使用DAM Web UI,因为它提供了更好的体验。 它为Adobe提供了更大的灵活性以满足客户需求。
限制 limitations
WebDAV/SMB1网络共享为在Explorer/Finder窗口中处理文件提供了便利。 但是,Explorer/Finder和AEM通过具有某些限制的网络连接进行通信。 例如,将1-GB文件复制到已装载的WebDAV/SMB目录所花费的时间与使用Web浏览器将1-GB文件上传到网站所需的时间大致相同。 事实上,在前一种情况下,由于WebDAV/SMB协议和操作系统的WebDAV/SMB客户端(特别是macOS X)效率低下,持续时间可能会更长。
对于可以从装入的目录执行的任务类型,有一些限制。 通常,处理大型文件,尤其是通过低/高延迟/低带宽网络连接处理大型文件可能具有挑战性,尤其是在编辑大型文件时。
Adobe建议在将某些类型的文件可以从已装载目录就地有效编辑的提交到客户端之前执行一些用例测试。
AEM Desktop不适合执行密集的文件系统操作,包括但不限于:
- 移动或复制文件和目录
- 将许多资源添加到AEM
- 通过文件系统搜索和打开文件(浏览文件夹除外)
- 压缩或解压缩文件存档
由于操作系统的限制,Windows的文件大小限制为4,294,967,295字节(约4.29 GB)。 这是因为注册表设置定义了网络共享上的文件可以有多大。 注册表设置的值是一个最大大小等于引用数字的DWORD。
Experience Manager桌面应用程序没有可配置的超时值,该超时值在固定时间间隔后断开Experience Manager服务器与桌面应用程序之间的连接。 上传大型资产时,如果连接在一段时间后超时,应用程序会重试上传资产,方法是增加上传超时时间。 没有更改默认超时设置的推荐方法。
缓存和与AEM的通信 caching-and-communication-with-aem
AEM桌面应用程序提供内部缓存和后台上传功能,以改善最终用户体验。 保存大文件时,首先会将文件保存在本地,以便您继续工作。 过了一段时间(当前为30秒)后,文件会被发送到后台的AEM服务器。
与Creative Cloud Desktop或其他文件同步解决方案(如Microsoft One Drive)不同,AEM桌面应用程序不是完整的Desktop Sync客户端。 原因在于,它提供了对整个AEM Assets存储库的访问权限,要实现完全同步,存储库可能非常大(数百个GB或TB)。
通过缓存,可将网络/存储开销限制为仅与用户相关的资源子集。
以下是AEM桌面应用程序执行缓存的方式:
- 当您在Finder中打开文件夹并显示文件的缩略图或预览时,桌面应用程序将缓存文件二进制文件。 同样,当您在应用程序中打开文件时,应用程序还会缓存文件二进制文件。
- 通过Finder或其他桌面应用程序存储文件时,文件首先存储在本地(缓存),并通知操作系统。 然后,文件会排队等候在后台上传到服务器,并最终通过网络上传。 如果存在网络错误,则桌面应用程序会重试上传整个文件,次数最多三次。 如果重试三次后上载失败,则该文件将标记为冲突文件,并且状态会通过“后台上载队列状态”窗口显示。 该桌面应用程序不再尝试更新文件。 用户应更新文件,并在连接恢复后重新上传
不会将每个操作缓存在本地。 以下内容将立即传输到AEM服务器,而不进行本地缓存:
- 对文件夹的任何操作,例如创建、删除等
- 1.4 版本中引入的“文件夹上传”功能可以上传本地文件夹层次结构,而不会在本地缓存文件
单个操作 individual-operations
针对个别用户的次优化性能进行故障排除时,首先要检查应用程序限制。 后续部分包含改进个人用户性能的建议。
带宽建议 bandwidth-recommendations
单个用户可用的带宽对WebDAV/SMB客户端的性能起着至关重要的作用。
Adobe建议单个用户的上传速度应接近10 Mbps。 对于无线连接,带宽通常在多个用户之间共享。 如果多个用户同时执行消耗网络带宽的任务,则性能可能会进一步降低。 要避免此类问题,请使用有线连接。
并发操作 concurrent-operations
当您在本地与文件交互时,AEM Desktop会检查AEM中是否有较新版本的文件可用。 如果有新版本可用,应用程序会将文件的新副本下载到本地缓存。 但是,如果本地缓存的文件已被修改,则AEM Desktop不会覆盖该文件。 此功能可防止意外覆盖您的工作。
在本地和AEM中修改同一文件时,本地修改的版本会覆盖AEM中的版本。 在这种情况下,资产时间轴中提供了先前版本。 您可以验证两个版本并解决任何冲突。
如果本地文件与服务器中可用的版本不一致,则后台上载状态对话框将通知您有关冲突的信息。 要解决此问题,请打开发生冲突的文件并保存该文件。 保存文件会强制AEM Desktop将您的最新本地更改同步到AEM。 您可以在时间轴中查看资产的早期版本并解决任何冲突。
当多个用户尝试在针对同一AEM实例的单独已装载目录中工作时,请考虑其他因素。 特别是,以下因素很重要:
- 用户原始网络上的可用带宽量
- 原始网络的网络配置,如防火墙或代理
- 目标AEM实例网络中的可用带宽量
- Dispatcher是否在Target AEM实例之前存在
- 目标AEM实例上的当前负载
其他AEM配置 additional-aem-configurations
如果WebDAV/SMB性能在多用户同时工作时急剧下降,则可以在AEM中配置一些内容,这有助于提高性能。
更新资产临时工作流 update-asset-transient-workflows
您可以通过为DAM更新资产工作流启用临时工作流来提高AEM性能。 启用临时工作流会降低在AEM中创建或修改资产时更新资产所需的处理能力。
- 导航到Experience Manager实例(
https://[aem_server]:[port]/miscadmin
)中的/miscadmin
。 - 从导航树中,展开 工具 > 工作流 > 模型 > Dam。
- 双击 DAM更新资产。
- 从浮动工具面板切换到 页面 选项卡,然后单击 页面属性。
- 选中 临时工作流 复选框,然后单击 确定。
调整 Granite Transient 工作流程队列 adjust-granite-transient-workflow-queue
另一种提高AEM性能的方法是为Granite临时工作流队列作业配置最大并行作业值。 建议值大约为服务器可用CPU数的一半。 要调整值,请执行以下步骤:
- 在要配置的AEM实例中导航到
/system/console/configMgr
(例如,https://[aem_server]:[port]/system/console/configMgr
)。 - 搜索
QueueConfiguration
,单击以打开每个作业,直到找到 Granite临时工作流队列 作业并单击 编辑 为止。 - 更改
Maximum Parallel Jobs
值,然后单击 保存。
AWS配置 aws-configuration
由于网络带宽的限制,当多个用户同时工作时,WebDAV/SMB的性能可能会降低。 Adobe建议为在AWS上运行的目标AEM实例增加AWS实例的大小以增强WebDAV/SMB的性能。
这项措施特别提高了服务器可用的网络带宽量。 以下是一些详细信息:
- 专用于AWS实例的网络带宽量会随着实例大小的增加而增加。 有关每个实例大小的可用带宽的信息,请转到AWS文档。
- 在针对大型客户端进行故障排除时,Adobe将其AEM实例的大小配置为c4.8xlarge,主要针对其提供的4000 Mbps专用带宽。
- 如果AEM实例前面有一个Dispatcher,请确保它的大小合适。 如果AEM实例提供4000 Mbps,而Dispatcher仅提供500 Mbps,则有效带宽仅为500 Mbps。 这是因为Dispatcher造成了网络瓶颈。
签出文件限制 checked-out-file-limitations
通过Explorer/Finder与已签出文件交互的方式存在一些已知限制。 如果文件已签出,则除已签出文件的用户外,任何人都应该以只读模式访问该文件。 在AEM中实施WebDAV/SMB1协议会强制实施此规则。 但是,OS WebDAV/SMB客户端通常无法与签出的文件正常交互。 下面介绍了一些奇特之处。
常规 general
在写入签出的文件时,仅在AEM WebDAV实现中强制实施锁定。 因此,使用WebDAV的客户端(如桌面应用程序)只强制执行锁定。 不会通过AEM Web界面强制执行锁定。 AEM界面只会在已签出的资产的卡片视图中显示一个锁定图标。 图标是修饰性的,对AEM的行为没有任何影响。
通常,WebDAV客户端并不总是按预期运行。 可能还有其他问题。 但是,在AEM中刷新或检查资源是验证资源是否未被修改的可靠方法。 这种行为是不受Adobe控制的OS WebDAV客户端的典型行为。
Windows windows
删除文件似乎成功,因为该文件在Windows中从文件资源管理器中消失。 但是,刷新目录并签入AEM Assets会显示文件仍然存在。 此外,编辑文件似乎可以成功(不显示警告对话框或错误消息)。 但是,重新打开文件或签入AEM Assets时,会显示文件未更改。
MACOS X mac-os-x
替换文件不会显示警告或错误,但检查AEM中的资源会显示它保持不变。 在AEM中刷新或检查资源以验证它未被修改。
桌面应用程序图标问题疑难解答(macOS X) troubleshooting-desktop-app-icon-issues-mac-os-x
安装桌面应用程序后,桌面应用程序菜单图标会显示在菜单栏中。 如果未显示该图标,请执行以下步骤来解决问题:
-
打开操作系统终端窗口。
-
在命令提示符下键入以下命令,然后按Enter键:
code language-shell cd ../Library/Caches.
-
键入以下命令,然后按Enter键:
code language-shell rm -r com.adobe.aem.assetscompanion
-
键入以下命令,然后按Enter键:
code language-shell cd ~/Library/Preferences
-
键入以下命令,然后按Enter键:
code language-shell rm com.adobe.aem.assetscompanion.plist
-
键入以下命令,然后按Enter键:
code language-shell rm ~/Library/Group\ Containers/group.com.adobe.aem.desktop/*
-
重新启动系统。
AEM Desktop尝试同步任何给定文件三次。 如果第三次尝试后文件无法同步,AEM Desktop会认为文件存在冲突,并通过后台上载状态窗口通知您。 冲突状态表示您可在本地使用最新更改,但这些更改不会同步回AEM。 AEM桌面应用程序不再尝试同步。
解决这种情况的最简单方法是打开冲突文件并再次保存。 它会强制AEM Desktop尝试另外三次同步。 如果文件仍无法同步,请参阅以下部分以获取更多帮助。
正在清除AEM桌面缓存 clearing-aem-desktop-cache
清除AEM Desktop的缓存是一项初步的故障排除任务,可以解决若干AEM Desktop问题。
可以通过删除应用程序在以下位置的缓存目录来清除缓存。
在Windows中,%LocalAppData%\Adobe\AssetsCompanion\Cache\
在Mac中,~/Library/Group/Containers/group.com.adobe.aem.desktop/cache/
但是,该位置可能会因AEM Desktop配置的AEM端点而发生更改。 该值是目标URL的编码版本。 例如,如果应用程序面向http://localhost:4502
,则目录名称为http%3A%2F%2Flocalhost%3A4502%2F
。
要清除缓存,请删除<Encoded AEM Endpoint>目录。
查找AEM桌面版本 finding-the-aem-desktop-version
确定AEM桌面版本的过程对于Windows和macOS都是相同的。
单击“AEM桌面”图标,然后选择 关于。 版本号显示在屏幕上。
在macOS上升级AEM桌面应用程序 upgrading-aem-desktop-app-on-macos
在macOS上升级AEM桌面应用程序时,有时可能会出现问题。 AEM桌面应用程序的旧版系统文件夹导致了这些问题。 这会阻止正确加载新版本的AEM Desktop。 要解决此问题,可以手动删除以下文件夹和文件。
在执行以下步骤之前,将“Adobe Experience Manager Desktop”应用程序从macOS Applications文件夹拖到垃圾桶中。 然后打开终端,执行以下命令,在出现提示时提供密码。
sudo rm -rf ~/Library/Application\ Support/com.adobe.aem.desktop
sudo rm -rf ~/Library/Preferences/com.adobe.aem.desktop.plist
sudo rm -rf ~/Library/Logs/Adobe\ Experience\ Manager\ Desktop
sudo find /var/folders -type d -name "com.adobe.aem.desktop" | xargs rm -rf
sudo find /var/folders -type d -name "com.adobe.aem.desktop.finderintegration-plugin" | xargs rm -rf
保存由其他人签出的文件 saving-a-file-checked-out-by-others
操作系统的技术限制使得用户在尝试覆盖其他人已签出的文件时无法拥有一致的体验。 体验会因用于编辑检出文件的应用程序而异。 有时,应用程序会显示一条错误消息,指示磁盘写入失败,或显示一个看似不相关或一般性的错误。 在其他情况下,不会显示错误信息,并且操作似乎成功。
在这种情况下,关闭和重新打开文件可能会显示内容未更改。 但是,某些应用程序可能会存储文件的备份,以便应用您的更改。
无论行为如何,当您签入文件时,文件将保持不变。 即使显示了文件的其他版本,更改也不会同步到AEM。
有关移动文件的疑难解答 troubleshooting-problems-around-moving-files
服务器API需要传递其他标头(X-Destination、X-Depth和X-Overwrite),才能进行移动和复制操作。 默认情况下,Dispatcher不会传递这些标头,这会导致这些操作失败。 有关详细信息,请参阅连接到Dispatcher后面的AEM。
AEM桌面连接问题疑难解答 troubleshooting-aem-desktop-connection-issues
SAML重定向问题 saml-redirect-issue
AEM Desktop连接到已启用SSO的(SAML) AEM实例时出现问题的最常见原因是,SAML进程不会重定向回最初请求的路径。 或者,也可以将连接重定向到未在AEM桌面应用程序中配置的主机。 执行以下步骤以验证登录过程:
- 打开Web浏览器。
- 在地址栏中,指定URL
/content/dam.json
。 - 将URL替换为目标AEM实例,例如
https://localhost:4502/content/dam.json
。 - 登录到AEM。
- 登录后,在地址栏中检查浏览器的当前地址。 它应该与您最初输入的URL匹配。
- 验证
/content/dam.json
之前的所有内容是否与AEM Desktop中配置的目标AEM值匹配。
SSL配置问题 ssl-configuration-issue
AEM桌面应用程序用于HTTP通信的库使用严格的SSL强制实施。 有时,连接可能会成功使用浏览器,但无法使用AEM桌面应用程序。 要正确配置SSL,请在Apache中安装缺少的即时证书。 请参阅如何在Apache中安装中间CA证书。
将AEM桌面与Dispatcher结合使用 using-aem-desktop-with-dispatcher
AEM Desktop可与Dispatcher后面的AEM部署配合使用,后者是AEM服务器的默认和推荐配置。 AEM创作环境前的AEM Dispatcher通常配置为跳过缓存DAM资源。 因此,调度程序不会从AEM Desktop角度提供额外的缓存。 确保已调整Dispatcher配置以用于AEM桌面。 有关其他详细信息,请参阅使用Dispatcher连接到AEM。
检查日志文件 checking-for-log-files
根据您的操作系统,您可以在以下位置找到AEM Desktop的日志文件:
- Windows:
%LocalAppData%\Adobe\AssetsCompanion\Logs
- Mac:
~/Library/Logs/Adobe\ Experience\ Manager\ Desktop