Self-managed SSL certificates are certificates that you obtain, provision, and renew yourself. You can use this resource to secure communication between clients and your load balancer.
Self-managed certificates can be any combination of the following certificate types:
- Domain Validation (DV)
- Organization Validation (OV)
- Extended Validation (EV)
Self-managed certificates are supported with the following load balancers:
- Global certificates
- Global external Application Load Balancer
- Classic Application Load Balancer
- External proxy Network Load Balancer (with a target SSL proxy)
- Regional certificates
- Regional external Application Load Balancer
- Regional internal Application Load Balancer
This page describes the process of obtaining a valid Compute Engine certificate and then uploading your certificate to create a Google Cloud SSL certificate resource.
To create Google-managed certificates using Certificate Manager, see Deployment overview.
Before you begin
- Make sure that you are familiar with the SSL certificates overview.
- Make sure that you have the domain names that you want to use for your self-managed SSL certificate. If you're using Cloud Domains, see Step 1: Register a domain name using Cloud Domains.
Permissions
To perform the tasks in this guide, you must be able to create and modify SSL certificates in your project. You can do this if one of the following is true:
- You are a project Owner or
Editor (
roles/owner
orroles/editor
). - You have both the Compute Security Admin role
(
compute.securityAdmin
) and the Compute Network Admin role (compute.networkAdmin
) in the project. - You have a custom role for the project that includes the
compute.sslCertificates.*
permissions and one or both ofcompute.targetHttpsProxies.*
andcompute.targetSslProxies.*
, depending on the type of load balancer that you are using.
Step 1: Create a private key and certificate
If you already have a private key and a certificate from a certificate authority (CA), skip this section and go to Creating an SSL certificate resource.
Select or create a private key
A Google Cloud SSL certificate includes both a private key and the certificate itself, both in PEM format. Your private key must meet the following criteria:
- It must be in PEM format.
- It cannot be protected by a passphrase. Google Cloud stores your private key in its own encrypted format.
- Its encryption algorithm must be either RSA-2048 or ECDSA P-256.
To create a new private key, use one of the following OpenSSL commands.
Create an RSA-2048 private key:
openssl genrsa -out PRIVATE_KEY_FILE 2048
Create an ECDSA P-256 private key:
openssl ecparam -name prime256v1 -genkey -noout -out PRIVATE_KEY_FILE
Replace PRIVATE_KEY_FILE with the path and filename for the new private key file.
Create a certificate signing request (CSR)
After you have a private key, you can generate a certificate signing request (CSR) in the PEM format using OpenSSL. Your CSR must meet the following criteria:
- It must be in PEM format.
- It must have a common name (
CN
) or a subject alternative name (SAN
) attribute. Practically speaking, your certificate should contain bothCN
andSAN
attributes, even if it is for a single domain—modern clients, like the current versions of macOS and iOS don't rely on just theCN
attribute.
To create a CSR, follow these steps:
Create an OpenSSL configuration file. In the following example, subject alternative names are defined in the
[sans_list]
.cat <<'EOF' >CONFIG_FILE [req] default_bits = 2048 req_extensions = extension_requirements distinguished_name = dn_requirements prompt = no [extension_requirements] basicConstraints = CA:FALSE keyUsage = nonRepudiation, digitalSignature, keyEncipherment subjectAltName = @sans_list [dn_requirements] countryName = Country Name (2 letter code) stateOrProvinceName = State or Province Name (full name) localityName = Locality Name (eg, city) 0.organizationName = Organization Name (eg, company) organizationalUnitName = Organizational Unit Name (eg, section) commonName = Common Name (e.g. server FQDN or YOUR name) emailAddress = Email Address [sans_list] DNS.1 = SUBJECT_ALTERNATIVE_NAME_1 DNS.2 = SUBJECT_ALTERNATIVE_NAME_2 EOF
Run the following OpenSSL command to create a certificate signing request (CSR) file. The command is interactive; you are prompted for attributes except for the subject alternative names, which you defined in the
[sans_list]
of the CONFIG_FILE in the previous step.openssl req -new -key PRIVATE_KEY_FILE \ -out CSR_FILE \ -config CONFIG_FILE
For both steps, replace the following:
- CONFIG_FILE: the path, including the filename, for the OpenSSL configuration file (you can delete the file after you complete this procedure)
SUBJECT_ALTERNATIVE_NAME_1 and SUBJECT_ALTERNATIVE_NAME_2: Subject Alternative Names for your certificate
If your certificate is only for one hostname, you should only define a single subject alternative name that matches the Common Name. If you need more than two subject alternative names, add them to the configuration file, incrementing the number after
DNS
(DNS.3
,DNS.4
, etc.).PRIVATE_KEY_FILE: the path to the private key file
CSR_FILE: the path, including the filename, for the CSR
Sign the CSR
When a Certificate Authority (CA) signs your CSR, it uses its own private key to create a certificate. Use one of the following methods to sign the CSR:
Use a publicly trusted CA
If you request a publicly trusted CA to sign your CSR, the resulting certificate is trusted by all clients that trust that public CA. To produce a signed certificate, the public CA only needs your CSR.
Use your own internal CA
If you manage your own CA, you can use it to sign your CSR. Using your CA to sign your CSR creates an internally trusted certificate when your clients have also been configured to trust your own CA.
Use a self-signed certificate
If you use the same private key that you used to create the CSR to sign the CSR, then you've created a self-signed certificate. You should only use self-signed certificates for testing.
Google Cloud doesn't support client-side verification for self-signed server certificates. Therefore, you must configure the client to skip certificate validation. For example, you can create a web browser client that displays a message asking you if you want to trust a self-signed certificate.
If you manage your own CA, or if you want to create a self-signed certificate for testing, you can use the following OpenSSL command:
openssl x509 -req \ -signkey PRIVATE_KEY_FILE \ -in CSR_FILE \ -out CERTIFICATE_FILE \ -extfile CONFIG_FILE \ -extensions extension_requirements \ -days TERM
Replace the following:
- PRIVATE_KEY_FILE: the path to the private key for your CA; if creating a self-signed certificate for testing, this private key is the same as the one used to create the CSR
- CSR_FILE: the path to the CSR
- CERTIFICATE_FILE: the path to the certificate file to create
- TERM: the number of days, from now, during which the certificate should be considered valid by clients that verify it
Wildcards in common names
Your self-managed SSL certificates can use a wildcard in the common name. For
example, a certificate with the common name *.example.com.
matches the
hostnames www.example.com
and foo.example.com
, but not a.b.example.com
or
example.com
. When the load balancer selects a certificate, it always prefers
to match a hostname to certificates without wildcards over certificates with
wildcards.
Certificates with wildcard fragments, such as f*.example.com
, aren't
supported.
Step 2: Create a self-managed SSL certificate resource
Before you can create a Google Cloud SSL certificate resource, you must have a private key and certificate. Refer to Creating a private key and certificate if you have not already created or obtained them.
After creating a certificate, you can't change its scope from global to regional, or from regional to global.
Console
You can work with global SSL certificates on the Classic Certificates tab
in the Google Cloud console.
Regional SSL certificates cannot be created in the Google Cloud console.
Use either gcloud
or the REST API.
- Go to the Classic Certificate tab in the Google Cloud console.
Go to Classic Certificates - Click Create SSL certificate.
- Enter a name and an optional description for the certificate.
- Select Upload my certificate.
- Paste in your certificate or click Upload to navigate to your
certificate file.
You can choose to include the CA certificate chain in the same file as the certificate. Google Cloud does not validate the certificate chain for you – validation is your responsibility. - Paste in your private key or click Upload to navigate to your private key file.
- Click Create.
gcloud
To create a global SSL certificate, use the gcloud compute ssl-certificates
create
command
with the --global
flag:
gcloud compute ssl-certificates create CERTIFICATE_NAME \ --certificate=CERTIFICATE_FILE \ --private-key=PRIVATE_KEY_FILE \ --global
To create a regional SSL certificate,
use the gcloud compute ssl-certificates
create
command with
the --region
flag:
gcloud compute ssl-certificates create CERTIFICATE_NAME \ --certificate=CERTIFICATE_FILE \ --private-key=PRIVATE_KEY_FILE \ --region=REGION
Replace the following:
- CERTIFICATE_NAME: the name of the certificate resource to create
CERTIFICATE_FILE: the path to a PEM-formatted certificate file
You can choose to include the CA certificate chain in the same file as the certificate. Google Cloud does not validate the certificate chain for you—validation is your responsibility.
PRIVATE_KEY_FILE: the path to a PEM-formatted private key; the private key cannot be protected by a passphrase
REGION: if applicable, the region for the regional SSL certificate
If this certificate resource is for either an internal Application Load Balancer or a regional external Application Load Balancer, the region must be the same as the region of the load balancer.
API
To use the API methods, you must first read the certificate and private key files because the API request must send the contents of the files.
Read the certificate and private key files, and then create the SSL certificate. The following examples show how to do this with Python.
For global SSL certificates, use the sslCertificates.insert API method:
For regional SSL certificates, use the regionSslCertificates.insert API method:
For additional code samples, see the API reference page.
Step 3: Associate an SSL certificate with a target proxy
You must associate at least one SSL certificate with each target HTTPS or SSL proxy. You can configure the target proxy with up to the maximum number of SSL certificates per target HTTPS or target SSL proxy. You can reference multiple self-managed certificates on the same target proxy.
Console
When you use the Google Cloud console to edit an existing load balancer, you automatically associate the SSL certificate with the appropriate target proxy.
gcloud
To associate a global SSL certificate with a target HTTPS proxy,
use the gcloud compute target-https-proxies
update
command
with the --global
and --global-ssl-certificates
flags:
gcloud compute target-https-proxies update TARGET_PROXY_NAME \ --global \ --ssl-certificates=SSL_CERTIFICATE_LIST \ --global-ssl-certificates
To associate a global SSL certificate with a target SSL proxy,
use the gcloud compute target-ssl-proxies
update
command:
gcloud compute target-ssl-proxies update TARGET_PROXY_NAME \ --ssl-certificates=SSL_CERTIFICATE_LIST
To associate a regional SSL certificate with a target HTTPS proxy,
use the gcloud compute target-https-proxies
update
command
with the --region
and --ssl-certificates-region
flags:
gcloud compute target-https-proxies update TARGET_PROXY_NAME \ --region=REGION \ --ssl-certificates=SSL_CERTIFICATE_LIST \ --ssl-certificates-region=REGION
Replace the following:
TARGET_PROXY_NAME
: the name of the load balancer's target proxyREGION
(if applicable): the region for the regional target proxy and regional SSL certificate; the regions must matchSSL_CERTIFICATE_LIST
: a comma-delimited list of Google Cloud SSL certificate namesMake sure that the list of referenced certificates includes all older valid SSL certificates as well as the new SSL certificate. The
gcloud compute target-ssl-proxies update
command overrides the original values for--ssl-certificates
with the new value.
API
To associate a global SSL certificate with a target HTTPS proxy, make a POST
request to the
targetHttpsProxies.insert
method, replacing PROJECT_ID
with your project ID.
POST https://compute.googleapis.com/compute/v1/projects/PROJECT_ID/global/targetHttpsProxy { "name": "l7-xlb-proxy", "urlMap": "projects/PROJECT_ID/global/urlMaps/l7-xlb-map", "sslCertificates": /projectsPROJECT_IDglobal/sslCertificates/SSL_CERT_NAME }
To associate a global SSL certificate with a target HTTPS proxy, make a POST
request to the
targetSslProxies.insert
method, replacing PROJECT_ID
with your project ID.
POST https://compute.googleapis.com/compute/v1/projects/PROJECT_ID/global/targetSslProxy { "name": "l7-ssl-proxy", "sslCertificates": /projectsPROJECT_IDglobal/sslCertificates/SSL_CERT_NAME }
To associate a regional SSL certificate with a target HTTPS proxy, make a POST
request to the
targetHttpsProxies.insert
method, replacing PROJECT_ID
with your project ID.
POST https://compute.googleapis.com/compute/v1/projects/PROJECT_ID/global/targetHttpsProxy { "name": "l7-xlb-proxy", "urlMap": "projects/PROJECT_ID/global/urlMaps/l7-ilb-map", "region": "us-west1" "sslCertificates": /projectsPROJECT_IDregions/us-west1/sslCertificates/SSL_CERT_NAME }
Step 4: Update the DNS A and AAAA records to point to the load balancer's IP address
At your registrar's site, DNS host, or ISP (wherever your DNS records are managed), add or update the DNS A records (for IPv4) and DNS AAAA records (for IPv6) for your domains and any subdomains so that they point to the IP address associated with the load balancer's forwarding rule or rules.
If you're using Cloud DNS and Cloud Domains, set up your domains and update your name servers.
If you're using multiple domains for a single certificate, you must add or update DNS records for all of the domains and any subdomains so that they all point to your load balancer's IP address.
After waiting for DNS propagation to
complete,
you can verify your setup by running the dig
command. For example,
suppose your domain is www.example.com
. Run the following dig
command:
dig www.example.com
; <<>> DiG 9.10.6 <<>> www.example.com ;; global options: +cmd ;; Got answer: ;; ->>HEADER<<- opcode: QUERY, status: NOERROR, id: 31748 ;; flags: qr rd ra; QUERY: 1, ANSWER: 4, AUTHORITY: 0, ADDITIONAL: 1 ;; OPT PSEUDOSECTION: ; EDNS: version: 0, flags:; udp: 512 ;; QUESTION SECTION: ;www.example.com. IN A ;; ANSWER SECTION: www.example.com. 1742 IN CNAME www.example.com.edgekey.net. www.example.com.edgekey.net. 21330 IN CNAME www.example.com.edgekey.net.globalredir.akadns.net. www.example.com.edgekey.net.globalredir.akadns.net. 3356 IN CNAME e6858.dsce9.akamaiedge.net. e6858.dsce9.akamaiedge.net. 19 IN A 203.0.113.5 ;; Query time: 43 msec ;; SERVER: 8.8.8.8#53(8.8.8.8) ;; WHEN: Wed Jun 03 16:54:44 PDT 2020 ;; MSG SIZE rcvd: 193
In this example, 203.0.113.5
is your load balancer's IP address.
Step 5: Test with OpenSSL
It can take up to 30 minutes for your load balancer to begin using your self-managed SSL certificate.
To test, run the following OpenSSL command, replacing DOMAIN with your DNS name and IP_ADDRESS with the IP address of your load balancer.
echo | openssl s_client -showcerts -servername DOMAIN -connect IP_ADDRESS:443 -verify 99 -verify_return_error
This command outputs the certificates that the load balancer presents
to the client. Along with other detailed information, the output should
include the certificate chain and Verify return code: 0 (ok)
.
Work with self-managed SSL certificates
The following sections describe how to list, view, delete, and replace SSL certificate resources.
List SSL certificates
Console
You can check the status of your global SSL certificates on the
Classic Certificates tab on the Certificate Manager page.
Regional SSL certificates cannot be maintained in the Google Cloud console.
Use either gcloud
or the REST API.
- Go to the Classic Certificates tab in the Google Cloud console.
Go to Classic Certificates - (Optional) Filter the list of SSL certificates.
gcloud
To list global SSL certificates, use the gcloud compute ssl-certificates
list
command with the
--global
flag:
gcloud compute ssl-certificates list \ --global
To list regional SSL certificates, use
the gcloud compute ssl-certificates
list
command with the
region
filter:
gcloud compute ssl-certificates list \ --filter="region:(REGION ...)"
Replace the following:
- REGION: a Google Cloud region; include multiple regions as a space-separated list
Describe SSL certificates
Console
You can view additional details about your global SSL certificates on the Classic Certificates tab on the Certificate Manager page.
- Go to the Classic Certificates page in the Google Cloud console.
Go to Classic Certificates - (Optional) Filter the list of SSL certificates.
- To view more details, click the certificate name.
gcloud
To describe a global SSL certificate,
use the gcloud compute ssl-certificates
describe
command
with the --global
flag:
gcloud compute ssl-certificates describe CERTIFICATE_NAME \ --global
To describe a regional SSL certificate, use the gcloud compute ssl-certificates
describe
command
with the --region
flag:
gcloud compute ssl-certificates describe CERTIFICATE_NAME \ --region=REGION
Replace the following:
- CERTIFICATE_NAME: the name of the SSL certificate
- REGION: a Google Cloud region
Delete SSL certificates
Before you can delete an SSL certificate, you must first update each target proxy
that references the certificate. For each target proxy, run the appropriate
gcloud update
command to update the target proxy's
SSL_CERTIFICATE_LIST such that it no longer includes the SSL certificate
that you need to delete. Each target SSL proxy or target HTTPS proxy must
reference at least one SSL certificate.
After you update the target proxy, you can delete the SSL certificate.
Console
You can delete global SSL certificates on the Classic Certificates tab on the Certificate Manager page.
- Go to the Classic Certificates tab in the Google Cloud console.
Go to Classic Certificates - Select the SSL certificate that you want to delete.
- Click Delete.
- To confirm, click Delete again.
gcloud
To delete a global SSL certificate, use the gcloud compute ssl-certificates
delete
command
with the --global
command:
gcloud compute ssl-certificates delete CERTIFICATE_NAME \ --global
To delete a regional SSL certificate, use the
gcloud compute ssl-certificates
delete
command
with the --region
command:
gcloud compute ssl-certificates delete CERTIFICATE_NAME \ --region=REGION
Replace the following:
- CERTIFICATE_NAME: the name of the SSL certificate
- REGION: a Google Cloud region
Replace or renew an SSL certificate before it expires
Follow these steps if you need to replace, renew, or rotate an SSL certificate:
Run the
gcloud compute ssl-certificates describe
command for the current certificate, to check if it's about to expire.Create a new SSL certificate resource. The new SSL certificate must have a unique name within the project.
Update the target proxy to detach the old SSL certificate and add the new one. Make sure to include any other existing SSL certificates that you want to retain.
To help avoid downtime, run a single
gcloud
command with the--ssl-certificates
flag. For example:For global external Application Load Balancers:
Use the
gcloud compute target-https-proxies update
command with the--global
flag.gcloud compute target-https-proxies update TARGET_PROXY_NAME \ --global \ --ssl-certificates=new-ssl-cert,other-certificates \ --global-ssl-certificates
For regional external Application Load Balancers and regional internal Application Load Balancers:
Use the
gcloud compute target-https-proxies update
command with the--region
flag.gcloud compute target-https-proxies update TARGET_PROXY_NAME \ --region=REGION \ --ssl-certificates=new-ssl-cert,other-certificates \ --ssl-certificates-region=REGION
For external proxy Network Load Balancers:
Use the
gcloud compute target-ssl-proxies update
command with the--backend-service
flag.gcloud compute target-ssl-proxies update TARGET_PROXY_NAME \ --ssl-certificates=new-ssl-cert,other-certificates
Verify that the load balancer is serving the replacement certificate by running the following OpenSSL command:
echo | openssl s_client -showcerts -connect IP_ADDRESS:443 -verify 99 -verify_return_error
Wait 15 minutes to ensure that the replacement operation has propagated to all Google Front Ends (GFEs).
(Optional) Delete the old SSL certificate.
Rotate SSL certificates periodically
This sample solution periodically checks the status of certificates used with Google Cloud load balancers and rotates certificates when they reach a given percentage of their lifetime. The tool uses CAs configured by using the Certificate Authority Service.
This solution works with the following load balancers:
- Global external Application Load Balancer
- Classic Application Load Balancer
- Regional external Application Load Balancer
- Internal Application Load Balancer
- External proxy Network Load Balancer with an SSL proxy
What's next
- To troubleshoot SSL certificates, see Troubleshooting SSL certificates.