Google Container Registry
  • 20 Jan 2025
  • Dark
    Light
  • PDF

Google Container Registry

  • Dark
    Light
  • PDF

Article summary

Overview

the Google Container Registry (GCR) provides a basic solution for managing Docker container images used in data processing pipelines and custom model deployments. However, its limited support for artifact types and less granular security controls can restrict scalability and flexibility when integrating with Dataloop's advanced data operations. Since GCR only supports container images, managing diverse workflows on Dataloop may require additional configurations, and Google no longer actively enhances GCR, making it less suitable for evolving data and AI needs.

Dataloop integrates with Google Container Registry (GCR), a GCP service for storing private container images. While GCR offers robust features, Artifact Registry is the recommended GCP service for managing container images and other artifacts. Learn more.

Notice

Google Container Registry is being deprecated and will be shut down on March 18, 2025.

To integrate Google Container Registry (GCR) with the Dataloop platform, follow these steps:

  1. Create and Configure a GCP Google Container Registry
  2. Integrate GCR with the Dataloop Platform

Create and Configure a GCP Google Container Registry

Step 1: Set Up a GCP Project

If you don’t have an existing project:

  1. Go to the GCP Console.
  2. Go to the Project Selector.
  3. Click New Project.
  4. Provide a Project Name and select the Billing Account.
  5. Click Create.
  6. Set the project as active:
gcloud config set project [PROJECT_ID]

Step 2: Enable the Google Container Registry API

  1. Go to the GCP Console.
  2. Navigate to APIs & Services > Library.
  3. Search for Google Container Registry API.
  4. Click Enable.
  5. Enable billing for your GCP project by following the necessary steps.

Step 3: Configure Docker Authentication

  1. Install the Google Cloud CLI if you haven't already.
  2. Download gcloud CLI.
  3. Authenticate and configure Docker:
gcloud auth login
gcloud auth configure-docker

Step 4: Create and Push a Container Image

  1. Tag your Docker image:
docker tag [IMAGE_NAME] gcr.io/[PROJECT_ID]/[IMAGE_NAME]:[TAG]
  1. Push the image to GCR:
docker push gcr.io/[PROJECT_ID]/[IMAGE_NAME]:[TAG]
  1. Verify the image:
    1. Navigate to Container Registry in the GCP Console: https://console.cloud.google.com/gcr.
    2. Confirm that the image is visible in the registry.

Integrate GCR with the Dataloop Platform

Step 1: Generate a Service Account Key

Generate and download the key from the GCP console, then upload it to Dataloop using either the UI or SDK.

  1. Create a service account:
    1. Navigate to IAM & Admin > Service Accounts.
    2. Click Create Service Account.
    3. Provide a Name (e.g., dataloop-access) and click Create.
    4. Assign the following roles:
      1. Storage Object Viewer.
      2. Container Registry Viewer.
    5. Click Done.
  2. Generate a key for the service account:
    1. Find your service account in the list, and click to open.
    2. Select the Keys tab.
    3. Click Add Key > Create New Key.
    4. Select JSON and click Create.
    5. Save the JSON key file securely.

Step 2: Upload the Service Account Key to Dataloop

  1. Log in to your Dataloop Platform.
  2. Navigate to the Integrations page.
  3. Click Create Integration -> Create Registry Integration.
    1. Integration Name: Provide a name for the integration.
    2. Provider: Select GCP from the list.
      1. Service: Select Google Container Registry from the list.
      2. Click Import JSON file.
  4. Click Create Integration.

Step 3: Test the Configuration

  • In the Dataloop platform, try pulling or referencing a Docker image hosted in your GCR.
  • Ensure the integration is working without any errors.