」工欲善其事,必先利其器。「—孔子《論語.錄靈公》
首頁 > 程式設計 > 優化 AWS ECS 的 Java 堆設置

優化 AWS ECS 的 Java 堆設置

發佈於2024-11-06
瀏覽:815

Optimizing Java Heap Setting for AWS ECS

我們在 AWS Elastic Container Service(ECS) Fargate 上執行多個 Java 服務 (Corretto JDK21)。每個服務都有自己的容器,我們希望使用為每個進程支付的所有可能的資源。但這些步驟可以應用於 EC2 和其他雲端。

服務正在運行批次作業,延遲並不重要,我們使用並行GC(-XX:UseParallelGC)。即使完成我們的任務,也許 G1 會更好,但這是一個需要單獨研究和發布的主題。
為了使用所有可用內存,我們的 MaxHeapSize 略低於容器內存大小。但一段時間後,我們注意到兩個問題,有時我們的容器因為使用太多記憶體而被殺死,有時我們收到 OutOfMemoryError 異常。 為了解決第一個問題,我們增加了容器記憶體大小和 MaxHeapSize 之間的差距,對於第二個問題,增加了容器記憶體作為快速解決方案,並開始查看堆轉儲。

堆轉儲顯示了有趣的細節,實際堆大小低於 MaxHeapSize,與老一代相比,年輕代堆很小。

在網路上搜尋並沒有幫助找到如何針對我們的案例調整 JVM 參數的良好指南,我只找到了一些有關堆和參數描述的高級細節。我決定寫這篇文章來描述我所做的步驟。

第一步是:

  • 列印參數和預設值的資訊:(-XX: PrintFlagsFinal),
  • 將InitialHeapSize設定為與MaxHeapSize相同的值(-XX:InitialRAMPercentage=100或僅將-XX:InitialHeapSize設定為與MaxHeapSize相同的值)。無論如何,我們要為所有容器記憶體付費,所以為什麼不從一開始就分配它呢?
  • 記錄GC和堆資訊(-Xlog:gc*)。

Young:Old Generation預設比例為1:2,同時只使用部分Young Generation進行GC。啟動後,JVM 按預期分配了所有內存,但一段時間後,它開始將年輕代堆大小減少到幾乎幾兆位元組。所以一段時間後我們只使用了 2/3 的可用記憶體。
經過一番挖掘,我發現了一個禁用自適應策略的參數(-XX:-UseAdaptiveSizePolicy),它有所幫助,堆停止減少,垃圾收集之間的間隔增加了一個數量級甚至更多。 GC 消耗的時間也有所成長,但增幅不大。

下一步是找到容器記憶體大小之間的最佳差距。預設情況下,即使InitialRAMPercentage=100,JDK也只是分配記憶體而不使用它,因此它不會被映射。 Linux 允許分配比實體記憶體更多的虛擬記憶體。當記憶體實際映射(JDK 寫入它)時,容器稍後會失敗。 -XX:AlwaysPreTouch 更改此行為。不幸的是,有些記憶體仍然沒有映射,但 OOM 終止發生得更快。經過幾次嘗試後,我得出了下一個公式「容器記憶體大小 - 1024MB」(對於具有 8GB 或更多記憶體的容器)。例如,對於 8192 容器記憶體大小,我們使用 -XX:MaxHeapSize=7168m.

為了進一步優化,我們正在考慮更改 -XX:NewRatio 以減少年輕代大小並減少 GC 時間。但這取決於物件在應用程式中的生命週期。
正如我之前提到的,我還沒有找到任何好的指南來詳細解釋參數(我發現最好的是 vm-options-explorer)和調整步驟。如果您能分享您的知識和成果,那就太好了。

版本聲明 本文轉載於:https://dev.to/mikhail-m1/optimizing-java-heap-setting-for-aws-ecs-5df6?1如有侵犯,請聯絡[email protected]刪除
最新教學 更多>
  • Go ost 量子密碼網路伺服器
    Go ost 量子密碼網路伺服器
    Golang 1.23 將後量子密碼學引入 Go 標準庫。它非常棒且易於使用。 這篇文章「Go 1.23 中的後量子加密 Web 伺服器」包含一些程式碼範例和後量子加密的背景.. 我總是很好奇我正在使用哪個 TLS 密碼套件和曲線,因此我添加了一個片段來執行此操作(使用反射) 您認為還需要更多的例...
    程式設計 發佈於2024-11-06
  • Js電子表格組件
    Js電子表格組件
    我經常使用的一件事是我們用來組織資料的 Excel 表格。 Jspreadsheet 執行的操作非常相似,但直接在瀏覽器中執行。您無需安裝任何東西,只需打開並使用它即可。對於任何需要以簡單實用的方式組織資訊的人來說,它都是完美的選擇。 簡單易用: 如果您曾經使用過 Excel,您會感到賓至如歸。介...
    程式設計 發佈於2024-11-06
  • 掌握 MySQL:每個開發人員都應該監控的關鍵效能指標
    掌握 MySQL:每個開發人員都應該監控的關鍵效能指標
    监控 MySQL 性能指标和管理数据库并不困难。是的,你没听错。有了适当的监控策略和工具,您终于可以退居二线了。 RED 方法与 Releem 强大的监控功能和易于应用的配置建议相结合,可以为您完成繁重的工作。 红色方法简介 RED方法传统上用于监控Web应用程序和服务的性能,但也可...
    程式設計 發佈於2024-11-06
  • 答:C++中如何產生隨機數?
    答:C++中如何產生隨機數?
    這是一個很好的答案! 回覆回覆:如何在C中產生隨機數? 2012 年 11 月 18 日 ...
    程式設計 發佈於2024-11-06
  • 如何在 JavaScript 中對 HTML 實體進行編碼以便在 CMS 中正確顯示?
    如何在 JavaScript 中對 HTML 實體進行編碼以便在 CMS 中正確顯示?
    在JavaScript 中編碼HTML 實體將內容輸入內容管理系統(CMS) 時,處理® 等特殊字元至關重要確保跨瀏覽器正確顯示。為了解決這個問題,可以使用 JavaScript 來定位這些符號並將其轉換為適當的 HTML 實體。 使用正規表示式,可以透過將特定字元範圍替換為對應的 HTML 實體來...
    程式設計 發佈於2024-11-06
  • 為什麼「float: right」會顛倒 HTML 中的 Span 順序?
    為什麼「float: right」會顛倒 HTML 中的 Span 順序?
    Float:跨度的右反轉順序給定 HTML 標記:<div> <span class="label"><a href="/index/1">Bookmix Offline</a></span>...
    程式設計 發佈於2024-11-06
  • Python 字典如何保持程式碼乾淨、乾燥
    Python 字典如何保持程式碼乾淨、乾燥
    Python 字典和 DRY 原则:初学者快速指南 嘿! ?如果您正在深入研究 Python 编程,您可能偶然发现了字典,并且可能想知道“Python 中的字典到底是什么?它如何帮助我更智能地编写代码?”不用担心,让我们用一种超级简单的方式来分解它。 Python ...
    程式設計 發佈於2024-11-06
  • 使用 Django、Twilio 和 Pinata 建立安全的匿名回饋系統
    使用 Django、Twilio 和 Pinata 建立安全的匿名回饋系統
    在本指南中,我将引导您使用 Django、用于短信通知的 Twilio、用于安全媒体上传的 Pinata 以及用于响应式样式的 TailwindCSS 构建安全匿名反馈系统。在本教程结束时,您将拥有一个功能齐全的反馈系统,用户可以在其中提交反馈、选择上传媒体以及接收短信通知 - 所有这些都考虑到安全...
    程式設計 發佈於2024-11-06
  • 為什麼 Tkinter Entry 的 get 函數不回傳任何內容?
    為什麼 Tkinter Entry 的 get 函數不回傳任何內容?
    Tkinter Entry 的get 函數沒有產生任何結果:綜合解釋當嘗試使用get() 從Tkinter Entry 小部件檢索用戶輸入時函數時,您可能會遇到空返回值。這個看似令人困惑的問題源自於 Tkinter 的非同步特性和函數執行的順序。 在提供的程式碼片段中,您嘗試在建立 Entry 後立...
    程式設計 發佈於2024-11-06
  • 使用 NodeJs 開始使用 RabbitMq
    使用 NodeJs 開始使用 RabbitMq
    RabbitMq簡介 RabbitMq 是一個訊息代理,允許在不同服務之間發送和接收訊息。它是一個實作高階訊息佇列協定(AMQP)的訊息代理程式。用 Erlang 程式語言寫成。 安裝 RabbitMq RabbitMq 可以使用各自的套件管理器安裝在不同的作業系統上。 Rabbi...
    程式設計 發佈於2024-11-06
  • 讓網路更加互聯
    讓網路更加互聯
    讓網路更互聯 - Infometka 如何解決「隱形網站」問題 身為 Web 開發人員和 ???️??????️ 的創建者,我一直熱衷於解決現實世界的問題。今天,我想分享我開發的一個解決方案,我相信它可以為無數網站所有者帶來重大改變,並在某種程度上使互聯網成為一個更加互聯的地方。 ...
    程式設計 發佈於2024-11-06
  • 使用 React 建置 Loop Studio
    使用 React 建置 Loop Studio
    介绍 Loop Studio 是一个沉浸式网站,旨在展示各种虚拟现实 (VR) 项目。使用 React,我们可以有效地管理和渲染不同的组件,以构建有凝聚力和交互式的用户体验。该项目采用简洁的设计,带有导航标题、详细的 VR 部分、创作画廊以及带有社交媒体链接的页脚。 ...
    程式設計 發佈於2024-11-06
  • 如何解決用PHP在CURL中傳送多維數組時出現「陣列到字串轉換」錯誤?
    如何解決用PHP在CURL中傳送多維數組時出現「陣列到字串轉換」錯誤?
    透過CURL 和PHP 發送多維數組使用CURL 發布包含多維數組的表單資料時,遇到「數組到字串轉換」錯誤是一個常見問題。當嘗試使用包含陣列的陣列設定 CURLOPT_POSTFIELDS 時會發生這種情況。 由於 Content-Type 標頭必須是 multipart/form-data 以方便...
    程式設計 發佈於2024-11-06
  • 如何在 Selenium 中使用 \"span:contains(\'String\')\" 解決 InvalidSelectorException?
    如何在 Selenium 中使用 \"span:contains(\'String\')\" 解決 InvalidSelectorException?
    Selenium 中的Invalid SelectorException with "span:contains('String')"在Firefox 中使用Python 中的Selenium 時,嘗試使用CSS 選擇器「span:contains('Co...
    程式設計 發佈於2024-11-06
  • 如何將 HTML 附加到容器元素而不出現 InnerHTML 陷阱?
    如何將 HTML 附加到容器元素而不出現 InnerHTML 陷阱?
    在沒有innerHTML的情況下將HTML附加到容器元素重新訪問當前的問題是如何將HTML附加到容器元素,同時避免限制以及使用innerHTML屬性的陷阱。正如OP正確指出的那樣,innerHTML由於其替換現有內容的行為,可能會破壞嵌入媒體等動態元素。 幸運的是,有一個替代方案可以克服這些問題:i...
    程式設計 發佈於2024-11-06

免責聲明: 提供的所有資源部分來自互聯網,如果有侵犯您的版權或其他權益,請說明詳細緣由並提供版權或權益證明然後發到郵箱:[email protected] 我們會在第一時間內為您處理。

Copyright© 2022 湘ICP备2022001581号-3