Configure Cross-Cloud Auto-Fulfillment

If you want to automatically replicate the data product associated with your listing to other Snowflake regions, configure Cross-Cloud Auto-Fulfillment.

When auto-fulfillment is enabled for a listing, Snowflake automatically replicates your data product to consumer regions as needed. A data product is the share or application package that is attached to your listing.

By using auto-fulfillment, you can avoid manually replicating your data products and approving requests for your listings, helping consumers access your listings faster.

Note

Using Cross-Cloud Auto-Fulfillment in a Snowflake Native App with Snowpark Container Services is currently only supported on Amazon Web Services (AWS). See Known limitations with apps with containers for more information.

About Cross-Cloud Auto-Fulfillment

Cross-Cloud Auto-Fulfillment lets you offer a data product in any supported Snowflake region, based on the availability and access options you select for your listing, without having to manually replicate data.

You can configure and enable auto-fulfillment when a listing is in either draft or published state. When auto-fulfillment is enabled for a listing, Snowflake automatically fulfills your listing’s product to regions as needed.

How you make your data product available in other regions depends on your data product and how consumers access your listing:

  • If your data product is an application package, use auto-fulfillment to make your data product available in other regions.

  • If your data product is a share, use auto-fulfillment in most cases:

    • For free or limited trial listings on the Snowflake Marketplace, you can use Cross-Cloud Auto-Fulfillment or manually replicate the data.

    • For paid listings, you use auto-fulfillment.

    • For all listings shared with specific consumer accounts, Snowsight automatically detects whether or not the target account is in a different region and enables auto-fulfillment. You cannot manually replicate private listings to other regions.

When you make a data product available in other regions, you incur additional costs. See Manage Cross-Cloud Auto-Fulfillment costs.

How Cross-Cloud Auto-Fulfillment works

When you set up Cross-Cloud Auto-Fulfillment for your listing, Snowflake manages provisioning secure share areas and the replication of your data product to remote regions. If your data product already exists in the remote region, consumers in that region can get the data product instantly.

Your listing has a data product associated with it, either a share or an application package, and the data product contains objects from one or more databases, as well as application logic for an application package.

  • If your data product is a share, the entire database that contains the objects in your data product gets auto-fulfilled to other regions.

  • If your data product is an application package, the objects and logic in the application package, as well as objects referenced by the application package, are auto-fulfilled to other regions.

When your data product is auto-fulfilled to a remote region depends on how you make your listing available:

  • When you share a private listing, the database is auto-fulfilled after the specified consumers get your listing.

  • When you offer a listing on the Snowflake Marketplace, the database is auto-fulfilled to a region after a consumer in a specific region gets your listing.

When your data product is auto-fulfilled to a new region for the first time, the database (for a share) or data content and application logic (for an application package) is replicated to a secure share area in that region. The secure share area is managed by Snowflake. Multiple listings can use the same database, but the database is only replicated once to a new region.

After the initial replication of your data product to the secure share area in a region, changes to your data product are synced from your account based on the configured refresh frequency:

  • If your data product is a share, you set a refresh frequency when you configure Cross-Cloud Auto-Fulfillment for a listing. The refresh frequency applies to the database associated with the listing. If multiple listings share objects from the database, they share the same refresh frequency. The date and time of the refresh depends on when the first consumer requested the data product in a region.

  • If your data product is an application package, you set a refresh frequency at the account level that applies to every application package that you offer from your account.

After Cross-Cloud Auto-Fulfillment of a database occurs for a region, future requests made to database objects, even those associated with other listings, are fulfilled from the database in the secure share area. This keeps future refresh and replication costs lower. See Manage Cross-Cloud Auto-Fulfillment costs for more details about cost.

Considerations for auto-fulfillment

When you use auto-fulfillment for your listings, consider the following:

  • If you signed up for Snowflake using AWS Marketplace, GCP Marketplace, or Azure Marketplace, you can only create accounts and secure share areas in those clouds. Fulfilling listings to regions outside of your current cloud service region will fail.

  • Depending on the size of your data product, it can take some time for the data product to be available to the consumer. The size of your data product can also affect the cost of auto-fulfillment. See Manage Cross-Cloud Auto-Fulfillment costs for details about cost.

  • Snowflake Marketplace calculates compute costs for listing auto-fulfillment to VPS regions by using VPS rates. For details on VPS rates, see Snowflake Service Consumption Table.

  • You cannot use auto-fulfillment for listings in a data exchange. To replicate data to other regions for a data exchange, see Sharing Data Securely Across Regions and Cloud Platforms.

  • When a database is attached to a listing, it can support a single auto-fulfillment refresh type: object-level (SUB_DATABASE) or full database (FULL_DATABASE).

Note

Auto-fulfillment enforces a 10TB limit on the size of the database being replicated. When attaching a share to a listing, Snowsight checks the size of the database and returns an error if the size of data to be replicated is larger than 10TB. See Troubleshoot Cross-Cloud Auto-Fulfillment.

When the listing is auto-fulfilled, the consumer receives an error if the source data is larger than 10TB.

After assessing the cost implications, you can contact Snowflake Support to increase the size limit for a secure share area using a parameter. See INITIAL_REPLICATION_SIZE_LIMIT_IN_TB

Objects supported for auto-fulfillment

Only specific database objects are supported for auto-fulfillment. The database included in or referenced by your share or application package must contain only objects supported for auto-fulfillment.

Depending on your data product, different objects are supported:

Object

Share (Database)

Application package

Table

View

Materialized View

Secure view that references data stored in other databases using the REFERENCE_USAGE privilege.

Dynamic Table

✔ (only from the application package)

Database Roles

SQL UDF

✔ (when called from shared views in referenced databases)

Stored Procedure (not used by sharing)

Masking and Row Access Policies

Tags

Tasks (not used by sharing)

Alerts (not used by sharing)

Secrets (not used by sharing)

If an object on this list is designated as part of a failover group, it is not supported for auto-fulfillment. See Introduction to Replication and Failover.

If your data product contains objects other than the listed supported objects, you must update your data product or manually replicate your data. See Manually replicate data to fulfill a listing request.

Auto-fulfillment for objects that depend on account roles

Auto-fulfillment does not replicate account roles. Instead, objects in secure share areas are owned by the ACCOUNTADMIN role.

If your share or application package contains objects that depend on an account role, the object might work differently than you expect when shared with consumers. For example:

  • If you share a secure view that includes data protected by a policy using the INVOKER_ROLE context function, the policy might evaluate to a different value than in the provider account region because the view owner role is different.

  • If you share a secure view where the objects referenced by the view are restricted to an account role, such as a table where only the SECURITYADMIN role has SELECT privileges, the view might fail to expand when queried by a user without the SECURITYADMIN role in the provider account, but return results when queried by a user without the SECURITYADMIN role in the consumer account.

Instead of using account roles, use database roles. For more information, see Share data protected by a policy and IS_DATABASE_ROLE_IN_SESSION.

Support for auto-fulfillment in Virtual Private Snowflake (VPS)

By default, VPS does not permit data sharing outside of the VPS. VPS customers may choose to enable all accounts within their organization to receive data products from non-VPS customers using data sharing and collaboration, such as a listing shared with the VPS account.

When auto-fulfillment for VPS customers is enabled, all accounts within the VPS customer’s organization can be targeted for data sharing by the non-VPS customer specified by the VPS customer. VPS customers are not permitted to send data to other VPS or non-VPS customers via data sharing using auto-fulfillment.

To start receiving data from non-VPS customers, contact Snowflake Support and see Allow providers to share private listings into your VPS for more details.

Internal Snowflake objects created for auto-fulfillment

Snowflake creates the following internal objects to support Cross-Cloud Auto-Fulfillment:

Object Type

Name

Roles

SNOWFLAKE$GDS_RL

AUTO_FULFILLMENT_EXECUTOR

Database

SNOWFLAKE$GDS

Replication groups

Prefixed with SNOWFLAKE$GDS

These internal objects are used to perform tasks for auto-fulfillment, such as to create a secure share area in another region, and create a database to store objects used for auto-fulfillment, such as fulfillment tasks.

These internal objects appear when you run SHOW DATABASES, SHOW ROLES, or SHOW REPLICATION GROUPS respectively. Do not modify these objects or grant them to other users or roles.

Set up auto-fulfillment

When you configure a listing and make it available in a region other than your local region, or you share a private listing with consumer accounts in another region, you can enable auto-fulfillment. See Region availability (Marketplace listings only).

You must add a data product to your listing before you can set up auto-fulfillment. The steps to set up auto-fulfillment are different depending on the data product you offer and how you make your listing available.

Required privileges

To perform auto-fulfillment tasks, you must use one of the following roles:

Any role that you use must also have OWNERSHIP or MODIFY privileges on the listing.

Set up auto-fulfillment for a secure share data product shared on the Snowflake Marketplace

If your data product is a secure share that you publish to the Snowflake Marketplace using a listing, use the following steps to set up auto-fulfillment:

  1. Sign in to Snowsight.

  2. In the navigation menu, select Data Products » Provider Studio » Listings.

  3. Select the listing for which you want to set up auto-fulfillment.

  4. Select Region Availability » Edit.

  5. For Region availability, choose your desired availability.

    • By default, All regions is selected. Choosing all regions ensures the availability of your listing in any future regions added by Snowflake.

    • For paid listings, Custom regions is selected by default. Paid listings are only available in supported regions and any future supported regions added by Snowflake.

    • If your listing has specific regional limitations, change the region availability to Custom regions and select the regions in which you want to offer your data product.

      When you choose custom regions, your listing is visible in all current Snowflake Marketplace regions, but consumers can only get your data product in the regions you specify. Your listing will not be available in any new regions automatically.

  6. For Fulfillment method, Automatic fulfillment is the default selection. With Cross-Cloud Auto-Fulfillment, your data product is automatically fulfilled to a region and you incur costs only when there is consumer demand in that region.

    If you can’t use auto-fulfillment and the option is available, select Manual to manually replicate your data product. See Manually replicate data to fulfill a listing request.

  7. If you select Automatic for auto-fulfillment:

    1. Select a refresh frequency from the drop-down list, then enter a value. You must select a refresh frequency of at least 8 days.

    2. If you don’t have a default warehouse set, select a warehouse to use for auto-fulfillment.

    3. When you add a data product to your listing, Snowflake performs a compatibility check to validate that your data product can be auto-fulfilled to other regions. If the check returns any incompatibilities, you might need to update your data product. See Troubleshoot Cross-Cloud Auto-Fulfillment.

    4. Select Save and Enable Fulfillment.

      Auto-fulfillment for the listing is now enabled. The data product attached to the listing is not fulfilled to any regions until the listing is published and a consumer requests the data product. See How Cross-Cloud Auto-Fulfillment works.

  8. If you chose to manually fulfill the listing, select Save. Before publishing the listing, you must replicate data to each of the available regions you select. See Manually replicate data to fulfill a listing request.

Set up auto-fulfillment for an application package data product shared on the Snowflake Marketplace

If your data product is an application package that you publish to the Snowflake Marketplace with a listing, use the following steps to set up auto-fulfillment:

  1. Sign in to Snowsight.

  2. In the navigation menu, select Data Products » Provider Studio » Listings.

  3. Select the listing for which you want to set up auto-fulfillment.

  4. Select Region Availability » Edit.

  5. For Region availability, choose your desired availability.

    • By default, All regions is selected. Choosing all regions ensures the availability of your listing in any future regions added by Snowflake.

    • For paid listings, Custom regions is selected by default. Paid listings are only available in supported regions and any future supported regions added by Snowflake.

    • If your listing has specific regional limitations, change the region availability to Custom regions and select the regions in which you want to offer your data product.

      When you choose custom regions, your listing is visible in all current Snowflake Marketplace regions, but consumers can only get your data product in the regions you specify. Your listing will also not become automatically available in any new regions.

  6. Review the refresh frequency configured at the account level. If you need to use a different refresh frequency, see Set account-level refresh frequency.

  7. If you don’t have a default warehouse set, select a warehouse to use for auto-fulfillment.

  8. Select Save and Enable Fulfillment.

    Auto-fulfillment for the listing is now enabled. The data product attached to the listing is not fulfilled to any regions until the listing is published and a consumer requests the data product. See How Cross-Cloud Auto-Fulfillment works.

Set up auto-fulfillment using object-level replication

If you want to automatically replicate the data product associated with your listing to other Snowflake regions, configure Cross-Cloud Auto-Fulfillment. When auto-fulfillment is enabled for a listing, Snowflake automatically replicates your data product to remote regions as needed.

To help reduce costs and ease the manageability burden, you can use object-level (SUB_DATABASE) replication to let you choose to replicate only the tables and views in a data product to a remote region using auto-fulfillment.

About object-level replication

When you configure auto-fulfillment, object-level replication is used for supported objects. For a list of supported objects, see Objects supported for auto-fulfillment.

Diagram showing a consumer account in the AWS US East (Ohio) region getting a data product from the Snowflake Marketplace and then Snowflake initiating auto-fulfillment to replicate the data product to the Secure Share Area in the consumer region (AWS US East (Ohio)) from the provider account and region, AWS US West (Oregon). In this case, the data product is using object level replication so a share in the provider database, and only the objects in the share, are replicated to the Secure Share Area in AWS US East (Ohio), and when the consumer installs the data product they install it from the Secure Share Area in their region.
  1. The first consumer in a region gets the listing.

  2. Auto-fulfillment replicates the objects in the share to the Secure Share Area.

  3. Any consumer that gets the listing gets the data product from the Secure Share Area in their Snowflake region.

What gets replicated by object-level replication

When your data product is replicated using object-level replication, only the objects granted directly to the share or application, or referenced by a secure view in your share or application package, are replicated.

For example:

Object in data product

What is replicated

Table in a database and schema

Table

Secure view created from a table in the same database

Secure view and table

Table in a database that is already replicated by auto-fulfillment without object-level replication

Entire database

Set up object-level replication using Snowsight

You set up object-level replication when you set up the region availability (for a listing published on the Snowflake Marketplace) or when you add a consumer located in another region (for a listing shared privately).

  1. Create a listing. See Create and publish a listing.

  2. Add a data product that contains only supported objects.

  3. Set up regions or accounts to share with to start setting up auto-fulfillment:

    • For a listing published to the Snowflake Marketplace:

      1. Locate the Region Availability section and select Add.

      2. For Region availability, keep the default of All regions or select Custom regions for your listing.

    • For a listing shared privately, add a consumer account in a remote region.

  4. Select your preferred refresh frequency for updating the data product in remote regions.

  5. Publish your listing or save it as a draft.

Monitoring and managing auto-fulfillment settings

Manage your listing to monitor the regions where consumers are using your listing, monitor the cost of replication, and make changes to the refresh frequency for your listing.

Note

You must use a role with the Required privileges for configuring auto-fulfillment.

Manage other auto-fulfillment settings

To manage or monitor auto-fulfillment settings for your listing, do the following:

  1. Sign in to Snowsight.

  2. In the navigation menu, select Data Products » Provider Studio » Listings.

  3. Select the row for the listing that you want to manage.

  4. From the listing details page, access the auto-fulfillment settings:

    1. For a listing offered on the Snowflake Marketplace, in the Region Availability section, select Manage.

    2. For a listing offered to specific consumers, in the Consumer Accounts section, select .

  5. Select the option that you want to manage for your listing:

    • Select Manage Regions & Replication to see the regions where the listing is fulfilled and the status of auto-fulfillment. You can add or remove availability for a particular region or check the replication status.

      Select a region to see the timestamp of the last sync and how many consumers are accessing the data.

      If no consumers have accessed your listing’s product in a region, you can select Remove Region.

      If a consumer has accessed your listing’s product in a region, you cannot remove the region. Instead, if you want to remove your data product from that region, all consumers using the product must drop the database or application first, or you must delete the listing.

    • Select Update Refresh Frequency to update the refresh interval and frequency of your data product.

      The refresh frequency of an application package must be set at the account level. See Set account-level refresh frequency.

      The refresh frequency for a share is set at the listing level, but you can only specify one schedule for each database. If you have multiple shares attached to multiple listings that contain objects from the same database, updating the refresh frequency for one of the listings updates the refresh frequency for all other listings that use the same database.

      You cannot manage when a refresh occurs. Instead, the refresh schedule for a data product in a region is based on the date and time that a consumer in that region first requests your data product.

    • Select Monitor Replication Cost to monitor the costs related to fulfilling the data product to other regions. See Manage Cross-Cloud Auto-Fulfillment costs.

For more details about modifying listings, see Modify published listings.

Set account-level refresh frequency

If your data product is an application package that is auto-fulfilled to remote regions, updates to your product occur following a refresh frequency that you set at the account level.

If you have the ACCOUNTADMIN role, you can change the refresh frequency for the account using Snowsight or a SQL command. When you do this, you update the auto-fulfillment refresh frequency for every application package published by your account. This refresh frequency does not affect listings with shares attached.

Set refresh frequency using Snowsight

To set the refresh frequency for your application using Snowsight, you must use the ACCOUNTADMIN role and complete the following steps:

  1. Sign in to Snowsight.

  2. In the navigation menu, select Data Products » Provider Studio » Listings.

  3. Select the row for the listing that you want to manage.

  4. From the listing details page, access the auto-fulfillment settings:

    1. For a listing offered on the Snowflake Marketplace, in the Region Availability section, select Manage.

    2. For a listing offered to specific consumers, in the Consumer Accounts section, select .

  5. Select Update Refresh Frequency to update the refresh interval and frequency of your data product.

  6. Select a frequency at which to refresh your data product, such as every minute or up to once every 8 days.

    The refresh frequency you select affects all application packages published by your account. You can show all listings affected by the refresh frequency change before you make the change.

    You can specify the refresh frequency, but the scheduled time when the refresh occurs in a region is based on the date and time that a consumer in that region first requests your data product.

  7. Select Update to save the updated refresh frequency.

Set refresh frequency using SQL

To set the refresh frequency for your application using SQL, you must use the ACCOUNTADMIN role and run the following command:

ALTER ACCOUNT SET LISTING_AUTO_FULFILLMENT_REPLICATION_REFRESH_SCHEDULE = '<schedule>'
Copy

Where:

schedule:

The time interval at which to refresh the data product to other regions. Specify a time period in minutes, including the unit: MINUTES.

For example, to set the auto-fulfillment refresh frequency for every application package published by your account to every hour, run the following:

ALTER ACCOUNT SET LISTING_AUTO_FULFILLMENT_REPLICATION_REFRESH_SCHEDULE = '60 MINUTES'
Copy

Note

The refresh schedule for a data product in a region is based on the date and time that a consumer in that region first requests your data product.

Allow accounts to set up Cross-Cloud Auto-Fulfillment

If you are the organization administrator (i.e., if you are using the ORGADMIN role) for an account, delegate the privileges required to set up Cross-Cloud Auto-Fulfillment to the ACCOUNTADMIN role in the accounts in your organization.

After delegating privileges to the ACCOUNTADMIN role, the ACCOUNTADMIN role can grant the MANAGE LISTING AUTO FULFILLMENT privilege to other roles in the account. See About listing providers.

You can delegate the privileges, revoke the privileges, and determine if the privileges have been delegated to a specific account. You can only delegate privileges to other accounts in your organization.

Delegate privileges to set up Cross-Cloud Auto-Fulfillment

To enable users with the ACCOUNTADMIN role to set up Cross-Cloud Auto-Fulfillment, call the system function named SYSTEM$ENABLE_GLOBAL_DATA_SHARING_FOR_ACCOUNT. The arguments for this system function are described below.

Calling this system function requires the ORGADMIN role.

SELECT SYSTEM$ENABLE_GLOBAL_DATA_SHARING_FOR_ACCOUNT(
  '<account_name>'
  );
Copy

Where:

account_name

Specifies the name of the account in which to enable users with the ACCOUNTADMIN role to manage Cross-Cloud Auto-Fulfillment. See Account Identifiers.

Revoke privileges to set up Cross-Cloud Auto-Fulfillment

To prevent users with the ACCOUNTADMIN role from setting up Cross-Cloud Auto-Fulfillment, call the system function named SYSTEM$DISABLE_GLOBAL_DATA_SHARING_FOR_ACCOUNT. The arguments for this system function are described below.

Calling this system function requires the ORGADMIN role.

SELECT SYSTEM$DISABLE_GLOBAL_DATA_SHARING_FOR_ACCOUNT(
  '<account_name>'
  );
Copy

Where:

account_name

Specifies the name of the account in which to prevent users with the ACCOUNTADMIN role from manage Cross-Cloud Auto-Fulfillment. See Account Identifiers.

Check if an account can set up Cross-Cloud Auto-Fulfillment

To determine whether users with the ACCOUNTADMIN role in a specific account are permitted to set up Cross-Cloud Auto-Fulfillment, call the system function named SYSTEM$IS_GLOBAL_DATA_SHARING_ENABLED_FOR_ACCOUNT. The arguments for this system function are described below.

Calling this system function requires the ORGADMIN role.

SELECT SYSTEM$IS_GLOBAL_DATA_SHARING_ENABLED_FOR_ACCOUNT(
  '<account_name>'
  );
Copy

Where:

account_name

Specifies the name of the account for which you want to check if users with the ACCOUNTADMIN role can manage cross-cloud auto-fulfillment. See Account Identifiers.