We are running on AEM as a cloud service and Adobe recommends updating the SDK to the latest version every month. However, I would like to know if it's also recommended to update the SDK version in the pom.xml file every month? Also, will there be any potential chances of the existing functionalities (either OOTB or custom development) to break as a repercussion of updating the SDK version in pom.xml?
Solved! Go to Solution.
Views
Replies
Total Likes
AEM CS updates are 100% backwards compatible in terms of API; that means even if you build your application against a SDK version of 2021, the resulting code will work with the latest version of AEM CS (both on the cloud as well as with the SDK). Of course you cannot use the latest extension in your code, but if you don't need them ...
Nevertheless I recommend to update the SDK version in the pom.xml every now and then, but in my personal priority list it won't be in the top 5
@SRK_1D It hard to answer as AEMaaCS is new. We should update AEM SDK in case of major feature release from Adobe. It is fine to have as is as this provide backward compatibility. Also, I think it doesn't matter as everything depends on AEMaaCS as it will be having backward compatibility always. In case of any deprecate feature we will be getting a release note from Adobe in one or other way.
The frequency with which you need to update the Adobe Experience Manager (AEM) SDK version in your codebase depends on several factors:
Vendor Release Cycle: Adobe periodically releases updates and new versions of AEM SDK. The frequency of these releases can vary, but major updates might happen annually or semi-annually, while minor updates or patches could be released more frequently.
Feature Requirements: If your project requires specific features or improvements introduced in a newer version of the SDK, you might need to update more frequently to take advantage of these capabilities.
Security Patches and Bug Fixes: It's crucial to stay updated with security patches and bug fixes provided by Adobe. If vulnerabilities or critical bugs are discovered in your current version, you should update as soon as possible to ensure the security and stability of your application.
End of Support: Adobe typically provides support for older versions of AEM SDK for a limited period. It's essential to monitor the support lifecycle and plan your updates accordingly to avoid running unsupported versions.
Compatibility: Consider the compatibility of the newer SDK version with your existing codebase, third-party integrations, and any customizations. Updating too frequently might introduce compatibility issues that require additional development effort to resolve.
Resource Availability: Updating the SDK version requires resources, including time and effort from your development team. Ensure that you have the necessary resources allocated for the update process.
Based on these factors, you should assess your project's specific needs and constraints to determine the appropriate frequency for updating the AEM SDK version in your codebase. In general, it's recommended to stay relatively up-to-date with SDK versions to benefit from new features, security enhancements, and support. However, the exact frequency of updates may vary from project to project.
Hi @SRK_1D
updating the SDK version in pom.xml won't impact the run time SDK version (run time SDK version will be used from AEM).
The POM version is for development purpose and added with provided scope.
Dependency scope is used to limit the transitivity of a dependency and to determine when a dependency is included in a classpath.
There are 6 scopes:
compile
, but indicates you expect the JDK or a container to provide the dependency at runtime. For example, when building a web application for the Java Enterprise Edition, you would set the dependency on the Servlet API and related Java EE APIs to scope provided
because the web container provides those classes. A dependency with this scope is added to the classpath used for compilation and test, but not the runtime classpath. It is not transitive.provided
except that you have to provide the JAR which contains it explicitly. The artifact is always available and is not looked up in a repository.pom
in the <dependencyManagement>
section. It indicates the dependency is to be replaced with the effective list of dependencies in the specified POM's <dependencyManagement>
section. Since they are replaced, dependencies with a scope of import
do not actually participate in limiting the transitivity of a dependency.
We've encountered a couple of situations where the dialogue functionality of an extended AEM component didn't perform as expected following a release.
Adobe consistently rolls out updates, typically on a monthly basis, via pipelines equipped with various checks to ensure smooth upgrades and minimize potential disruptions to instances. An important part of these checks is Experience Audits https://experienceleague.adobe.com/docs/experience-manager-cloud-service/content/implementing/using-...
While it's impractical to validate the environment after every single release, authors usually uncover residual issues post-pipeline checks. Mostly these are minor ones. If there is anything major, one can request for a rollback of AEM version.
That said, it's advisable to routinely update the SDK version in the pom.xml file, necessitating a local AEM SDK update, which can be time-consuming. Therefore, it's important to plan for these updates regularly, if not on a monthly basis. The frequency of updates should also be determined by factors outlined by @Imran__Khan
@SRK_1D Did you find the suggestions from users helpful? Please let us know if more information is required. Otherwise, please mark the answer as correct for posterity. If you have found out solution yourself, please share it with the community.
Views
Replies
Total Likes
AEM CS updates are 100% backwards compatible in terms of API; that means even if you build your application against a SDK version of 2021, the resulting code will work with the latest version of AEM CS (both on the cloud as well as with the SDK). Of course you cannot use the latest extension in your code, but if you don't need them ...
Nevertheless I recommend to update the SDK version in the pom.xml every now and then, but in my personal priority list it won't be in the top 5