Workflow: Develop an app with containers

This topic describes the general workflow for creating a Snowflake Native App with Snowpark Container Services.

Understand Snowpark Container Services and the Snowflake Native App Framework

Before beginning to develop a Snowflake Native App with Snowpark Container Services

  1. Ensure that you are familiar with Snowpark Container Services and the Snowflake Native App Framework.

    The following tutorials are available for these Snowflake products:

  2. Review About Snowflake Native Apps with Snowpark Container Services to understand how Snowflake Native App with Snowpark Container Services works.

  3. Review Costs associated with apps with containers to understand the costs associated with developing, publishing, and using an app with containers.

Create the containers and services to be managed by an app.

The first step in developing an app with containers is to set up the required containers and services using Snowpark Container Services.

The basic workflow for using Snowpark Container Services is:

  1. Create a repository to store container images.

    This repository exists in the provider account and maintains the container images required by the app. See Create an image repository

  2. Copy the container images to the image repository.

    After creating the image repository, providers must upload the container images used by the application. Snowpark Container Services support using Docker commands to perform the upload.

    See Upload container images to the image repository for more information.

  3. Create a service specification file.

    The service specification file is a YAML file used to configure and run services within Snowpark Container Services. Snowflake Native App with Snowpark Container Services includes this file within the application package.

    See Create the service specification file for more information.

  4. Configure block storage and snapshots.

    If the services in your app require using block storage, create a spec.volumes in your service specification file.

    See Using block storage volumes with services for more information.

  5. Upload the required files to a stage.

    To make the service specification file accessible to the application package, providers must upload it to the stage used to store other files required by the application package.

    See Staging data files from a local file system and Staging files using Snowsight for more information on uploading files to a stage.

    Note

    If you are using the Snowflake CLI, you are not required to upload the files to a stage.

Develop and publish a Snowflake Native App with Snowpark Container Services

The workflow for developing and publishing an app with containers is similar to the workflow for any Snowflake Native App. However, within each stage of the workflow there are differences.

The following is a typical workflow for developing and publishing an app with containers:

  1. Create the manifest file for the app.

    The manifest file for an app with containers includes configuration information about the containers included in the app. See Create the manifest file for an app with containers for more information.

  2. Create the setup script for the app.

    The specific contents of the setup script depend on the requirements of the app. For general information on creating the setup script for an app, see Create a setup script.

    Within the setup script you can create the following objects that are specific to a Snowflake Native App with Snowpark Container Services:

    You can also add other objects that are part of any Snowflake Native App, including:

    • Warehouses

    • External access integrations

    • Secrets

  3. Create the application package.

    The process of creating an application package for an app with containers is the same as other apps. See Create an application package for more information.

  4. Publish the app

    Publishing an app as a private listing or on the Snowflake Marketplace is the same as other apps. See Share an app with consumers for more information.