次の方法で共有


Azure Artifacts でユニバーサル パッケージを発行してダウンロードする

Azure DevOps Services

ユニバーサル パッケージを使用すると、開発者は NuGet、npm、Python パッケージなどの従来のパッケージ以外のさまざまな種類のパッケージを格納できます。Azure CLI を使用すると、コマンド ラインからユニバーサル パッケージを直接発行してダウンロードできます。 発行済みパッケージのサイズはさまざまですが、最大 4 TB に達する場合は、名前とバージョン番号を含めるという必須要件を常に維持する必要があります。 この記事では、Azure Artifacts フィードからユニバーサル パッケージを発行してダウンロードする手順について説明します。

前提 条件

フィードを作成する

フィードが既にある場合は、次のセクションに進むことができます。 それ以外の場合は、次の手順に従って新しい Azure Artifacts フィードを作成します。

  1. Azure DevOps 組織にサインインし、プロジェクトに移動します。

  2. [成果物 ]を選択し、次に[フィードの作成 ]を選択します。

  3. フィードのわかりやすい 名前 を指定し、その 可視性 (フィード内のパッケージを閲覧できる範囲) を設定します。 フィードの スコープの を定義し、パブリック レジストリのパッケージを含める場合は、[アップストリーム ソース ] チェック ボックスをオンにします。

  4. 完了したら [作成] を選択します。

    新しいフィードを作成する方法を示すスクリーンショット。

手記

新しく作成されたフィードでは、プロジェクトの Build Service ロールが既定で フィードおよびアップストリーム 閲覧者 (コラボレーター) として指定されます。

Azure DevOps 拡張機能をインストールする

CLI を使用すると、タスクを効率化できます。 続行する前に、Azure CLI (バージョン 2.10.1 以降) がインストールされていることを確認してください。 さらに、コマンド ラインから Azure DevOps サービスを管理するには、Azure DevOps 拡張機能をインストールする必要があります。

  1. 次のコマンドを実行して、Azure DevOps 拡張機能をインストールします。

    az extension add --name azure-devops
    
  2. Azure DevOps 拡張機能が既にインストールされていて、最新の拡張機能に更新する場合は、次のコマンドを実行します。

    az extension update --name azure-devops
    

フィードに接続する

  1. Azure DevOps 組織にサインインし、プロジェクトに移動します。

  2. [Artifacts] を選択し、ドロップダウン メニューからフィードを選択します。

  3. [フィードに接続する] を選択してから、左側のナビゲーション ペインから[ユニバーサル パッケージ] を選択します。

  4. Project のセットアップ セクションの手順に従ってフィードに接続します。

  1. 次のコマンドを実行して、Azure CLI にログインします。

    az login
    
  2. 次のコマンドを実行して、CLI の既定の構成としてプロジェクトと組織を設定します。

    az devops configure --defaults project=<YOUR_PROJECT_NAME> organization=https://dev.azure.com/<YOUR_ORGANIZATION_NAME> 
    

手記

組織でファイアウォールまたはプロキシ サーバーを使用している場合は、Azure Artifacts ドメイン URL と IP アドレス許可していることを確認します。

ユニバーサル パッケージの発行

ユニバーサル パッケージをフィードに発行するには、パッケージ名とバージョン番号を指定する必要があります。

パッケージ名は小文字で、先頭と末尾は英字または数字で、文字、数字、非連続ダッシュ、アンダースコア、ピリオドのみを含める必要があります。 パッケージのバージョンも小文字で、ビルド メタデータ (+ サフィックス) を含めないようにする必要があります。 詳細については、セマンティック バージョン管理 を参照してください。

  1. 次のコマンドを実行して、ユニバーサル パッケージをフィードに発行します。

    • 組織スコープのフィード:

      az artifacts universal publish --organization https://dev.azure.com/<YOUR_ORGANIZATION> --feed <FEED_NAME> --name <PACKAGE_NAME> --version <PACKAGE_VERSION> --path <PACKAGE_DIRECTORY> --description <PACKAGE_DESCRIPTION>
      
    • プロジェクト スコープのフィード:

      az artifacts universal publish --organization https://dev.azure.com/<YOUR_ORGANIZATION> --project <PROJECT_NAME> --scope project --feed <FEED_NAME> --name <PACKAGE_NAME> --version <PACKAGE_VERSION> --path <PACKAGE_DIRECTORY> --description <PACKAGE_DESCRIPTION>
      

手記

非常に多くのファイル (100,000 以上) を含むユニバーサル パッケージは、発行に失敗する可能性があります。 この場合、ファイル数を減らすために、ファイルを ZIP にバンドルするか、TAR アーカイブ することをお勧めします。

発行済みパッケージを表示する

  1. Azure DevOps 組織にサインインし、プロジェクトに移動します。

  2. [Artifacts] を選択し、ドロップダウン メニューからフィードを選択します。 発行プロセスが正常に完了したら、フィードでパッケージを使用できるようになります。

    新しく発行されたユニバーサル パッケージを示すスクリーンショット。

ユニバーサル パッケージのダウンロード

次のコマンドを実行して、Azure CLI を使用してフィードから特定のユニバーサル パッケージをダウンロードします。

  • 組織スコープのフィード:

    az artifacts universal download --organization https://dev.azure.com/<YOUR_ORGANIZATION_NAME> --feed <FEED_NAME> --name <PACKAGE_NAME> --version <PACKAGE_VERSION> --path <DOWNLOAD_PATH>
    
  • プロジェクト スコープのフィード:

    az artifacts universal download --organization https://dev.azure.com/<YOUR_ORGANIZATION_NAME> --project <PROJECT_NAME> --scope project --feed <FEED_NAME> --name <PACKAGE_NAME> --version <PACKAGE_VERSION> --path <DOWNLOAD_PATH>
    

特定のファイルをダウンロードする

特定のファイルのみをダウンロードする場合は、--file-filter パラメーターを使用してファイルのサブセットをフェッチします。 詳細については、「ファイル 一致パターンのリファレンス」を参照してください。

  • 組織スコープのフィード:

    az artifacts universal download --organization https://dev.azure.com/<YOUR_ORGANIZATION_NAME> --feed <FEED_NAME> --name <PACKAGE_NAME> --version <PACKAGE_VERSION> --path <DOWNLOAD_PATH> --file-filter <MATCH_PATTERN>
    
  • プロジェクト スコープのフィード:

    az artifacts universal download --organization https://dev.azure.com/<YOUR_ORGANIZATION_NAME> --project <PROJECT_NAME> --scope project --feed <FEED_NAME> --name <PACKAGE_NAME> --version <PACKAGE_VERSION> --path <DOWNLOAD_PATH> --file-filter <MATCH_PATTERN>
    

例: たとえば、--file-filter logs/.log を使用すると、ファイル名が "logs" を含み、拡張子が ".log" (たとえば、build_logs.log) で終わるファイルと一致します。

最新バージョンをダウンロードする

ワイルドカード * を使用して、ユニバーサル パッケージの最新バージョンをダウンロードできます。

:

  • --version '*': 最新バージョンをダウンロードします。

  • --version '1.*': メジャー 1 の最新バージョンをダウンロードします。

  • --version '1.2.*': メジャー 1 とマイナー 2 の最新のパッチ リリースをダウンロードします。

手記

ワイルドカード パターンは、プレリリース バージョン (バージョン番号にダッシュが付いたパッケージ) ではサポートされていません。