DG dg
開發人員指導方針
背景 background
DG 會識別 AEM 6.5 和 AEM as a Cloud Service 選定開發指導方針的偏離。遵循最佳實務可以改進系統的可維護性和效能。儘管其中部分的偏離可能在其他應用程式 (包括舊版 AEM) 內容中不成問題,但在 AEM as a Cloud Service 中使用時則可能會造成問題。
子類型用於識別偵測到的不同違規類型:
java.io.inputstream:在應用程式的程式碼中使用了java.io.InputStream。maintenance.task.configuration:某種定期維護活動的設定。sling.commons.scheduler:Sling Commons Scheduler API 用於已排程任務。unsupported.asset.api:在應用程式程式碼中使用不受支援的 Asset Manager API。javax.jcr.observation.EventListener:在應用程式的程式碼中使用事件監聽程式。custom.guava.cache:在應用程式的程式碼中使用 Guava 快取。java.api:部分Java API已從Java 11移除至Java 17。configuration.admin:將標籤存取設定的自訂程式碼。guava.api:在AEM 6.5 LTS上不支援立即可用的Guava。com.day.cq.dam.scene7.api.model:package com.day.cq.dam.scene7.api.model有重大版本變更。
可能的影響和風險 implications-and-risks
-
java.io.inputstream- 使用
java.io.InputStream串流處理二進位資料,可能會消耗記憶體資源到影響效能的程度。這個問題是因為 AEM as a Cloud Service 中所用容器的記憶體有限所致。
- 使用
-
maintenance.task.configuration- 以前需要明確設定的部分維護任務,現在是在 AEM as a Cloud Service 內自動設定和管理的。
- AEM as a Cloud Service 中的維護任務設定必須移至原始檔控制系統。
-
sling.commons.scheduler- 因為 AEM as a Cloud Service 中無法保證執行,所以相依於背景任務 (使用 Sling Commons Scheduler) 的應用程式可能無法如預期運作。
- 對於背景任務和長時間執行工作的指導方針建議,執行為已排程任務的程式碼也必須假設執行所在的執行個體隨時都會停機。因此程式碼必須有韌性和可恢復性。
-
unsupported.asset.api-
下列 AssetManager API 在 AEM as a Cloud Service 中被標記為不受支援。
- createAssetForBinary
- getAssetForBinary
- removeAssetForBinary
- createAsset
-
-
javax.jcr.observation.EventListener- 依賴於事件監聽程式的應用程式可能無法如預期般運作,因為無法保證執行。
-
custom.guava.cache- 使用 Guava 快取可能會導致 AEM 出現效能問題。
-
java.api- 若使用JRE17上的AEM 6.5 LTS,這些移除的Java API將無法使用,且將無法使用。
-
configuration.admin- 您應檢視使用情形,確認未使用任何不支援的設定,例如social。
-
guava.api- 由於AEM 6.5 LTS不支援Guava,因此使用Guava的自訂程式碼將不會啟用。
-
com.day.cq.dam.scene7.api.model- 由於主要版本變更,無法解析自訂套件組合中的匯入套件
com.day.cq.dam.scene7.api.model。
- 由於主要版本變更,無法解析自訂套件組合中的匯入套件
可能的解決方案 solutions
-
java.io.inputstream- 使用直接二進位上傳方法,即二進位直接新增至資料存放區。
- 對於資產使用案例,請參閱 aem-upload。對於其他類型的二進位資料,自訂上傳邏輯可以仿照此相同模式。
-
maintenance.task.configuration -
sling.commons.scheduler- 將 Sling Commons Scheduler 取代為 Sling 工作,後者有至少執行一次的保證。
- 如有可能應避免長時間執行工作。
-
unsupported.asset.api- 不要再使用不受支援的 Asset Manager API,請參閱 aem-upload。
-
javax.jcr.observation.EventListener- 與其使用事件監聽程式,建議將事件處理機制重構為 Sling 工作,因為它提供了處理的保證。
-
custom.guava.cache- 如果需要,應該在 AEM 外部建立快取。可以考慮外部快取解決方案。
-
請聯絡 AEM 支援團隊以釐清或解決問題。
-
configuration.admin- 移除不支援功能(例如Social)的任何設定用法。
-
guava.api- 如果您在自訂程式碼中使用Guava,請安裝Guava或移除使用方式。
-
com.day.cq.dam.scene7.api.model- 將匯入的封裝
com.day.cq.dam.scene7.api.model的版本範圍更新為 3.0.4。
- 將匯入的封裝
recommendation-more-help
c50d24a5-718e-4110-a484-b335e8a63206