This document explains how to update your internal DNS policy to use zonal DNS for new projects. Zonal DNS improves application reliability by isolating outages within zones, preventing disruptions to critical services like instance creation and autohealing.
Before you begin
- 
  
  If you haven't already, set up authentication.
  Authentication verifies your identity for access to Google Cloud services and APIs. To run
  code or samples from a local development environment, you can authenticate to
  Compute Engine by selecting one of the following options:
  
    
    
      
    
  
    
    
      
    
  
    
    
      
    
  
 
  
 
  
    
      Select the tab for how you plan to use the samples on this page: ConsoleWhen you use the Google Cloud console to access Google Cloud services and APIs, you don't need to set up authentication. gcloud- 
 
  
  
  
    
    
  
    
    
  
    
    
      
    
  
  
    
    
  
    
    
  
    
    
  
  
  
   
    
      Install the Google Cloud CLI. After installation, initialize the Google Cloud CLI by running the following command: gcloud initIf you're using an external identity provider (IdP), you must first sign in to the gcloud CLI with your federated identity. 
- Set a default region and zone.
 RESTTo use the REST API samples on this page in a local development environment, you use the credentials you provide to the gcloud CLI. Install the Google Cloud CLI. After installation, initialize the Google Cloud CLI by running the following command: gcloud initIf you're using an external identity provider (IdP), you must first sign in to the gcloud CLI with your federated identity. For more information, see Authenticate for using REST in the Google Cloud authentication documentation. 
- 
 
  
  
  
    
    
  
    
    
  
    
    
      
    
  
  
    
    
  
    
    
  
    
    
  
  
  
   
    
      
Required roles
To get the permissions that you need to view organization wide internal dns usage and update the default policy, ask your administrator to grant you the following IAM roles:
- 
            Check the default global DNS policy:
              
  
  
    
      Organization Policy Administrator   (roles/orgpolicy.policyAdmin) on the folder or organization
- 
            Determine if a folder is ready to migrate to zonal DNS:
              
  
  
    
      Browser  (roles/browser) on the folder or organization
For more information about granting roles, see Manage access to projects, folders, and organizations.
These predefined roles contain the permissions required to view organization wide internal dns usage and update the default policy. To see the exact permissions that are required, expand the Required permissions section:
Required permissions
The following permissions are required to view organization wide internal dns usage and update the default policy:
- 
                Set an organization policy constraint:
                  orgpolicy.*
- 
                Determine if a folder is ready to migrate to zonal DNS:
                - 
                      resourcemanager.folders.get
- 
                      resourcemanager.folders.list
- 
                      resourcemanager.organizations.get
- 
                      resourcemanager.projects.get
- 
                      resourcemanager.projects.list
 
- 
                      
- 
                Check for global DNS names and VM metadata:
                  compute.projects.get
You might also be able to get these permissions with custom roles or other predefined roles.
Overview of the configuration
When you set an organization policy to override the default internal DNS type, newly created projects use zonal DNS by default. The organization policy doesn't impact existing projects where the Compute Engine API is already enabled. To switch existing projects to use zonal DNS, see switching existing projects to zonal DNS.
We recommend enforcing a zonal DNS policy at the organization level. This approach ensures that all new projects created within your organization will use zonal DNS, improving their reliability and resilience. However, you might need to exempt some folders from this organization-wide policy. Exempting folders is necessary when new projects within those folders depend on existing projects that are incompatible with zonal DNS.
The process of enforcing a zonal DNS policy at the organization level includes the following steps:
- Gather a list of projects and folders: Compile a list of all projects and their associated folders within your organization.
- Identify folders to exempt: Pinpoint the folders that contain the incompatible projects identified in the Step 1. These folders will need to be temporarily exempt from the zonal DNS policy.
- Set the organizational policy: Enforce the zonal DNS policy at the organizational level.
- Exempt specific folders: Apply exemptions to the folders identified in Step 3. This allows them to continue using global DNS while you address the incompatible projects within them.
This approach ensures that new projects utilize zonal DNS for enhanced reliability, while also accommodating existing dependencies on older projects that might not be ready for immediate migration.
Limitations
Enabling zonal DNS names across your entire organization applies zonal DNS settings to instances in other services, such as the following:
- App Engine flexible environment, Google Kubernetes Engine, and Containers running on Compute Engine
- Cloud SQL, Cloud Run functions, and Batch
- Dataproc and Dataflow
Review whether your applications use any of these services and use query analysis to identify compatibility issues with zonal DNS for the folders and projects associated with those applications.
Check if your organization uses Global DNS by default
The default DNS setting for your organization depends on two factors:
- The organization creation date: - Created after September 6, 2018: Your organization uses zonal DNS by default. No further action is needed.
- Created before September 6, 2018: Your organization uses global DNS by default. You should consider migrating to zonal DNS.
 
- The existence and enforcement of an organization policy constraint: - Even if your organization was created before September 6, 2018, an administrator might have enforced a policy to use zonal DNS for all new projects created within the organization. To check if such a policy exists, you can use the Google Cloud console or Google Cloud CLI. 
Console
- Go to the IAM & Admin>Identity & Organization page in the console. 
- Check the organization signup date.  
- If your organization was created before September 6, 2018, check if an organization policy constraint sets the default DNS type for all newly created projects to zonal DNS. - Go to the IAM & Admin>Organization Policies page in the Google Cloud console.
- In the Filter field, enter constraints/compute.setNewProjectDefaultToZonalDNSOnly.
- If the constraint is configured, click the name Sets the internal DNS setting for new projects to Zonal DNS Only.
- On the Policy details page, check the Status.
- If the status is Enforced, then the default internal DNS type is zonal DNS for all new projects created in the organization.
- Otherwise, the default DNS type for the project is still determined by the organization creation time.
 
- If the constraint wasn't configured for the organization, the default DNS type for the project is determined by the organization creation date.
 
gcloud
Use the organizations describe command
and the resource-manager org-policies list command
to determine the default DNS type for an organization.
- Check the organization - creationTimemetadata value.- gcloud organizations describe ORGANIZATION_ID - Replace ORGANIZATION_ID with either the organization ID number or the organization domain name. 
- If your organization was created before September 6, 2018, determine if an organization policy constraint is configured to set the default DNS type for all newly created projects to zonal DNS. - gcloud resource-manager org-policies list --organization=ORGANIZATION_ID \ --filter="constraints/compute" - In the output, look for - constraints/compute.setNewProjectDefaultToZonalDNSOnly.- If the constraint is present and StatusisEnforced, then all new projects created in the organization use zonal DNS by default.
- If the constraint isn't present or isn't enforced, the default DNS type is determined by the organization's creation date, as described in the first step.
 
- If the constraint is present and 
Determine which projects in a folder or organization use global DNS
To determine which projects are using global DNS, we recommend using BigQuery to create a table that lists the relative projects for your organization and their metadata. You can then use this table to run a query
- Create a BigQuery dataset.
- Export the asset metadata for your organization to a BigQuery table. - Make sure the Cloud Asset Inventory API is enabled.
- Configure the permissions that are required to use the Cloud Asset Inventory API.
- Use the following gcloud CLI command to export the - compute.googleapis.com/Projectasset:- gcloud asset export \ --content-type resource \ --organization 'ORGANIZATION_ID' \ --bigquery-table 'projects/PROJECT_ID/datasets/DATASET_ID/tables/TABLE_NAME' \ --asset-types='compute.googleapis.com/Project' \ --output-bigquery-force - Replace the following: - ORGANIZATION_ID: the organization ID number
- PROJECT_ID: the project ID
- DATASET_ID: the name of the BigQuery dataset
- TABLE_NAME: the table you're exporting your metadata to. If the table doesn't exist, BigQuery creates the table.
 
 
- Go to the BigQuery page in the Google Cloud console. 
- Select Compose a new query. 
- In the query editor text area, enter the following GoogleSQL query and then click Run. - SELECT JSON_VALUE(SAFE.PARSE_JSON(resource.data).vmDnsSetting) AS vmDnsSetting, count(*) as project_count FROM PROJECT_ID.DATASET_ID.TABLE_NAME GROUP BY 1 - Replace the following: - PROJECT_ID: the project ID
- DATASET_ID: the name of the BigQuery dataset
- TABLE_NAME: the table that contains the exported metadata, from Step 2.
 - Projects with the value - ZONAL_ONLYfor- vmDnsSettinghave zonal DNS configured. Otherwise, the projects use global DNS by default.
- Optional: For a detailed view of the - vmDnsSettingfor each project, enter the following GoogleSQL query and then click Run.- SELECT SUBSTR(name,35) as project_id, JSON_VALUE(SAFE.PARSE_JSON(resource.data).vmDnsSetting) AS vmDnsSetting FROM PROJECT_ID.DATASET_ID.TABLE_NAME 
Determine migration readiness of a folder
This step uses a bash script and the BigQuery table created in
the previous section to determine the migration readiness
of the folder.
- The folder is ready if all projects haven't made any queries that are incompatible with zonal DNS in the last 30 days.
- If a folder is not ready for migration, the script responds with the project IDs in the folder that are preventing the folder from being ready for migration. The projects in this result list are not yet compatible with zonal DNS and require additional action.
Complete the following steps:
- Get the folder ID. If you don't know the folder ID, do the following:
- In the Google Cloud console, go to the Managed resources page.
- Apply the filter Name:FOLDER_NAMEto get the folder ID.
 
- Query the BigQuery table with the exported - compute.Project assetsdata.- For the instructions on how to create the BigQuery table, see Determine which projects in a folder or organization use global DNS. - Enter the following GoogleSQL query and then click Run: - SELECT SUBSTR(name,35) AS project_id, FROM PROJECT_ID.DATASET_ID.TABLE_NAME WHERE CONTAINS_SUBSTR(ancestors, 'FOLDER_NUMBER') - Replace the following: - PROJECT_ID: the project ID
- DATASET_ID: the name of the BigQuery dataset
- TABLE_NAME: the table that contains the exported metadata
- FOLDER_NUMBER: the folder ID number
 
- Copy the project ID list and save it to a file. 
- Run the following - bashscript. The script iterates through the project IDs in the saved file to determine whether a folder is ready for migration.
#!/bin/bash
inaccessible_projects=()
unready_projects=()
for project in $(cat ~/FILENAME | tr '\n' ' '); do
  echo -e "Checking project $project..."
  ERROR=`curl -s --request POST "https://monitoring.googleapis.com/v3/projects/$project/timeSeries:query"   -H "Authorization: Bearer $(gcloud auth print-access-token)"   -H "Accept: application/json"   -H "Content-Type: application/json"   --data '{"query":"fetch compute.googleapis.com/Location | metric '"'"'compute.googleapis.com/global_dns/request_count'"'"' | filter metric.zonal_dns_readiness = '"'"'zonal_dns_risky'"'"' | every 30d | within 30d"}'   --compressed | jq --raw-output '.error'`
  if ! [[ "$ERROR" -eq "null" ]]; then
    inaccessible_projects+=($project)
    continue
  fi
  QUERY_COUNT=`curl -s --request POST "https://monitoring.googleapis.com/v3/projects/$project/timeSeries:query"   -H "Authorization: Bearer $(gcloud auth print-access-token)"   -H "Accept: application/json"   -H "Content-Type: application/json"   --data '{"query":"fetch compute.googleapis.com/Location | metric '"'"'compute.googleapis.com/global_dns/request_count'"'"' | filter metric.zonal_dns_readiness = '"'"'zonal_dns_risky'"'"' | every 30d | within 30d"}'   --compressed | jq --raw-output '.timeSeriesData[0].pointData[0].values[0].int64Value'`
  if [[ "$QUERY_COUNT" -ne "null" ]] && [[ "$QUERY_COUNT" -ne "0" ]]; then
    unready_projects+=($project)
  fi
done
error_len=${#inaccessible_projects[@]}
unready_len=${#unready_projects[@]}
echo -e "$error_len projects were inaccessible"
echo -e "$unready_len projects were not ready for migration"
if [ $error_len -ne 0 ]; then
  echo "Unable to access the following projects:"
  for project in "${inaccessible_projects[@]}"; do
    echo "$project"
  done
fi
if [ $unready_len -ne 0 ]; then
  echo "The following projects are not ready for migration:"
  for project in "${unready_projects[@]}"; do
    echo "$project"
  done
fi
if (( $error_len + $unready_len > 0 )); then
  echo "This folder is NOT ready for gDNS -> zDNS migration."
else
  echo "This folder is ready for gDNS -> zDNS migration."
fi
Replace FILENAME with the name of the file that you saved the project ID list in.
Convey the results of the migration readiness analysis with the project owners:
- For folders and projects that are safe to migrate, notify the project owners that they can begin to migrate ready projects.
- For folders that contain projects that aren't safe to migrate, instruct project owners to fix incompatible queries.
Exempt folders not ready to migrate to zonal DNS
To exempt a folder from the organization policy, complete the
following steps to set the enforcement option
for the policy at the folder level to Off.
- Sign in to the Google Cloud console as a Google Workspace or Cloud Identity super administrator.
- In the console, go to the Organization policies page. 
- Click Select, and then select the folders that you want to exempt from the organization policy. - The Google Cloud console displays a list of organization policy constraints for that folder on one or more pages. 
- To find the organization policy constraint that enforces zonal DNS: - Click Filter.
- Select Name.
- Set the filter name to Sets the internal DNS setting for new projects to Zonal DNS Only.
 
- Click the organization policy constraint name to open the Policy details page. 
- Click Edit. 
- On the Edit page, select Customize. 
- Under Enforcement, select Off to disable enforcement of the constraint. This means that the default internal DNS type for all projects in the folder are determined by the organization creation date. 
- Click Save. 
For more information about customizing organization policy constraints, see Customizing policies for boolean constraints in the Resource Manager documentation.
Enforce zonal DNS by default for new projects
Use the following steps to set the organization policy for a folder or organization.
- Sign in to the Google Cloud console as a Google Workspace or Cloud Identity super administrator. 
- In the console, go to the Organization policies page. 
- Select the folder or organization for which you want to view organization policies. The Google Cloud console displays a list of organization policy constraints that are available. The list might span multiple pages. 
- To find the policy to enforce zonal DNS, click Filter and select Name, then set the filter name to Sets the internal DNS setting for new projects to Zonal DNS Only. 
- Click the policy name to see its details. - The policy details page provides information about the constraint and how the constraint is applied. - By default, the enforcement is undefined for a folder or organization. However, if a parent folder has a defined enforcement, then the enforcement is inherited from the closest parent folder that has a defined enforcement. For more information, see Understanding hierarchy evaluation. 
- To customize the organization policy, click Edit. 
- In the edit page, select Customize. 
- Under Enforcement, select On. - This sets the default internal DNS type for all new projects in the organization to zonal DNS. 
- Click Save. 
To validate the organization policy change, you can create a new project under the folder or organization, then create and start a VM instance, and check whether your VM is enabled for zonal DNS.
If global DNS is needed to resolve a DNS name query built into your workload, you can rollback this change at the organization or folder level by disabling the enforcement.
Revert to using global DNS for an organization or folder
To revert an organization or folder to using global DNS, stop enforcement of the organizational policy for zonal DNS. Complete the following steps.
- Disable the organization policy - constraints/compute.setNewProjectDefaultToZonalDNSOnlyat the organization or folder level. For instructions on how to modify this policy, see Enforce zonal DNS by default for new projects.- Set the enforcement of Sets the internal DNS setting for new projects to Zonal DNS Only to Off. 
- If you want to revert to using global DNS for the entire organization, verify that none of the folders in the organization are enforcing the organization policy - constraints/compute.setNewProjectDefaultToZonalDNSOnly.
- To verify that global DNS is configured for your projects and instances, see Determine which projects in a folder or organization use global DNS. 
What's next
- Any existing projects that use global DNS must be migrated separately. For more information, see Update your projects to use zonal DNS.