6.4. 再現可能なコンテナービルドの使用


ARG SOURCE_DATE_EPOCH を ContainerFile に追加して、-source-date-epoch および --rewrite-timestamp オプションを使用して再現可能なコンテナーイメージをビルドできます。

手順

  • Buildah コマンドの実行時にこれらのオプションを設定します。たとえば、Containerfile からイメージをビルドし、すべてのタイムスタンプを特定の時間に強制するには、以下を実行します。

    Use a specific, immutable image.
    FROM registry.access.redhat.com/ubi9/ubi:9.4 AS builder
    
    # Set the SOURCE_DATE_EPOCH for deterministic timestamps
    ARG SOURCE_DATE_EPOCH
    ENV SOURCE_DATE_EPOCH=${SOURCE_DATE_EPOCH:-1}
    
    # Build the image using the build-arg and rewrite-timestamp options
    buildah bud --build-arg --source-date-epoch=${SOURCE_DATE_EPOCH} \
      --rewrite-timestamp \
      -f Containerfile \
      -t my-reproducible-image .
  • 一貫性のあるタイムスタンプを指定して podman build コマンドを実行し、再現可能なイメージを作成します。

    # Set a consistent timestamp using the last Git commit date
    export SOURCE_DATE_EPOCH=$(git log -1 --pretty=%ct)
  • 指定のタイムスタンプでイメージをビルドします。

    podman build --source-date-epoch=${SOURCE_DATE_EPOCH} --rewrite-timestamp -t my-reproducible-app .

検証

  • ビルド後に、再現可能なコマンドを再度実行します。ビルドが完全に再現可能な場合は、buildah inspect コマンドに同じイメージダイジェストが表示されるはずです。

    buildah bud --build-arg --source-date-epoch=${SOURCE_DATE_EPOCH} \ --rewrite-timestamp \ -f Containerfile \ -t my-reproducible-image-2 .
  • ダイジェストを比較します。

    buildah inspect --format '{{.Digest}}' my-reproducible-image
    buildah inspect --format '{{.Digest}}' my-reproducible-image-2
Red Hat logoGithubredditYoutubeTwitter

詳細情報

試用、購入および販売

コミュニティー

Red Hat ドキュメントについて

Red Hat をお使いのお客様が、信頼できるコンテンツが含まれている製品やサービスを活用することで、イノベーションを行い、目標を達成できるようにします。 最新の更新を見る.

多様性を受け入れるオープンソースの強化

Red Hat では、コード、ドキュメント、Web プロパティーにおける配慮に欠ける用語の置き換えに取り組んでいます。このような変更は、段階的に実施される予定です。詳細情報: Red Hat ブログ.

会社概要

Red Hat は、企業がコアとなるデータセンターからネットワークエッジに至るまで、各種プラットフォームや環境全体で作業を簡素化できるように、強化されたソリューションを提供しています。

Theme

© 2026 Red Hat
トップに戻る