Crea una CA subordinada a partir de una CA externa
En esta página, se describe cómo crear una autoridad certificadora (CA) subordinada que se encadena a una CA raíz externa.
Si tienes una jerarquía de infraestructura de clave pública (PKI) existente que contiene una CA raíz y CA subordinadas, puedes mantener la misma CA raíz y crear una CA subordinada en el servicio de CA que se encadene a tu CA raíz externa. La clave y las operaciones de la CA raíz externa permanecen fuera de Google Cloud. Solo puedes usar la CA raíz externa para emitir el certificado de la AC subordinada aGoogle Cloud. Cualquier carga de trabajo que confíe en la CA raíz externa confía de inmediato en la CA subordinada. Luego, puedes usar la CA subordinada para emitir certificados sin necesidad de volver a la CA raíz externa en el tiempo de ejecución.
Antes de comenzar
- Asegúrate de tener el rol de IAM de Administrador de operaciones del Servicio de CA (
roles/privateca.caManager) o Administrador del Servicio de CA (roles/privateca.admin). Para obtener más información, consulta Configura políticas de IAM. - Identifica la CA raíz externa.
- Define el nombre, el asunto, el período de validez y el tamaño de la clave de la CA subordinada. Para obtener más información, consulta Cómo determinar la configuración de la CA.
Crea una CA subordinada a partir de una CA externa
La creación de una CA subordinada a partir de una CA externa implica los siguientes pasos:
Genera la solicitud de firma de certificado (CSR) de la CA subordinada: El primer paso es generar una CSR para la CA subordinada y, luego, descargarla.
Obtén el certificado de la AC subordinada firmado por la AC raíz externa: El segundo paso es enviar la CSR a la AC raíz externa para que la firme. Asegúrate de seguir las instrucciones específicas de la AC raíz externa para enviar CSR y obtener certificados firmados.
Importa el certificado de la AC subordinada firmado en CA Service: El último paso es subir la cadena de certificados PEM firmada con Google Cloud CLI o la consola de Google Cloud .
En la siguiente sección, se muestra cómo crear una CA subordinada a partir de una CA raíz externa.
Crea una CSR
Console
En la consola de Google Cloud , ve a la página Certificate Authority Service.
Haz clic en la pestaña Administrador de CA.
Haz clic en Crear CA.
Select CA type:
- Haz clic en CA subordinada.
- En el campo Válido durante, ingresa la duración para la que deseas que sean válidos los certificados emitidos por la CA subordinada.
- Haz clic en La CA raíz es externa.
- Selecciona una de las opciones disponibles para el nivel de la CA. Para obtener más información, consulta Selecciona los niveles de operación.
- En Regionalización, selecciona una ubicación de CA de la lista.
- Haz clic en Siguiente.
- En el campo Organización (O), ingresa el nombre de tu empresa.
- Opcional: En el campo Unidad organizativa (UO), ingresa la subdivisión de la empresa o la unidad de negocios.
- Opcional: En el campo Nombre del país (C), ingresa un código de país de dos letras.
- Opcional: En el campo Nombre del estado o provincia, ingresa el nombre de tu estado.
- Opcional: En el campo Nombre de la localidad, ingresa el nombre de tu ciudad.
- En el campo Nombre común de CA (CN), ingresa el nombre de la CA.
- Haz clic en Continuar.
- Elige el algoritmo de clave que mejor se adapte a tus necesidades. Para obtener más detalles sobre las opciones de claves de firma, consulta Cómo configurar claves de firma de la CA.
- Para usar una clave de firma administrada por el cliente, selecciona Clave administrada por el cliente y proporciona la versión de la clave criptográfica de Cloud Key Management Service.
- Haz clic en Continuar.
- Elige si deseas usar un bucket de Cloud Storage administrado por Google o por el cliente.
- En el caso de un bucket de Cloud Storage administrado por Google, CA Service crea un bucket administrado por Google en la misma ubicación que la CA.
- En el caso de un bucket de Cloud Storage administrado por el cliente, haz clic en Explorar y selecciona uno de los buckets de Cloud Storage existentes.
- Haz clic en Continuar.
Los siguientes pasos son opcionales.
Si deseas agregar etiquetas a la CA, haz lo siguiente:
- Haz clic en Agregar elemento.
- En el campo Clave 1, ingresa la clave de la etiqueta.
- En el campo Valor 1, ingresa el valor de la etiqueta.
- Si deseas agregar otra etiqueta, haz clic en Agregar elemento. Luego, agrega la clave y el valor de la etiqueta como se mencionó en los pasos 2 y 3.
- Haz clic en Continuar.
Revisa con atención todos los parámetros de configuración y, luego, haz clic en Listo para crear la CA.
Descarga la CSR
- En la página Autoridad certificadora, selecciona la CA que deseas activar.
- Haz clic en Activar.
En el diálogo que se abre, haz clic en Descargar CSR.
gcloud
Para crear un grupo de AC para la AC subordinada, ejecuta el siguiente comando. Para obtener más información, consulta Crea un grupo de AC.
gcloud privateca pools create SUBORDINATE_POOL_ID --location=LOCATIONReemplaza lo siguiente:
- SUBORDINATE_POOL_ID: Es el nombre del grupo de CA.
- LOCATION: Es la ubicación del grupo de CA.
Para crear una CA subordinada en el grupo de CA creado, ejecuta el siguiente comando
gcloud. El comandogcloudtambién crea una CSR y la guarda en el archivo FILE_NAME.gcloud privateca subordinates create SUBORDINATE_CA_ID \ --pool=SUBORDINATE_POOL_ID \ --location=LOCATION \ --create-csr --csr-output-file=FILE_NAME \ --key-algorithm="ec-p256-sha256" \ --subject="CN=Example Server TLS CA, O=Example LLC"Reemplaza lo siguiente:
- SUBORDINATE_CA_ID: Es el identificador único de la CA subordinada.
- SUBORDINATE_POOL_ID: Es el nombre del grupo de CA.
- LOCATION: Es la ubicación del grupo de CA.
- FILE_NAME: Es el nombre del archivo en el que se escribe la CSR codificada en PEM.
La marca
--key-algorithmespecifica el algoritmo criptográfico que deseas usar para crear una clave de Cloud HSM administrada para la CA.La marca
--subjectespecifica el nombre X.501 del sujeto del certificado.Para obtener más información sobre el comando
gcloud privateca subordinates create, consulta gcloud privateca subordinates create.Para crear una CA subordinada con una clave de firma administrada por el cliente, ejecuta el siguiente comando:
gcloud privateca subordinates create SUBORDINATE_CA_ID \ --pool=SUBORDINATE_POOL_ID \ --location=LOCATION \ --create-csr --csr-output-file=FILE_NAME \ --kms-key-version=KMS_KEY_VERSION \ --subject="CN=Example Server TLS CA, O=Example LLC"Reemplaza lo siguiente:
- SUBORDINATE_CA_ID: Es el identificador único de la CA subordinada.
- SUBORDINATE_POOL_ID: Es el nombre del grupo de CA.
- LOCATION: Es la ubicación del grupo de CA.
- FILE_NAME: Es el nombre del archivo en el que se escribe la CSR codificada en PEM.
- KMS_KEY_VERSION: Es el ID de recurso completo de una versión de clave criptográfica de Cloud KMS administrada por el cliente que se usará como clave de firma.
Para obtener más detalles sobre las opciones de claves de firma y cómo preparar una clave de firma administrada por el cliente, consulta Configura claves de firma de la CA.
Se devuelve la siguiente instrucción cuando se crea la CSR:
Created Certificate Authority [projects/my-project-pki/locations/us-west1/caPools/SUBORDINATE_POOL_ID/certificateAuthorities/SUBORDINATE_CA_ID] and saved CSR to FILE_NAME.
Para ver la lista exhaustiva de parámetros de configuración disponibles, ejecuta el siguiente comando:
gcloud privateca subordinates create --help
Si pierdes la CSR, puedes volver a descargarla con el siguiente comando:
gcloud privateca subordinates get-csr SUBORDINATE_CA_ID \
--pool=SUBORDINATE_POOL_ID \
--location=LOCATION
Terraform
Para crear un grupo de CA y una CA subordinada en ese grupo, usa el siguiente archivo de configuración:
resource "google_privateca_ca_pool" "default" { name = "test-ca-pool" location = "us-central1" tier = "ENTERPRISE" } resource "google_privateca_certificate_authority" "sub-ca" { pool = google_privateca_ca_pool.default.name certificate_authority_id = "my-certificate-authority-sub" location = "us-central1" config { subject_config { subject { organization = "HashiCorp" common_name = "my-subordinate-authority" } subject_alt_name { dns_names = ["hashicorp.com"] } } x509_config { ca_options { is_ca = true # Force the sub CA to only issue leaf certs max_issuer_path_length = 0 } key_usage { base_key_usage { cert_sign = true crl_sign = true } extended_key_usage { } } } } lifetime = "86400s" key_spec { algorithm = "RSA_PKCS1_4096_SHA256" } type = "SUBORDINATE" }Para recuperar el CSR, agrega la siguiente configuración.
data "google_privateca_certificate_authority" "sub-ca-csr" { location = "us-central1" pool = google_privateca_ca_pool.default.name certificate_authority_id = google_privateca_certificate_authority.sub-ca.certificate_authority_id } output "csr" { value = data.google_privateca_certificate_authority.sub-ca-csr.pem_csr }Ejecuta
terraform apply.
Firma la CSR
Pasa el archivo CSR generado al miembro de tu organización responsable de la emisión de certificados y pídele que lo firme. Los pasos específicos dependen de la configuración de tu organización.
Puedes experimentar con una AC raíz simple usando los siguientes comandos de openssl:
Shell
Configura los parámetros de configuración de la nueva CA raíz.
cat > root.conf <<- EOM
[ req ]
distinguished_name = req_distinguished_name
x509_extensions = v3_ca
prompt = no
[ req_distinguished_name ]
commonName = Sample Root
[ v3_ca ]
subjectKeyIdentifier=hash
basicConstraints=critical, CA:true
EOM
Crea la nueva CA raíz.
openssl req -x509 -new -nodes -config root.conf -keyout rootCA.key \
-days 3000 -out rootCA.crt -batch
Configura las extensiones que se deben agregar al nuevo certificado de la CA subordinada.
cat > extensions.conf <<- EOM
basicConstraints=critical,CA:TRUE,pathlen:0
keyUsage=critical,keyCertSign,cRLSign
extendedKeyUsage=critical,serverAuth
subjectKeyIdentifier=hash
authorityKeyIdentifier=keyid
EOM
Firma la CSR de la CA subordinada con esta raíz.
openssl x509 -req -in FILE_NAME -CA rootCA.crt -CAkey rootCA.key \
-CAcreateserial -out subordinate.crt -days 1095 -sha256 -extfile extensions.conf
Concatena toda la cadena de certificados en un solo archivo.
cat subordinate.crt > chain.crt
cat rootCA.crt >> chain.crt
Sube el certificado firmado
Para activar una CA subordinada con un certificado firmado, haz lo siguiente:
Console
Ve a la página Certificate Authority Service en la consola deGoogle Cloud .
Haz clic en la pestaña Administrador de CA.
En Autoridades certificadoras, elige la CA subordinada que creaste.
Haz clic en Activar.
En el diálogo que se abre, haz clic en Descargar CSR para descargar el archivo de CSR con codificación PEM que puede firmar la CA emisora.
Haz clic en Siguiente.
En el campo Subir cadena de certificados, haz clic en Explorar.
Sube el archivo de certificado firmado con la extensión
.crt.Haz clic en Activar.
gcloud
gcloud privateca subordinates activate SUBORDINATE_CA_ID \
--pool=SUBORDINATE_POOL_ID \
--location=LOCATION \
--pem-chain ./chain.crt
Reemplaza lo siguiente:
- SUBORDINATE_CA_ID: Es el identificador único de la AC subordinada que deseas activar.
- SUBORDINATE_POOL_ID: Es el nombre del grupo de AC que contiene la AC subordinada.
- LOCATION: Es la ubicación del grupo de AC. Para obtener la lista completa de ubicaciones, consulta Ubicaciones.
La marca --pem-chain es obligatoria. Esta marca especifica un archivo que contiene la lista de certificados codificados con PEM. La lista de certificados comienza con el certificado de la AC actual y termina con el certificado de la AC raíz.
Para obtener más información sobre el comando gcloud privateca subordinates activate, consulta gcloud privateca subordinates activate.
Cuando se sube el certificado firmado, se devuelve la siguiente instrucción:
Activated certificate authority [SUBORDINATE_CA_ID].
Terraform
- Guarda el certificado de la AC firmado de forma local como
subordinate.crt. - Guarda los certificados de CA del firmante de forma local como
rootCA.crt. - Quita la configuración para recuperar la CSR que se menciona en el primer paso, ya que intenta recuperar la CSR, lo que no se permite después de la activación de la CA.
Actualiza la configuración de la CA subordinada con los siguientes campos y ejecuta
terraform apply.pem_ca_certificate = file("subordinate.crt") subordinate_config { pem_issuer_chain { pem_certificates = [file("rootCA.crt")] } }
Si la cadena de la entidad emisora incluye más de una CA, especifica el valor como [file("intermediateCA.cert"), file("rootCA.crt")].
¿Qué sigue?
- Obtén más información para solicitar certificados.
- Obtén información sobre las plantillas y las políticas de emisión.