gcloud - SSL CERTIFICATE_VERIFY_FAILED
gcloud - SSL CERTIFICATE_VERIFY_FAILED
Command:
gcloud info –run-diagnostics
Error Messages:
1
2
3
4
5
6
7
8
9
10
11
12
ERROR: Reachability Check failed.
httplib2 cannot reach https://cloudresourcemanager.googleapis.com/v1beta1/projects:
[SSL: CERTIFICATE_VERIFY_FAILED] certificate verify failed: unable to get local issuer certificate (_ssl.c:1000)
httplib2 cannot reach https://www.googleapis.com/auth/cloud-platform:
[SSL: CERTIFICATE_VERIFY_FAILED] certificate verify failed: unable to get local issuer certificate (_ssl.c:1000)
requests cannot reach https://cloudresourcemanager.googleapis.com/v1beta1/projects:
HTTPSConnectionPool(host='cloudresourcemanager.googleapis.com', port=443): Max retries exceeded with url: /v1beta1/projects (Caused by SSLError(SSLCertVerificationError(1, '[SSL: CERTIFICATE_VERIFY_FAILED] certificate verify failed: unable to get local issuer certificate (_ssl.c:1000)')))
requests cannot reach https://www.googleapis.com/auth/cloud-platform:
HTTPSConnectionPool(host='www.googleapis.com', port=443): Max retries exceeded with url: /auth/cloud-platform (Caused by SSLError(SSLCertVerificationError(1, '[SSL: CERTIFICATE_VERIFY_FAILED] certificate verify failed: unable to get local issuer certificate (_ssl.c:1000)')))
System Configuration:
- Operating System: MacOS
What steps resulted in this error?
- Initializing the gcloud cli
1
gcloud info --run-diagnostics
What does this error mean?
- The error you are encountering suggests that your gcloud command-line tool is having trouble verifying the SSL certificate for the Google Cloud Platform endpoint.
Why did this error occur?
- The SSL certificate verification process has failed because the local system could not verify the certificate of the server.
- This is a common issue when using corporate networks or private certificates that are not included in the default certificate store.
Solution
- Follow the below steps to resolve the issue:
- Obtain the Corporate Certificate:
- Ensure you have the corporate certificate file, typically with a .crt or .pem extension.
- Locate the Python installation Directory:
1 2
which python /opt/anaconda3/bin/python
- Copy the Corporate Certificate to default CA certificate of Conda Environment (similar approach can be used for other python environment):
- Copy your corporate certificate to the Conda environment’s ssl directory. Assuming your Conda base environment is in /Users/your-username/anaconda3, you would do something like this:
1
sudo cat /path/to/CorportaCACertificate.pem >> /opt/anaconda3/ssl/cacert.pem
- Copy your corporate certificate to the Conda environment’s ssl directory. Assuming your Conda base environment is in /Users/your-username/anaconda3, you would do something like this:
- Configure gcloud to use the Conda python environment and set the environmental variable for requests and httplib
1 2 3 4
export CLOUDSDK_PYTHON=/opt/anaconda3/bin/python3 export CURL_CA_BUNDLE=/opt/anaconda3/ssl/cacert.pem export HTTPLIB2_CA_CERTS=/opt/anaconda3/ssl/cacert.pem export REQUESTS_CA_BUNDLE=/opt/anaconda3/ssl/cacert.pem
- Persist the Configuration:
- To make sure the configuration is persistent across shell sessions, add the environment variable to your shell profile (e.g., .zshrc, .bashrc, or .bash_profile):
1 2 3 4 5
echo 'export CLOUDSDK_PYTHON=/opt/anaconda3/bin/python3' >> ~/.zshrc echo 'export CURL_CA_BUNDLE=/opt/anaconda3/ssl/cacert.pem' >> ~/.zshrc echo 'export HTTPLIB2_CA_CERTS=/opt/anaconda3/ssl/cacert.pem' >> ~/.zshrc echo 'export REQUESTS_CA_BUNDLE=/opt/anaconda3/ssl/cacert.pem' >> ~/.zshrc source ~/.zshrc
- To make sure the configuration is persistent across shell sessions, add the environment variable to your shell profile (e.g., .zshrc, .bashrc, or .bash_profile):
- Verify the Configuration:
- Ensure the environment variable is set correctly:
1 2 3 4
echo $CLOUDSDK_PYTHON echo $CURL_CA_BUNDLE echo $HTTPLIB2_CA_CERTS echo $REQUESTS_CA_BUNDLE
- Ensure the environment variable is set correctly:
- Test the gcloud Commands:
- Try running a gcloud command to verify if the setup works correctly:
1
gcloud info --run-diagnostics
- Try running a gcloud command to verify if the setup works correctly:
This post is licensed under CC BY 4.0 by the author.