Register a domain

Stay organized with collections Save and categorize content based on your preferences.

This page describes how to search for an available domain name and register the domain using Cloud Domains. Cloud Domains enables you to choose your DNS provider and customize your DNS settings. After you register your domain, Cloud Domains automatically renews your domain registration as long as your Cloud Billing account stays active.

Before you begin

Before you start using Cloud Domains to register your domains, follow these steps:

  1. In the Google Cloud console, go to the project selector page.

    Go to the project selector page

  2. Make sure that billing is enabled for your Cloud project. Learn how to check if billing is enabled on a project.

  3. Enable the API.

Register a domain

To register a domain, you must complete the following tasks:

  1. Search for a domain name.
  2. Configure DNS for the domain.
  3. Choose privacy settings for your domain.
  4. Specify contact details.
  5. Verify your contact information.

When registering a domain that is owned by a company, the registrant must provide the company's contact details, such as the email address and phone number. If the registrant provides their personal contact details, the company might lose access to the domain when the registrant leaves.

To register a domain, complete the following steps.

Console

  1. In the Google Cloud console, go to the Cloud Domains page.

    Go to Cloud Domains

  2. Click Register domain.
  3. Search for an available domain. Identify the domain name that you'd like to purchase. Pricing is listed for each available domain.
  4. Click Add. You can add as many domains as you like, subject to your available quota. For details, see the Quotas page. The total pricing based on your selection is calculated to the right. To remove a domain from your cart, click Delete next to the domain name.

  5. Click Continue.

  6. On the DNS configuration page, choose one of the following DNS providers for your name servers. If you are registering multiple domains, you can choose individual settings for each domain.

    DNS provider Description Cost
    Cloud DNS Google recommends that you use Cloud DNS as your DNS provider for all your name servers. Additional Cloud DNS charges apply. For details, see the Cloud DNS pricing page.
    Google Domains

    If you choose this option, you can use Cloud Domains to configure your name servers, and then use Google Domains to configure your DNS resource records.

    Note: Using Google Domains does not allow API access.

    No additional cost.
    Custom name servers If you choose this option, you can use Cloud Domains to configure your name servers, and then use a third-party DNS provider to configure your DNS resource records. Check with your DNS provider.

    1. If you choose Cloud DNS, from the Cloud DNS drop-down, select the default New zone that is automatically created for the domain. To edit the zone name and other details, select Setup new zone, make the required edits, and click Save and Continue.

      If you have already created a zone, Google Cloud chooses that zone by default.

    2. If you choose Google Domains, select whether you want to enable or disable DNSSEC. For more information on DNSSEC, see DNS Security.

    3. If you choose Custom name servers, enter at least two name servers. To add additional name servers, click Add another name server.

  7. Click Continue.

  8. By default, privacy protection is turned on. However, you can change the settings to one of the following privacy options:

    Privacy option Description
    Privacy protection on

    Choosing this option ensures that your contact information is not available to the public. To help protect your contact information and prevent spam, a third party provides alternate (proxy) contact information for your domain in the public directory. The third-party provider forwards all messages that are sent to your proxy contact information to the actual private contact information.

    Cloud Domains does not offer privacy protection for all domain endings or top-level domains (TLDs). Registries, the organizations that manage domain endings, have policies prohibiting the use of privacy protection for certain TLDs. To see privacy information for a specific TLD, click the TLD on the Supported TLD reference page. Privacy information for the TLD is available in the DNS reference section.

    Limit your info available to the public Choosing this option makes limited personal contact information available to the public. The actual information available publicly depends on the domain that you have chosen. To see privacy information for a specific TLD, click the TLD on the Supported TLD reference page. Privacy information for the TLD is available in the DNS reference section.
    Make all contact info public Choosing this option makes all your contact information available to the public through the WHOIS database.

  9. If you choose to make all contact information publicly available, you must click I agree on the pop-up dialog.

  10. Click Continue.

  11. Enter your contact information for the domain, which is necessary for ICANN to reach you if there are any problems. By default, your contact information applies to the registrant, technical and administrative contacts. To enter different information for each type of contact, you can edit your contact settings later.

  12. Click Register.

gcloud

  1. Search and check availability for a domain:

    • To search for an available domain, use the gcloud domains registrations search-domains command:

      gcloud domains registrations search-domains SEARCH_TERMS
      

      Replace SEARCH_TERMS with any non-empty string to search for a domain name—for example, example. It returns suggestions for possible domain names that you can register.

    • To check up-to-date availability for a domain name, and get the parameters needed to register a new domain, including price, availability, supported privacy modes and notices, use the gcloud domains registrations get-register-parameters command:

      gcloud domains registrations get-register-parameters DOMAIN_NAME
      

      Replace the following:

      • DOMAIN_NAME: the domain name that you want to check availability for— example, example.app.

      Your output looks similar to the following:

      availability: AVAILABLE
      domainName: example.app
      domainNotices:
      - HSTS_PRELOADED
      supportedPrivacy:
      - PRIVATE_CONTACT_DATA
      - PUBLIC_CONTACT_DATA
      yearlyPrice:
        currencyCode: USD
        units: '12'
        

  2. Create a managed public zone for your domain (optional):

    You can choose a DNS provider for your name servers based on the DNS provider options explained in the Overview. If you use Cloud DNS, you must first create a managed public zone for your domain.

    To create a new Cloud DNS managed zone for the domain, use the dns managed-zones create command:

    gcloud dns managed-zones create CLOUD_DNS_ZONE_NAME \
       --description="DESCRIPTION" \
       --dns-name=DOMAIN_NAME \
    

    Replace the following:

    • CLOUD_DNS_ZONE_NAME: a name for your zone
    • DESCRIPTION: a description for your zone
    • DOMAIN_NAME: the DNS domain name for your zone, like example.com
  3. Register the domain:

    To register the domain, use the gcloud domains registrations register command:

    gcloud domains registrations register DOMAIN_NAME
    

    Replace DOMAIN_NAME with the domain name that you want to register—for example, example.app.

    Your output looks similar to the following when you register a domain example.com using name servers provided by Cloud DNS:

    Yearly price: 12.00 USD
    Do you agree to pay this yearly price for your domain (y/N)?  y
    You can provide your DNS settings by specifying name servers, Cloud
    DNS Managed Zone name or by choosing free name servers provided by
    Google Domains
     [1] Provide name servers list
     [2] Provide Cloud DNS Managed Zone name
     [3] Use free name servers provided by Google Domains
    Please enter your numeric choice (2):  NAME_SERVER_CHOICE
    Cloud DNS Managed Zone name:  CLOUD_DNS_ZONE
    Cloud DNS Zone 'CLOUD_DNS_ZONE' is not signed. DNSSEC won't be enabled.
    Contact data not provided using the --contact-data-from-file flag.
    Do you want to enter it interactively (Y/n)?  y
    Full name:  NAME
    Organization (if applicable):  ORGANIZATION
    Email:  EMAIL_ADDRESS
    Enter phone number with country code, e.g. "+1.8005550123".
    Phone number:  PHONE_NUMBER
    Enter fax number with country code, e.g. "+1.8005550123".
    Fax number (if applicable):  FAX_NUMBER
    Enter two-letter Country / Region code, e.g. "US" or "PL".
    Refer to the guidelines for entering address field information at https://support.google.com/business/answer/6397478.
    Country / Region code:  COUNTRY_CODE
    Postal / ZIP code:  ZIP_CODE
    State / Administrative area (if applicable):  STATE
    City / Locality:  CITY
    Address Line 1:  ADDRESS_LINE_1
    Address Line 2 (if applicable):  ADDRESS_LINE_2
    Address Line 3 (if applicable):
    Specify contact privacy
     [1] private-contact-data
     [2] public-contact-data
    Please enter your numeric choice (1):  DATA_PRIVACY_CHOICE
    Waiting for 'operation-1597880129306-5ad437580410d-2c65d582-0861c5b7' to
    complete...done.
    Created registration [example.com] Note:
    The domain is not yet registered.
    Wait until the registration resource changes state to ACTIVE.
    
    Replace the following:

    • NAME_SERVER_CHOICE: choose the name server option based on your DNS provider choice. For DNS provider options, see the DNS providers section.
    • CLOUD_DNS_ZONE: the Cloud DNS managed zone name.
    • NAME: your full name—for example, Alice Smith.
    • ORGANIZATION: (optional) your organization—for example, Doe Corp.
    • EMAIL_ADDRESS: your email address for verification—for example alice@example.net.
    • PHONE_NUMBER: the phone number of the contact in international format—for example, +1-800-555-0123.
    • FAX_NUMBER: (optional) the phone number of the contact in international format—for example, +1-800-555-0123.
    • COUNTRY_CODE: the country or region code of the address—for example, US for United States.
    • ZIP_CODE: the postal code or ZIP code of the address—for example, 94043.
    • STATE: the state or administrative area of the address—for example, CA.
    • CITY: the city or locality of the address—for example, Mountain View.
    • ADDRESS_LINE_1: the first address line of the registrant—for example, 1599 Bayview Parkway. You can have up to 5 address lines but only the first one is required.
    • ADDRESS_LINE_2: (optional) the second address line of the registrant—for example, APT. 123.

    • DATA_PRIVACY_CHOICE: your data privacy choice. For detailed information about privacy options, see the Privacy protection section.

API

  1. To search for an available domain name, use the registrations.searchDomains method with an empty request body:

    GET https://domains.googleapis.com/v1/projects/PROJECT_ID/locations/global/registrations:searchDomains?query=SEARCH_TERM
    

    Replace the following:

    • PROJECT_ID: the ID of the project where the domain registration is created.
    • SEARCH_TERMS: any non-empty string to search for a domain name—for example, example. It returns suggestions for possible domain names that you can register.
  2. To check up-to-date availability for a domain name, and get the parameters needed to register a new domain, including price, availability, supported privacy modes and notices, use the registrations.retrieveRegisterParameters method with an empty body:

    GET https://domains.googleapis.com/v1/projects/PROJECT_ID/locations/global/registrations:retrieveRegisterParameters?domainName=DOMAIN_NAME
    
    Replace the following:

    • PROJECT_ID: the ID of the project where the managed zone is created
    • DOMAIN_NAME: the domain name that you want to check availability for—for example, example.app.

    The resulting response contains the yearlyPrice for the domain, which you need to use in the registrations.register API call.

  3. You can choose a DNS provider for your name servers based on the DNS provider options explained in the Overview.

    If you're using Cloud DNS as your DNS provider, to create a managed public DNS zone, use the managedZones.create method:

    POST https://dns.googleapis.com/dns/v1/projects/PROJECT_ID/managedZones
    {
     "name": "ZONE_NAME",
     "description": "DESCRIPTION",
     "dnsName": "DOMAIN_NAME.",
     "visibility": "public"
    }
    

    Replace the following:

    • PROJECT_ID: the ID of the project where the managed zone is created
    • ZONE_NAME: a name for your zone
    • DESCRIPTION: a description for your zone
    • DOMAIN_NAME.: the DNS suffix for your zone like example.com. Note that the trailing dot in the managedZones.create method is required.

    The resulting response contains a nameServers list that you must use in the registrations.register API call.

  4. To register the domain, use the registrations.register method:

    POST https://domains.googleapis.com/v1/projects/PROJECT_ID/locations/global/registrations:register
    {
     "registration": {
       "domainName": "DOMAIN_NAME",
       "dnsSettings": {
         "customDns": {
           "nameServers": [
             "NAME_SERVERS"
           ]
         }
       },
       "contactSettings": {
         "privacy": "CONTACT_PRIVACY",
         "registrantContact": {
           "postalAddress": {
             "regionCode": "REGION_CODE",
             "postalCode": "POSTAL_CODE",
             "administrativeArea": "SUBDIVISION",
             "locality": "CITY",
             "addressLines": [
               "ADDRESS"
             ],
             "recipients": [
               "CONTACT_NAME"
             ],
             "organization": "ORGANIZATION"
           },
           "email": "EMAIL_ADDRESS",
           "phoneNumber": "PHONE_NUMBER",
           "faxNumber": "FAX_NUMBER"
         },
         "adminContact": {
           "postalAddress": {
             "regionCode": "REGION_CODE",
             "postalCode": "POSTAL_CODE",
             "administrativeArea": "SUBDIVISION",
             "locality": "CITY",
             "addressLines": [
               "ADDRESS"
             ],
             "recipients": [
               "CONTACT_NAME"
             ],
             "organization": "ORGANIZATION"
           },
           "email": "EMAIL_ADDRESS",
           "phoneNumber": "PHONE_NUMBER",
           "faxNumber": "FAX_NUMBER"
         },
         "technicalContact": {
           "postalAddress": {
             "regionCode": "REGION_CODE",
             "postalCode": "POSTAL_CODE",
             "administrativeArea": "SUBDIVISION",
             "locality": "CITY",
             "addressLines": [
               "ADDRESS"
             ],
             "recipients": [
               "CONTACT_NAME"
             ],
             "organization": "ORGANIZATION"
           },
           "email": "EMAIL_ADDRESS",
           "phoneNumber": "PHONE_NUMBER",
           "faxNumber": "FAX_NUMBER"
         }
       }
     },
     "yearlyPrice": {
       "currencyCode": "CURRENCY_CODE",
       "units": NUMBER_OF_UNITS
     }
    }
    

    Replace the following:

    • PROJECT_ID: the ID of the project where you created the registration resource.
    • DOMAIN_NAME: the domain name that you want to register—for example, example.com.
    • NAME_SERVERS: the name servers you want to use. If you are using Cloud DNS, use the nameServers field output that you got from the managedZones.create.post API call.
    • CONTACT_PRIVACY: the preferred privacy setting for the contact data.

      For detailed information on the available privacy options, see Contact privacy.

    Replace the following values for the registrantContact, adminContact and technicalContact:

    For detailed information on each type of contact, see the Contact information section.

    • REGION_CODE: the region code of the address—for example, US for United States
    • POSTAL_CODE: the postal code of the address. For example, 94043
    • SUBDIVISION: the highest administrative subdivision of an address, like a state, a province, an oblast, or a prefecture—for example, CA for the state of California
    • CITY: the name of the city or town of the address—for example, Mountain View
    • ADDRESS: the lower levels of an address—for example, 1599 Amphitheater Parkway
    • CONTACT_NAME: the name of the contact
    • ORGANIZATION: (optional) the name of the organization that is registering the domain—for example, Doe Corporation
    • EMAIL_ADDRESS: the email address of the contact—for example, john@example.com
    • PHONE_NUMBER: the phone number of the contact in international format—for example, +1-800-555-0123
    • FAX_NUMBER: (optional) the fax number of the contact in international format—for example, +1-800-555-0123

    Values for the yearly price of the domain:

    This is the amount obtained from the yearlyPrice field in the registrations.retrieveRegisterParameters API call:

    • CURRENCY_CODE: the three-letter currency code as defined in ISO 4217—for example, USD.
    • NUMBER_OF_UNITS: the whole units of the amount—for example, if currencyCode is USD, then one unit is one US dollar.

Verify your contact information

After you register your domain, Cloud Domains sends a verification email to the address that you provided in your contact information for the domain. This email includes a subject line that states Action required: Please verify your email address.

You must verify your contact information within 15 days or your domain becomes inactive.

To verify your email address, follow these steps:

  1. Open the verification email from domains-noreply@google.com.
  2. Click Verify email now.

    After Cloud Domains verifies your contact information, a Google Domains page with the message that your email address has been verified is displayed.

    If there is an error in verifying your contact information, see the Troubleshooting section.

What's next