Skip to content

Latest commit

 

History

History
 
 

base-jre-image

Folders and files

NameName
Last commit message
Last commit date

parent directory

..
 
 
 
 

JRE Base Image

公司有維護 JRE Base Image, 包含了 Java 8, Java 11 等在公司專案中常用的 JRE 版本, 再多做些如 TimeZone 等常見的共通性設定, 一共有以下版本:

Harbor Registry

公司維護的 JRE Base Image 都收錄於 Harbor Registry, 名稱為:

  • harbor.softleader.com.tw/library/zulu-openjdk-alpine:{tag}
  • harbor.softleader.com.tw/library/adoptopenjdk-alpine:{tag}

你可以透過 docker 指令拉取, 如:

# Azul Zulu
docker pull harbor.softleader.com.tw/library/zulu-openjdk-alpine:11-jre-taipei

# AdoptOpenJDK
docker pull harbor.softleader.com.tw/library/adoptopenjdk-alpine:11-jre-taipei

點擊以下連擊檢視所有 Tag:

Nightly Build

為了能盡快套用上層的 Azul Zulu / AdoptOpenJDK Image 或 OS Package 的 Security Issue Fix Pack, 我們使用 GitHub Action 在每天晚間會自動的重 Build 這些 JRE Base Image

若你真的很急想要立馬重 Build, 你可以:

  1. softleader/dockerfile/actions 中選擇對應的 workflow, 點選 Run workflow
  2. 若上述沒權限, 也可以 checkout softleader/dockerfile 專案, 執行 azul-zulu/build-image-no-cache.shadoptopenjdk/build-image-no-cache.sh

Vulnerability Scan

我們 Harbor Registry 支援 ClairTrivy 做為 Image 安全掃描機制, 在每天午夜自動的掃描所有 Image, 其中包含了 Base JRE Image 及使用這些 Base JRE Image 的專案 Image 等

任何專案的 Image 只要打包過, Docker 就會自動的 Cache 過程中使用到的 Image Layers, 若想套用公司最新的 JRE Base Image, 則 Image 就必須要重新打包, 並且提醒 Docker 要重新拉取 Base Image (--pull) 及忽略 Cach Layer (--no-cache), 就好像 Maven force update (-U) 的概念一樣:

docker build harbor.softleader.com.tw/${my-project}/${my-image}:${my-tag} \
	--pull \
	--no-cache

預設的安全掃描機制目前是 Clair, 但各個 Harbor Project 都可以依照需求調整

Jenkins Setting

大部分我們的專案都是使用 Jenkins 作為 CI/CD 工具, 因此要稍作調整, 首先修改 Jenkinsfile, 找到打包 Image 步驟, 將其中的打包語法一樣加上 --no-cache--pull:

stage('docker build') {
    steps {
        sh "docker build --no-cache=${noCache} --pull=${noCache} -t harbor.softleader.com.tw/jasmine/${env.JOB_NAME}:${tag} . -f Dockerfile-ocp"
    }
}

接著到 Jenkins 的設定畫面, 點選 Job > General 中的參數化建置區塊, 增加 noCache 名稱的布林值參數, 說明打上:

打包 image 的過程是否參考 docker layer cache, noCache 通常用於要強制更新 base image 來解決上層 image 被掃出來的 security issue

這樣完成後, 只要在打包 Image 時打勾 noCache, 即可套用當前所有的 Security Issue Fix Pack!

請依專案特性決定 noCache 預設值是否要打勾 (打勾建置時間一定會比較久)

Containerize Tool

如果專案使用的是 Jib 或是 Buildpacks 等 Image 打包工具, 則應該都不用特別去處理, 因為這些工具通常預設都會去檢查 Base Image 是否有任何更新!