artifact-management
ビルド成果物、Dockerイメージ、パッケージレジストリを管理します。アーティファクトリポジトリの設定、バージョニング、配布戦略の構成が必要な場面で活用できます。
description の原文を見る
> Manage build artifacts, Docker images, and package registries. Configure artifact repositories, versioning, and distribution strategies.
SKILL.md 本文
アーティファクト管理
目次
概要
ビルドされたバイナリ、Docker イメージ、パッケージを保存、バージョン管理し、環境全体に配布するための包括的なアーティファクト管理戦略を実装します。
使用場面
- Docker イメージレジストリ管理
- パッケージの公開とバージョン管理
- ビルドアーティファクトの保存と取得
- コンテナイメージの最適化
- アーティファクト保持ポリシー
- マルチレジストリ配布
- 依存関係のキャッシング
クイックスタート
最小限の動作例:
# Dockerfile with multi-stage build for optimization
FROM node:18-alpine AS dependencies
WORKDIR /app
COPY package*.json ./
RUN npm ci --only=production
FROM node:18-alpine AS builder
WORKDIR /app
COPY package*.json ./
RUN npm ci
COPY . .
RUN npm run build
FROM node:18-alpine AS runtime
WORKDIR /app
COPY --from=dependencies /app/node_modules ./node_modules
COPY --from=builder /app/dist ./dist
COPY package*.json ./
EXPOSE 3000
HEALTHCHECK --interval=30s --timeout=3s --start-period=40s --retries=3 \
CMD node healthcheck.js
CMD ["node", "dist/server.js"]
// ... (see reference guides for full implementation)
リファレンスガイド
references/ ディレクトリ内の詳細な実装:
| ガイド | 内容 |
|---|---|
Docker Registry 設定 | Docker Registry 設定 |
GitHub Container Registry (GHCR) プッシュ | GitHub Container Registry (GHCR) プッシュ |
npm パッケージ公開 | npm パッケージ公開、アーティファクト保持ポリシー、アーティファクトバージョン管理、GitLab Package Registry |
ベストプラクティス
✅ すべき こと
- アーティファクトにセマンティックバージョニングを使用する
- デプロイ前にイメージスキャンを実装する
- 古いアーティファクトの保持ポリシーを設定する
- Docker イメージにマルチステージビルドを使用する
- アーティファクトに署名し検証する
- アーティファクトの不変性を実装する
- アーティファクトメタデータを文書化する
- 特定のベースイメージバージョンを使用する
- 脆弱性スキャンを実装する
- レイヤーを積極的にキャッシュする
- イメージにコミット SHA でタグを付ける
- ストレージ用にアーティファクトを圧縮する
❌ してはいけない こと
latestタグを唯一の識別子として使用する- シークレットをアーティファクトに保存する
- スキャンなしでアーティファクトをプッシュする
- 信頼されていないベースイメージを使用する
- アーティファクト検証をスキップする
- 公開済みアーティファクトを上書きする
- バイナリとソースアーティファクトを混在させる
- イメージレイヤーの最適化を無視する
- 機密情報を含むビルドログを保存する
ライセンス: MIT(寛容ライセンスのため全文を引用しています) · 原本リポジトリ
詳細情報
- 作者
- aj-geddes
- ライセンス
- MIT
- 最終更新
- 不明
Source: https://github.com/aj-geddes/useful-ai-prompts / ライセンス: MIT
関連スキル
superpowers-streamer-cli
SuperPowers デスクトップストリーマーの npm パッケージをインストール、ログイン、実行、トラブルシューティングできます。ユーザーが npm から `superpowers-ai` をセットアップしたい場合、メールまたは電話でサインインもしくはアカウント作成を行いたい場合、ストリーマーを起動したい場合、表示されたコントロールリンクを開きたい場合、後で停止したい場合、またはソースコードへのアクセスなしに npm やランタイムの一般的な問題から復旧したい場合に使用します。
catc-client-ops
Catalyst Centerのクライアント操作・監視機能 - 有線・無線クライアントのリスト表示・フィルタリング、MACアドレスによる詳細なクライアント検索、クライアント数分析、時間軸での分析、SSIDおよび周波数帯によるフィルタリング、無線トラブルシューティング機能を提供します。MACアドレスやIPアドレスでのクライアント検索、サイト別やSSID別のクライアント数集計、無線周波数帯の分布分析、Wi-Fi信号の問題調査が必要な場合に活用できます。
ci-cd-and-automation
CI/CDパイプラインの設定を自動化します。ビルドおよびデプロイメントパイプラインの構築または変更時に使用できます。品質ゲートの自動化、CI内のテストランナー設定、またはデプロイメント戦略の確立が必要な場合に活用します。
shipping-and-launch
本番環境へのリリース準備を行います。本番環境へのデプロイ準備が必要な場合、リリース前チェックリストが必要な場合、監視機能の設定を行う場合、段階的なロールアウトを計画する場合、またはロールバック戦略が必要な場合に使用します。
linear-release-setup
Linear Releaseに向けたCI/CD設定を生成します。リリース追跡の設定、LinearのCIパイプライン構築、またはLinearリリースとのデプロイメント連携を実施する際に利用できます。GitHub Actions、GitLab CI、CircleCIなど複数のプラットフォームに対応しています。
tracking-application-response-times
API エンドポイント、データベースクエリ、サービスコール全体にわたるアプリケーションのレスポンスタイムを追跡・最適化できます。パフォーマンス監視やボトルネック特定の際に活用してください。「レスポンスタイムを追跡する」「API パフォーマンスを監視する」「遅延を分析する」といった表現で呼び出せます。