Adobe Experience Manager (AEM) 可以使用 AEM as a Cloud Service SDK 的快速入门 Jar 在本地运行。这允许开发人员在将自定义代码、配置和内容提交到源控件之前,先对它们进行部署和测试,然后将其部署到 AEM as a Cloud Service 环境。
请注意 ~
用作用户目录的简写。 在Windows中,这等同于 %HOMEPATH%
.
Experience Manager是一种Java应用程序,因此需要Java SDK支持开发工具。
java -version
java --version
AEMas a Cloud ServiceSDK(或AEM SDK)包含用于在本地运行AEM创作和发布以进行开发的快速入门Jar,以及兼容版本的Dispatcher工具。
aem-sdk-XXX.zip
文件本地AEM创作服务为开发人员提供本地体验,数字营销人员/内容作者可以共享该体验来创建和管理内容。 AEM Author Service设计为一个创作和预览环境,允许可以针对它执行大多数功能开发验证,这使它成为本地开发过程的一个重要元素。
创建文件夹 ~/aem-sdk/author
复制 快速入门JAR 文件到 ~/aem-sdk/author
并将其重命名为 aem-author-p4502.jar
从命令行中执行以下命令,启动本地AEM Author服务:
java -jar aem-author-p4502.jar
admin
. 可接受任何管理员密码,但建议使用默认密码进行本地开发,以减少重新配置的需要。您 无法 启动AEM作为Cloud Service快速入门Jar 通过双击.
访问本地AEM创作服务,网址为 http://localhost:4502 在Web浏览器
Windows:
$ mkdir -p c:\Users\<My User>\aem-sdk\author
$ copy aem-sdk-Quickstart-XXX.jar c:\Users\<My User>\aem-sdk\author\aem-author-p4502.jar
$ cd c:\Users\<My User>\aem-sdk\author
$ java -jar aem-author-p4502.jar
macOS/Linux:
$ mkdir -p ~/aem-sdk/author
$ cp aem-sdk-Quickstart-XXX.jar ~/aem-sdk/author/aem-author-p4502.jar
$ cd ~/aem-sdk/author
$ java -jar aem-author-p4502.jar
本地AEM Publish服务为开发人员提供AEM的本地体验最终用户,例如浏览基于AEM的网站。 本地AEM发布服务非常重要,因为它与AEM SDK的集成 Dispatcher工具 并允许开发人员对面向最终用户的体验进行抽烟测试和微调。
创建文件夹 ~/aem-sdk/publish
复制 快速入门JAR 文件到 ~/aem-sdk/publish
并将其重命名为 aem-publish-p4503.jar
通过从命令行执行以下命令来启动本地AEM Publish Service:
java -jar aem-publish-p4503.jar
admin
. 可接受任何管理员密码,但建议使用默认密码进行本地开发,以减少重新配置的需要。您 无法 启动AEM作为Cloud Service快速入门Jar 通过双击.
访问本地AEM发布服务,网址为 http://localhost:4503 在Web浏览器
Windows:
$ mkdir -p c:\Users\<My User>\aem-sdk\publish
$ copy aem-sdk-Quickstart-XXX.jar c:\Users\<My User>\aem-sdk\publish\aem-publish-p4503.jar
$ cd c:\Users\<My User>\aem-sdk\publish
$ java -jar aem-publish-p4503.jar
macOS/Linux:
$ mkdir -p ~/aem-sdk/publish
$ cp aem-sdk-Quickstart-XXX.jar ~/aem-sdk/publish/aem-publish-p4503.jar
$ cd ~/aem-sdk/publish
$ java -jar aem-publish-p4503.jar
本地AEM运行时可以启动 预发行模式 允许开发人员根据AEMas a Cloud Service的下一个版本的功能进行构建。 通过传递 -r prerelease
本地AEM运行时的第一个启动项上的参数。 它可同时用于本地AEM作者和AEM发布服务。
# For AEM Author service in prerelease mode
$ java -jar aem-author-p4502.jar -r prerelease
# For AEM Publish service in prerelease mode
$ java -jar aem-publish-p4503.jar -r prerelease
在真实的Cloud Service环境中,使用将内容从Author服务分发到Publish服务 Sling内容分发 和Adobe管道。 此 Adobe管道 是一个只能在云环境中使用的独立微服务。
在开发期间,可能需要使用本地Author和Publish服务模拟内容的分发。 这可以通过启用旧版复制代理来实现。
复制代理只能在本地Quickstart JAR中使用,并且只能提供内容分发的模拟。
登录到 作者 服务并导航到 http://localhost:4502/etc/replication/agents.author.html.
单击 默认代理(发布) 以打开默认复制代理。
单击 编辑 以打开代理的配置。
在 设置 选项卡,更新以下字段:
在 传输 选项卡,更新以下字段:
http://localhost:4503/bin/receive?sling:authRequestLogin=1
admin
admin
单击 确定 保存配置并启用 默认 复制代理。
您现在可以更改Author服务上的内容,并将其发布到Publish服务。
快速入门Jar的命名, aem-<tier>_<environment>-p<port number>.jar
指定启动方式。 AEM在特定层、创作层或发布层启动后,无法更改为备用层。 要执行此操作, crx-Quickstart
必须删除首次运行期间生成的文件夹,并且必须再次运行快速入门Jar。 可以更改环境和端口,但是它们需要停止/启动本地AEM实例。
不断变化的环境, dev
, stage
和 prod
对于开发人员而言,确保环境特定的配置由AEM正确定义和解析,非常有用。 建议主要针对默认情况执行本地开发 dev
环境运行模式。
可用的排列如下:
快速入门Jar文件名 | 模式描述 |
---|---|
aem-author-p4502.jar |
作为作者,在端口4502上处于开发运行模式 |
aem-author_dev-p4502.jar |
As Author在端口4502上处于开发运行模式(与 aem-author-p4502.jar ) |
aem-author_stage-p4502.jar |
作为作者,在端口4502上处于暂存运行模式 |
aem-author_prod-p4502.jar |
作为作者,在端口4502上处于生产运行模式 |
aem-publish-p4503.jar |
在端口4503上以开发运行模式发布 |
aem-publish_dev-p4503.jar |
在端口4503上以开发运行模式发布(与 aem-publish-p4503.jar ) |
aem-publish_stage-p4503.jar |
在端口4503上以暂存运行模式发布 |
aem-publish_prod-p4503.jar |
在端口4503上以生产运行模式发布 |
请注意,端口号可以是本地开发计算机上的任何可用端口,但按惯例:
更改这些组件可能需要调整AEM SDK配置
要停止本地AEM运行时(AEM创作或发布服务),请打开用于启动AEM运行时的命令行窗口,然后点按 Ctrl-C
. 等待AEM关闭。 当关闭过程完成时,命令行提示符可用。
在每月的最后一个星期四或之后不久,至少每月更新AEM SDK,这是AEMas a Cloud Service“功能发布”的发布节奏。
将快速入门Jar更新为新版本需要替换整个本地开发环境,从而导致丢失本地AEM存储库中的所有代码、配置和内容。 确保任何不应销毁的代码、配置或内容都会安全提交到Git,或从本地AEM实例导出为AEM包。
升级AEM SDK会有效地创建一个全新的AEM运行时,包括一个新存储库,这意味着对先前AEM SDK的存储库所做的任何更改都将丢失。 以下是有助于在AEM SDK升级之间保留内容的可行策略,可以单独或一致使用:
includepaths
指令,用于将先前的AEM SDK存储库中的内容复制到新的AEM SDK存储库。请记住,在AEM SDK升级之间使用上述方法维护代码,表明存在开发反模式。 非一次性代码应源自开发IDE,并通过部署流入AEM SDK中。
双击快速入门Jar以启动时,会显示错误模式,阻止AEM在本地启动。
这是因为AEMas a Cloud Service快速入门Jar不支持双击快速入门Jar以本地启动AEM。 相反,必须从该命令行运行Jar文件。
要启动AEM Author服务, cd
进入包含Quickstart Jar的目录并执行命令:
$ java -jar aem-author-p4502.jar
或者,要启动AEM Publish服务, cd
进入包含Quickstart Jar的目录并执行命令:
$ java -jar aem-publish-p4503.jar
从命令行启动快速入门Jar时,进程立即中止,AEM服务未启动,并出现以下错误:
➜ ~/aem-sdk/author: java -jar aem-author-p4502.jar
Loading quickstart properties: default
Loading quickstart properties: instance
java.lang.Exception: Quickstart requires a Java Specification 11 VM, but your VM (Java HotSpot(TM) 64-Bit Server VM / Oracle Corporation) reports java.specification.version=1.8
at com.adobe.granite.quickstart.base.impl.Main.checkEnvironment(Main.java:1046)
at com.adobe.granite.quickstart.base.impl.Main.<init>(Main.java:646)
at com.adobe.granite.quickstart.base.impl.Main.main(Main.java:981)
Quickstart: aborting
这是因为AEMas a Cloud Service需要Java SDK 11,而您运行的是其他版本,很可能是Java 8。 要解决此问题,请下载并安装 oracleJava SDK 11.
安装Java SDK 11后,通过命令行执行以下操作来验证它是活动版本。
安装Java 11 SDK后,通过从命令行运行命令来验证它是活动版本:
java -version
java --version