Java 8 終於支持 Docker!

来源:https://www.cnblogs.com/lossingdawn/archive/2019/07/21/11222918.html
-Advertisement-
Play Games

Java 8曾經與Docker無法很好地相容性,現在問題已消失。 請註意:我在本文中使用採用GNU GPL v2許可證的OpenJDK官方docker映像。在Oracle Java SE中,這裡描述的docker支持功能在更新191中引入。Oracle在2019年4月更改了Java 8更新的許可證, ...


Java 8曾經與Docker無法很好地相容性,現在問題已消失。

請註意:我在本文中使用採用GNU GPL v2許可證的OpenJDK官方docker映像。在Oracle Java SE中,這裡描述的docker支持功能在更新191中引入。Oracle在2019年4月更改了Java 8更新的許可證,自Java SE 8 Update 211以來商業使用不再免費。

你是否遇到過在docker中運行的基於JVM的應用程式出現“隨機”故障?或者也許是一些奇怪的死機?兩者都可能是Java 8(仍廣泛使用的)中糟糕的docker支持引起的。

Docker使用控制組(cgroups)來限制資源。在容器中運行應用程式時限制記憶體和CPU絕對是個好主意――它可以阻止應用程式占用整個可用記憶體及/或CPU,這會導致在同一個系統上運行的其他容器毫無反應。限制資源可提高應用程式的可靠性和穩定性。它還允許為硬體容量作好規劃。在Kubernetes或DC/OS之類的編排系統上運行容器時尤為重要。

問題

JVM可以“看到”系統上的整個記憶體和可用的所有CPU核心,並確保與資源一致。它預設情況下將最大堆大小(heap size)設置為系統記憶體的1/4,並將某些線程池大小(比如針對GC)設置為物理核心數量。不妨舉例說明。

我們將運行一個簡單的應用程式,它消耗儘可能多的記憶體(可在該網站上找到):

img

我們在擁有64GB記憶體的系統上運行,所以不妨檢查預設的最大堆大小:

如上所述,它是物理記憶體的1/4即16GB。如果我們使用docker cgroups限制記憶體,會發生什麼?不妨檢查一下:

img

JVM進程被殺死了。由於它是一個子進程――容器本身幸存下來,但通常當java是容器(PID 1)內的唯一進程時,容器會崩潰。

不妨深入看看系統日誌:

img

img

像這樣的故障調試起來可能很難――應用程式日誌中沒有任何內容。在AWS ECS之類的托管系統上尤其困難重重。

CPU怎麼樣?不妨再次檢查,運行一個顯示可用處理器數量的小程式:

不妨在一個cpu編號設置為1的docker容器中運行它:

不好,這個系統上的確有12個CPU。因此,即使可用處理器的數量限製為1,JVM也會嘗試使用12――比如說,GC線程數量由該公式設置:

在擁有N個硬體線程(N大於8)的機器上,並行收集器使用N的固定分數作為垃圾收集器線程的數量。如果N的值很大,該分數約5/8。如果N的值低於8,使用的數字是N。

在我們的情況下:

解決方案

OK,我們現在意識到了這個問題。有解決方案嗎?幸運的是,有!

新的Java版本(10及以上版本)已經內置了docker支持功能。但有時升級不是辦法,比如說如果應用程式與新JVM不相容就不行。

好消息:Docker支持還被向後移植到Java 8。不妨檢查標記為8u212的最新openjdk映像。我們將記憶體限製為1G,並使用1個CPU:docker run -ti --cpus 1 -m 1G openjdk:8u212-jdk。

記憶體:

它是256M,正好是已分配記憶體的1/4。

CPU:

正如我們想要的那樣。

此外,還有幾個新的設置:

它們允許微調堆大小――這些設置的含義在StackOverflow的這個優秀答案中已得到瞭解釋。請註意:他們設置的是百分比,而不是固定值。正因為如此,改變Docker記憶體設置不會破壞任何東西。

如果由於某種原因不想要看到新的JVM行為,可以使用-XX:-UseContainerSupport來關閉。

總結

為基於JVM的應用程式設置正確的堆大小極其重要。如果使用最新的Java 8版本,你可以依賴安全(但非常保守)的預設設置。不需要在docker入口點中使用任何變通辦法,也不需要再將Xmx設置為固定值。

使用JVM愉快!


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • # 電影天堂爬蟲 **今日目標** 爬取電影天堂前30頁最新電影以及下載地址 ```python # 1. 列印程式執行時間 # 2. 數據爬下來後做處理(字元串),定義成字典 # 3. 一條龍: 獲取 -> 調用解析 -> 數據處理 from urllib import request impor... ...
  • 第七章 父 子關係文檔 打虎親兄弟,上陣父子兵。 本章作為 複雜搜索 的鋪墊,介紹父子文檔是為了更好的介紹複雜場景下的ES操作。 在非關係型資料庫資料庫中,我們常常會有表與表的關聯查詢。例如學生表和成績表的關聯查詢就能查出學會的信息和成績信息。在ES中,父子關係文檔就類似於表的關聯查詢。 背景 ES ...
  • 列表列表用中括弧[ ]把各種數據框起來,每一個數據叫作“元素”。每個元素之間都要用英文逗號隔開各種類型的數據(整數/浮點數/字元串)————————————————————————————從列表提取單個元素每個元素都有自己的位置編號(即偏移量) 1.偏移量是從0開始的2.列表名後加帶偏移量的中括弧, ...
  • 一、抽象工廠模式 1、生活場景 汽車生產根據用戶選擇的汽車類型,指定不同的工廠進行生產,選擇紅旗轎車,就要使用中國工廠,選擇奧迪轎車,就要使用德國工廠。 2、抽象工廠模式 1) 抽象工廠模式:定義了一個interface用於創建相關對象或相互依賴的對象,而無需指明具體的類; 2) 抽象工廠模式可以將 ...
  • 一.首先程式啟動,顯示下麵內容供用戶選擇: 1.請登錄 2.請註冊 3.進入文章頁面 4.進入評論頁面 5.進入日記頁面 6.進入收藏頁面 7.註銷賬號 8.退出整個程式 二.必須實現的功能: 1.註冊功能要求: a.用戶名、密碼要記錄在文件中。 b.用戶名要求:只能含有字母或者數字不能含有特殊字元 ...
  • 我喜歡直接了當, 這次主要是推薦蟒營大媽的 Python 入門課(https://py.101.camp), 還有不到一周就要開課了, 歡迎轉發推薦~ 點擊"夏日大作戰:從小白到小能手的 Python 學習之旅", 直接訪問課程的詳細信息, 以及課程的由來故事DM2: call back 下文為曾經 ...
  • 運用input函數搜集信息 input()函數結果的賦值name = input('請輸入你的名字:') #將input()函數的執行結果(收集的信息)賦值給變數name input()函數的使用場景1.函數結果賦值 name=input()2.搜集信息 name=input(xxx)3.輸出結果 ...
  • Goroutine 和 Channel 是 Go 語言併發編程的兩大基石,本文深度解密 channel 的底層原理。 ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...