Docs Menu
Docs Home
/ /
Configurar
/ / /

Cree un Proyecto por cada implementación de MongoDB utilizando un ConfigMap

El operador de Kubernetes de MongoDB Enterprise utiliza un ConfigMap de KubernetesPara vincular a un único proyecto de Ops Manager. Si el proyecto referenciado no existe, el operador de Kubernetes lo crea según... projectName que proporcione en ConfigMap.

Para crear un ConfigMap de operador de Kubernetes, puede editar algunas líneas del ConfigMap de ejemplo ArchivoYAML y aplicar el ConfigMap. Para ver un ejemplo completo, consulte el archivo project.yaml.

Como alternativa, puede utilizar la interfaz de usuario de MongoDB Cloud Manager o la interfaz de usuario de Ops Manager para crear o elegir un proyecto y generar automáticamente el archivo YAML ConfigMap, que luego puede aplicar a su entorno de Kubernetes.

  1. Solo se puede implementar un recurso de MongoDB por proyecto. Este límite se aplica porque Ops Manager solo admite un método de autenticación para el acceso de usuarios a la base de datos por proyecto. Para obtener más información, consulte Implementar un recurso de base de datos de MongoDB.

  2. Debe vincular una implementación de MongoDB Enterprise Kubernetes Operator con un proyecto único de Ops Manager. Puede crear un ConfigMap distinto para cada instancia de MongoDB Enterprise Kubernetes Operator que implemente o reutilizar el mismo ConfigMap para cualquier número de implementaciones omitiendo el data.projectName de su ConfigMap, de modo que los nombres de los proyectos coincidan con los nombres de los recursos implementados. Si se proporciona un nombre de proyecto en el mapa de configuración, se creará si ese proyecto aún no existe.

Importante

  • Puede utilizar el operador de Kubernetes para implementar recursos de MongoDB con Cloud Manager y con Ops Manager versión 6.0.x o posterior.

  • Puede utilizar el operador Atlas para implementar recursos de MongoDB en Atlas.

  • Versión de Kubernetes 1.11 o posterior o versión de Openshift 3.11 o posterior.

  • Operador MongoDB Enterprise Kubernetes versión 0.11 o posterior instalado.

1

Si aún no lo ha hecho, ejecute el siguiente comando para ejecutar todos los kubectl comandos en el espacio de nombres que creó.

Nota

Si está implementando un recurso de Ops Manager en una implementación de MongoDB de un clúster de Kubernetes múltiple:

  • Establezca context en el nombre del clúster del operador, como por ejemplo: kubectl config set context "$MDB_CENTRAL_CLUSTER_FULL_NAME".

  • Establezca --namespace en el mismo ámbito que utilizó para su implementación de MongoDB en un clúster de Kubernetes múltiple, como porkubectl config --namespace "mongodb" ejemplo:.

kubectl config set-context $(kubectl config current-context) --namespace=<metadata.namespace>
2
cat <<EOF | kubectl apply -f -
apiVersion: v1
kind: ConfigMap
metadata:
name: my-project
namespace: mongodb
data:
projectName: myProjectName # this is an optional parameter; when omitted, the Operator creates a project with the resource name
orgId: 5b890e0feacf0b76ff3e7183 # this is a required parameter
baseUrl: https://ops.example.com:8443
EOF
Clave
Tipo
Descripción
Ejemplo

metadata.name

string

Nombre del objeto de Kubernetes.

Los nombres de recursos deben tener 44 caracteres o menos.

Este nombre debe seguir las RFC1123 convenciones de nomenclatura, conteniendo solo caracteres alfanuméricos en minúsculas o - , y comenzando y terminando con un carácter alfanumérico.

Para obtener más información, consulte la documentación de Kubernetes sobre nombres.

my-project

metadata.namespace

string

Espacio de nombres de Kubernetes donde el operador de Kubernetes crea este MongoDB recurso y otros objetos.

mongodb

data.projectName

string

Etiqueta para su proyecto de Ops Manager.

El operador de Kubernetes crea el proyecto de Ops Manager si no existe. Si projectName omite, el operador de Kubernetes crea un proyecto con el mismo nombre que su recurso de Kubernetes.

Para usar un proyecto existente en una organización de Cloud Manager u Ops Manager, ubique projectName haciendo clic en el icono All Clusters Enlace en la esquina superior izquierda de la página de Cloud Manager u Ops Manager, y busque por nombre en el Search cuadro o desplácese para encontrarlo en la lista. Cada tarjeta de esta lista representa la combinación de una organización y un proyecto de Cloud Manager u Ops Manager.

myProjectName

data.orgId

string

Obligatorio.Cadena 24 hexadecimal de caracteres que identifica de forma única su organización Cloud Manager u Ops Manager.

Puede utilizar el operador de Kubernetes para implementar recursos de MongoDB con Cloud Manager y con Ops Manager versión 6.0.x o posterior.

Puede utilizar el operador Atlas para implementar recursos de MongoDB en Atlas.

Especifique una organización existente:

  1. Encuentra el ID de la organización.

    Haga clic en Settings en la barra de navegación izquierda.

  2. Copie y pegue el orgId en la URL.

    Seleccione su organización, vea la URL actual en su navegador y copie el valor que se muestra en el marcador de posición <orgId> de la siguiente manera:

    https://ops.example.com:8443/ v2#/org/<orgId>/projects

Debe tener el rol de Creador de proyectos de organización para crear un nuevo proyecto dentro de una organización existente de Cloud Manager u Ops Manager.

Si proporciona una cadena vacía como orgId, Kubernetes Operator crea una organización con el mismo nombre que su proyecto.

5b890e0feacf0b76ff3e7183

data.baseUrl

string

URL de su aplicación Ops Manager, incluido el FQDN y el número de puerto.

IMPORTANTE: Si implementa Ops Manager con el operador de Kubernetes y Ops Manager administra los recursos de la base de datos MongoDB implementados fuera del clúster de Kubernetes donde se implementa, debe establecer data.baseUrl con el mismo valor que el spec.configuration.mms.centralUrl parámetro en la especificación de recursos de Ops Manager. Para obtener más información, consulte Administración de implementaciones externas de MongoDB.

Si está utilizando Cloud Manager, establezca el valor data.baseUrl en https://cloud.mongodb.com.

https://ops.example.com:8443

3
kubectl describe configmaps <configmap-name>

Este comando devuelve una descripción de ConfigMap en el shell:

Name: <configmap-name>
Namespace: <namespace>
Labels: <none>
Annotations: <none>
Data
====
baseUrl:
----
<myOpsManagerURL>
Events: <none>

Es posible que haya optado por usar su propio certificado TLS para habilitar HTTPS en su instancia de Ops Manager. Si usó un certificado personalizado, debe agregar la CA que lo firmó al operador de Kubernetes. Para agregar su CA personalizada, complete lo siguiente:

1

El operador de Kubernetes requiere el certificado raíz CA de la CA que emitió el certificado del host de Ops Manager. Ejecuta el siguiente comando para crear un ConfigMap que contenga el CA raíz en el mismo espacio de nombres de tus pods de base de datos:

kubectl -n <metadata.namespace> create configmap <root-ca-configmap-name> \
--from-file=mms-ca.crt

Importante

El operador de Kubernetes requiere que nombre el certificado del recurso Ops Manager mms-ca.crt en ConfigMap.

2
1---
2apiVersion: v1
3kind: ConfigMap
4metadata:
5 name: <my-configmap>
6 namespace: <my-namespace>
7data:
8 projectName: <my-ops-manager-project-name> # this is an optional parameter
9 orgId: <org-id> # this is a required parameter
10 baseUrl: https://<my-ops-manager-URL>
11 sslMMSCAConfigMap: <root-ca-configmap-name>
12 sslRequireValidMMSServerCertificates: ‘true’
13...
3
  1. Invoque el siguiente comando para editar el ConfigMap de su proyecto en el editor configurado predeterminado:

    kubectl edit configmaps <my-configmap> -n <metadata.namespace>
  2. Pegue la sección resaltada en el ConfigMap de ejemplo al final del proyecto ConfigMap.

4

Cambie las siguientes claves TLS:

Clave
Tipo
Descripción
Ejemplo

sslMMSCAConfigMap

string

Nombre del ConfigMap creado en el primer paso que contiene el certificado de CA raíz utilizado para firmar el certificado del host de Ops Manager. Esto monta el certificado de CA en los recursos de operador y base de datos de Kubernetes.

my-root-ca

sslRequireValidMMSServerCertificates

booleano

Obliga al operador a solicitar un certificado TLS válido de Ops Manager.

IMPORTANTE: El valor debe estar entre comillas simples o el operador generará un error.

'true'

5
6
kubectl describe configmaps <my-configmap> -n <metadata.namespace>

Importante

Incluya siempre la opción de kubectl espacio de nombres con. Si no se especifica la opción, kubectlusa un espacio de nombres vacío -n de forma predeterminada, lo que provoca errores de implementación. Debe especificar el valor del <metadata.namespace> campo. Los recursos de operador, secreto y de Kubernetes MongoDB deben ejecutarse en el mismo espacio de nombres único.

Este comando devuelve una descripción de ConfigMap en el shell:

Name: <my-configmap>
Namespace: <namespace>
Labels: <none>
Annotations: <none>
Data
====
sslMMSCAConfigMap:
----
<root-ca-configmap-name>
sslRequireValidMMSServerCertificates:
----
true
Events: <none>

Ahora que ha creado su ConfigMap, cree credenciales para el operador de Kubernetes antes de comenzar a implementar recursos de MongoDB.

Volver

Crear credenciales

En esta página