Nota
En cualquier lugar de esta página donde diga Ops Manager, puedes sustituir Cloud Manager.
La El operador de controladores MongoDB para Kubernetes crea conjuntos con estado de Kubernetes a partir de archivos de especificaciones que usted escribe.
El Operador de Kubernetes crea recursos específicos de MongoDB en Kubernetes como recursos personalizados.
Para administrar estos recursos personalizados, utilice el siguiente proceso:
Crear o actualizar una
MongoDBespecificación de recursos.Controladores de MongoDB directos para el operador de Kubernetes para aplicar en tu entorno de Kubernetes. Como resultado, el Operador de Kubernetes realiza estas acciones:
Crea los statefulSets definidos, servicios y otros recursos de Kubernetes.
Actualiza la configuración de implementación de Ops Manager para reflejar los cambios.
Tipo de implementación | StatefulSets | Tamaño de StatefulSet |
|---|---|---|
Autónomo | 1 | 1 Pod |
Set de réplicas | 1 | 1 Pod por nodo |
Clúster fragmentado | <numberOfShards> + 2 |
Cada recurso de MongoDB utiliza una especificación de objeto en YAML para definir las características y configuraciones del objeto MongoDB: autónomo, set de réplicas, y clúster.
Configuraciones comunes de recursos
Cada tipo de recurso debe utilizar la siguiente configuración:
Requerido
metadata.nameTipo: string
Nombre del recurso
MongoDBque creas.Los nombres de recursos deben tener 44 caracteres o menos.
spec.credentialsTipo: string
Obligatorio. Nombre del secreto de Kubernetes secreto que se creó como Ops Manager API credenciales de autenticación para que el Operador de Kubernetes se comunique con Cloud Manager u Ops Manager.
El objeto secreto de Kubernetes de Ops Manager que contiene las credenciales debe existir en el mismo espacio de nombres que el recurso que desea crear.
Importante
El operador gestiona los cambios en el secreto.
El operador de Kubernetes rastrea cualquier cambio en el Secreto y reconcilia el estado del recurso
MongoDB.
spec.persistentTipo: booleano
Por defecto: true
ADVERTENCIA: Otorgue a sus contenedores permiso para escribir en su volumen persistente. El operador de Kubernetes
fsGroup = 2000establece,runAsUser = 2000yrunAsNonRoot = trueen. ElsecurityContextoperador de Kubernetes establecefsgroupigual arunAsUserpara que el volumen pueda ser escrito por un usuario que ejecuta el proceso principal en el contenedor. Para obtener más información,consulte "Configurar un contexto de seguridad para un pod o contenedor" y la información relacionada en la documentación de Kubernetes. Si volver a implementar el recurso no soluciona los problemas con su volumen persistente, póngase en contacto con el soporte técnico de MongoDB.Si no usas volúmenes persistentes, el Disk Usage y Disk IOPS gráficas no pueden mostrarse ni en la pestaña Processes de la página Deployment ni en la página Metrics al revisar los datos de esta implementación.
spec.typeTipo: string
Tipo de recurso
MongoDBa crear. Los valores aceptados son:StandaloneReplicaSetShardedCluster
spec.versionTipo: string
Versión de MongoDB que instalaste en este recurso
MongoDB.Importante
Asegúrese de elegir una versión de MongoDB Server compatible.
Las versiones compatibles difieren según la imagen base que utiliza el recurso de base de datos de MongoDB.
Nota
Si actualiza este valor a una versión posterior de MongoDB para sus recursos de base de datos, la versión de compatibilidad de funciones se mantendrá en la versión de MongoDB que está actualizando para que pueda cambiar a una versión inferior si es necesario. Si desea que la versión de compatibilidad de funciones coincida con la nueva versión de MongoDB, debe configurar manualmente
spec.featureCompatibilityVersioncon la nueva versión oAlwaysMatchVersioncon. Para obtener más información,spec.featureCompatibilityVersionconsulte.
Condicional
Cada recurso debe utilizar una de las siguientes configuraciones:
spec.opsManager.configMapRef.nameTipo: string
Nombre del ConfigMap con la configuración de conexión de Cloud Manager u Ops Manager. El parámetro es un alias para esta
spec.cloudManager.configMapRef.nameconfiguración y puede usarse en su lugar.Este valor debe existir en el mismo espacio de nombres que el recurso que quieres crear.
Importante
El operador administra los cambios en ConfigMap
El operador de Kubernetes rastrea cualquier cambio en ConfigMap y concilia el estado del recurso
MongoDB.
Opcional
Cada tipo de recurso puede usar la(s) siguiente(s) configuración(es):
metadata.annotations.mongodb.com/v1.architectureTipo: string
Determina la arquitectura de contenedor utilizada por una implementación específica:
Los contenedores no estáticos por defecto que descargan el binario de MongoDB en tiempo de ejecución, o
Contenedores estáticos (Visualización pública) que son inmutables en tiempo de ejecución.
Los valores aceptados son:
staticnon-static
apiVersion: mongodb.com/v1 kind: MongoDB metadata: name: my-project annotations: mongodb.com/v1.architecture: "static"
spec.agent.backupAgent.logRotateTipo: objeto
Umbrales a partir de los cuales el MongoDB Agent rota el registro de copia de seguridad.
spec.agent.backupAgent.logRotate.sizeThresholdMBTipo: entero
Tamaño máximo, en MB, de una entrada de registro de copia de seguridad antes de que el MongoDB Agent rote los registros.
spec.agent.backupAgent.logRotate.timeThresholdHrsTipo: entero
Número de horas después de las cuales el Agente MongoDB rota el archivo de registro de respaldo.
spec.agent.mongod.auditlogRotateTipo: objeto
Objeto que contiene la configuración de rotación del registro de auditoría para los procesos de MongoDB.
spec.agent.mongod.auditlogRotate.sizeThresholdMBTipo: número
Tamaño máximo, en MB, de un archivo de registro de auditoría antes de que el MongoDB Agent gire los registros.
spec.agent.mongod.auditlogRotate.timeThresholdHrsTipo: entero
Número de horas después de las cuales el Agente MongoDB rota el archivo de registro de auditoría.
spec.agent.mongod.auditlogRotate.numUncompressedTipo: entero
Número máximo de entradas de registro totales de auditoría que se pueden dejar sin comprimir, incluyendo la entrada de registro actual.
spec.agent.mongod.auditlogRotate.numTotalTipo: entero
Número total de archivos de registro de auditoría que Ops Manager conserva. Si no se establece este valor, el número total de archivos de registro de auditoría predeterminado 0 es.
spec.agent.mongod.auditlogRotate.percentOfDiskspaceTipo: número
Porcentaje máximo del espacio total en disco que Ops Manager puede utilizar para almacenar las entradas de registro expresado como decimal. Si se supera este límite, Ops Manager borra las entradas de registro comprimidas hasta cumplirlo. Ops Manager elimina primero los archivos de registro más antiguos.
El valor por defecto es 0,02.
spec.agent.mongod.logRotateTipo: objeto
Umbrales después de los cuales Ops Manager rota los registros de MongoDB de un proceso.
spec.agent.mongod.logRotate.sizeThresholdMBTipo: entero
Tamaño máximo en MB para una entrada de registro individual antes de que Ops Manager lo rote. Ops Manager rota la entrada de registro inmediatamente si cumple con el valor dado en este
sizeThresholdMBo en elspec.agent.mongod.logRotate.timeThresholdHrs.
spec.agent.mongod.logRotate.timeThresholdHrsTipo: entero
Duración máxima en horas de un archivo de registro individual antes de la siguiente rotación. El tiempo transcurrido es desde la última rotación.
Ops Manager rota el archivo de registro una vez que el archivo cumple
timeThresholdHrsconspec.agent.mongod.logRotate.sizeThresholdMBo.
spec.agent.monitoringAgent.logRotateTipo: objeto
Umbrales después de los cuales el MongoDB Agent rota el registro de supervisión.
spec.agent.monitoringAgent.logRotate.sizeThresholdMBTipo: entero
Tamaño máximo en MB para un archivo de registro individual antes de que el Agente MongoDB rote el registro de monitoreo.
spec.agent.monitoringAgent.logRotate.timeThresholdHrsTipo: entero
Número de horas después de las cuales el Agente de MongoDB rota el registro de supervisión.
spec.agent.readinessProbe.environmentVariablesTipo: objeto
Configura las siguientes variables de entorno que se utilizan para controlar los archivos de registro de la sonda de preparación:
apiVersion: mongodb.com/v1 kind: MongoDB metadata: name: my-project spec: agent: readinessProbe: environmentVariables: READINESS_PROBE_LOGGER_BACKUPS: 1 READINESS_PROBE_LOGGER_MAX_SIZE: 10 READINESS_PROBE_LOGGER_MAX_AGE: 3 READINESS_PROBE_LOGGER_COMPRESS: true MDB_WITH_AGENT_FILE_LOGGING: false LOG_FILE_PATH: /var/log/mongodb-mms-automation/readiness.log
spec.featureCompatibilityVersionTipo: string
Por defecto, la versión principal anterior de MongoDB tras la actualización de MongoDB.
Limita los cambios en los datos que ocurren con una nueva actualización a una nueva versión principal. Por ejemplo, si actualizas de MongoDB 5.0 a MongoDB 6.0, la compatibilidad de características entre versiones se mantiene en 5.0 para que tengas la opción de realizar un downgrade si es necesario.
Si quieres que la compatibilidad de características entre versiones coincida con la nueva versión de MongoDB, debes configurar manualmente
featureCompatibilityVersiona la nueva versión. Por ejemplo,featureCompatibilityVersion: 6.0.Como alternativa, puede habilitar la opción
AlwaysMatchVersionpara actualizar automáticamente la versión de compatibilidad de funciones para que coincida con la versión de MongoDB durante las actualizaciones. Por ejemplo,featureCompatibilityVersion: AlwaysMatchVersion.Para aprender más sobre la compatibilidad de funcionalidades, consulta
setFeatureCompatibilityVersionen el Manual de MongoDB.
spec.clusterDomainTipo: string
por defecto: clúster.local
Nombre de dominio del clúster de Kubernetes donde se implementa el Operador de Kubernetes. Cuando Kubernetes crea un StatefulSet, Kubernetes asigna a cada Pod un FQDN. Para actualizar Cloud Manager u Ops Manager, el Operador de Kubernetes calcula el FQDN para cada pod usando un nombre de clúster proporcionado. Kubernetes no proporciona una API para query estos nombres de host.
Advertencia
Debes configurar
spec.clusterDomainsi tu clúster de Kubernetes tiene un dominio por defecto distinto del por defectocluster.local. Si no utilizas la opción por defecto ni configuras la opciónspec.clusterDomain, el operador de Kubernetes podría no funcionar como se espera.
spec.clusterNameTipo: string
por defecto: clúster.local
Nombre de dominio del clúster de Kubernetes donde se implementa el Operador de Kubernetes. Cuando Kubernetes crea un StatefulSet, Kubernetes asigna a cada Pod un FQDN. Para actualizar Cloud Manager u Ops Manager, el Operador de Kubernetes calcula el FQDN para cada pod usando un nombre de clúster proporcionado. Kubernetes no proporciona una API para query estos nombres de host.
Advertencia
Debes configurar
spec.clusterDomainsi tu clúster de Kubernetes tiene un dominio por defecto distinto del por defectocluster.local. Si no utilizas la opción por defecto ni configuras la opciónspec.clusterDomain, el operador de Kubernetes podría no funcionar como se espera.
metadata.namespaceTipo: string
Kubernetes namespace (espacio de nombres), donde se crea este recurso de
MongoDBy otros objetos.
spec.serviceTipo: string
Por defecto: <resource_name>+"-svc" y <resource_name>+"-svc-external".
Nombre del servicio de Kubernetes que se creará o usará para un StatefulSet. Si el servicio con este nombre ya existe, el operador de Controladores de MongoDB para Kubernetes no lo elimina ni lo vuelve a crear. Esta configuración le permite crear sus propios servicios personalizados y que el operador de Kubernetes los reutilice.
spec.logLevelTipo: string
Predeterminado: INFO
Configura el nivel de registro del agente de automatización dentro del Pod. Los valores aceptados incluyen:
DEBUGINFOWARNERRORFATAL
spec.security.authentication.ignoreUnknownUsersTipo: booleano
Por defecto:
falseDetermina si se pueden modificar los usuarios de la base de datos que no fueron configurados a través de Kubernetes operador, Cloud Manager u Ops Manager.
Para administrar usuarios de la base de datos directamente a través de o, configure esta
mongodmongosconfiguracióntrueen.
Configuración de recursos específica de implementación
Otros ajustes que puedes y debes usar en una especificación de recurso MongoDB dependen del elemento de implementación de MongoDB que deseas crear:
Configuración autónoma
Nota
Todas las Configuraciones autónomas también aplican a los recursos de sets de réplicas.
spec.additionalMongodConfigtipo: colección
Opciones de configuración adicionales con las que desea iniciar procesos de MongoDB.
El operador de Kubernetes admite todas las opciones de configuración que admite la versión de MongoDB que implementa a través del agente de MongoDB, excepto que el operador de Kubernetes anula los valores que proporciona para cualquiera de las siguientes opciones:
Para obtener más información sobre las opciones de configuración que posee el operador de Kubernetes, consulte Configuración exclusiva del operador de Kubernetes de MongoDB.
Para saber qué opciones de configuración puedes utilizar, consulta Opciones avanzadas para implementaciones de MongoDB en la documentación de Ops Manager.
spec.agent.startupOptionstipo: colección
Configuración del agente MongoDB con el que desea iniciar el recurso de base de datos MongoDB.
Debe proporcionar la configuración de MongoDB Agent como pares clave-valor. Los valores deben ser cadenas.
Para obtener una lista de la configuración admitida de MongoDB Agent, consulta:
Configuración del agente MongoDB para proyectos de Cloud Manager.
Configuración del MongoDB Agent para la versión de Ops Manager que implementaste con el operador de Kubernetes.
1 2 apiVersion: mongodb.com/v1 3 kind: MongoDB 4 metadata: 5 name: my-standalone 6 spec: 7 version: "8.0.0" 8 service: my-service 9 10 opsManager: 11 configMapRef: 12 name: my-project 13 credentials: my-credentials 14 type: Standalone 15 16 persistent: true 17 agent: 18 startupOptions: 19 maxLogFiles: "30" 20 dialTimeoutSeconds: "40" 21 ...
spec.podSpecTipo: objeto
Objeto que contiene las especificaciones de los Pods de CustomResourceDefinition de MongoDB.
spec.externalAccesstipo: colección
Especificación para exponer su clúster a conexiones externas. Para saber cómo conectarse a su recurso MongoDB desde fuera del clúster de Kubernetes, consulte Conectarse a un recurso de base de datos MongoDB desde fuera de Kubernetes.
Si añades
spec.externalAccess, el Operador de Kubernetes crea un servicio externo para cada Pod en un set de réplicas. Los servicios externos proporcionan un punto de entrada externo para cada pod de la base de datos MongoDB en un clúster. Cada servicio externo tiene selectores que emparejan el servicio externo con un Pod específico.Si agrega esta configuración sin ningún valor, el Operador de Kubernetes crea un servicio externo con los siguientes valores por defecto:
CampoValorDescripciónName<pod-name>-svc-externalNombre del Servicio externo. No puedes cambiar este valor.
TypeLoadBalancerCrea un servicio externo LoadBalancer.
Port<Port Number>Un puerto para
mongod.publishNotReadyAddresstrueEspecifica que registros DNS se crean incluso si el Pod no está listo. No configures
falsepara ningún Pod de base de datos.Nota
Si estableces
spec.externalAccess.externalDomain, el servicio externo añade otro puerto (Port Number + 1) para copias de seguridad.
spec.externalAccess.externalServicetipo: colección
Especificación para sobrescribir los valores por defecto en
spec.externalAccess.Cuando estableces la configuración de
spec.externalAccess, el Operador de Kubernetes crea automáticamente un servicio de balanceador de carga externo con valores por defecto. Puedes anular ciertos valores o agregar nuevos valores según tus necesidades. Por ejemplo, si se pretende crear servicios NodePort y no se necesita un balanceador de carga, se deben configurar sobreescrituras en la especificación de Kubernetes:externalAccess: externalService: annotations: # cloud-specific annotations for the service spec: type: NodePort # default is LoadBalancer # you can specify other spec overrides if necessary Para obtener más información sobre la especificación de Kubernetes, consulta ServiceSpec en la documentación de Kubernetes.
spec.externalAccess.externalService.annotationstipo: colección
Pares clave-valor que le permiten agregar configuraciones específicas del proveedor de nube a todos los clústeres de su implementación. Para obtener más información, consulte anotaciones y la documentación de su proveedor de nube de Kubernetes.
Puedes usar anotaciones para especificar los valores de marcador de posición para los servicios externos utilizados por los implementaciones de Kubernetes operador. El operador de Kubernetes sustituye automáticamente estos valores por los valores correctos, tal como se describe en la siguiente tabla. Utilizar marcadores de posición permite proporcionar anotaciones específicas en cada servicio para un Pod específico.
ValorDescripción{resourceName}Igual
metadata.namea.{namespace}Igual
metadata.namespacea.{podIndex}Índice del Pod asignado por el StatefulSet y dirigido por el servicio externo actual.
{podName}Igual a
{resourceName}-{podIndex}.{statefulSetName}El StatefulSet. Igual a
{resourceName}.{externalServiceName}Nombre generado del servicio externo, basado en los valores de los marcadores de posición que hayas especificado. Igual a
{resourceName}-{podIndex}-svc-external.{mongodProcessDomain}El nombre de dominio del servidor que aloja el proceso mongod. Igual a
spec.externalAccess.externalDomainsi se establece. De lo contrario, igual al dominio utilizado para el procesomongodFQDN.Por ejemplo, para el nombre de host del proceso
mdb-rs-1.example.com,example.comes el nombre de dominio.{mongodProcessFQDN}El
mongodnombre de host del proceso establecido en la configuración de automatización.El nombre de host del proceso depende de la configuración de tu implementación. Si has configurado tu implementación para utilizar
external domains, el nombre de host del proceso utiliza el siguiente formato:{resourceName}-{podIndex}.{mongodProcessDomain}Por ejemplo:
mdb-rs-1.example.comSi tu implementación no utiliza dominios externos, el nombre de host del proceso utiliza el siguiente formato:
{resourceName}-{podIndex}.{resourceName}-{podIndex}-svc.{namespace}.svc.cluster.localPor ejemplo:
mdb-rs-1.mdb-rs-1-svc.ns.svc.cluster.localNota
Debe usar solo valores de marcador de posición conocidos, tal como se especifica en la tabla, y asegurarse de que no contengan valores vacíos o nulos. Tampoco puede usar un marcador de posición específico para implementaciones de varios clústeres de Kubernetes para una sola implementación de recursos de MongoDB.
De lo contrario, el operador de Kubernetes devuelve un error. Por ejemplo, podría aparecer el siguiente mensaje de error:
error replacing placeholders in map with key=external-dns.alpha.kubernetes.io/hostname, value={resourceName}-{podIndex}-{unknownPlaceholder}.{clusterName}-{clusterIndex}.example.com: missing values for the following placeholders: {clusterName}, {clusterIndex}, {unknownPlaceholder}`` Ejemplo
El siguiente ejemplo especifica los marcadores de posición
{resourceName},{podIndex}y{namespace}:apiVersion: mongodb.com/v1 kind: MongoDB metadata: name: mdb-rs namespace: ns spec: replicas: 3 externalAccess: externalService: annotations: external-dns.alpha.kubernetes.io/hostname: {resourceName}-{podIndex}-{namespace}.example.com El operador de Kubernetes rellena automáticamente las anotaciones de los servicios externos según el valor correcto de cada marcador de posición. Por ejemplo:
mdb-rs-0-svc-external: annotations: external-dns.alpha.kubernetes.io/hostname: mdb-rs-0-ns.example.com mdb-rs-1-svc-external: annotations: external-dns.alpha.kubernetes.io/hostname: mdb-rs-1-ns.example.com mdb-rs-2-svc-external: annotations: external-dns.alpha.kubernetes.io/hostname: mdb-rs-2-ns.example.com
spec.externalAccess.externalService.spectipo: colección
Configuración para el ServiceSpec. Para obtener más información, consulta
spec.externalAccess.externalService.
spec.podSpec.persistence.singletipo: colección
Haga que el Operador de Kubernetes cree un Reclamo de Volumen Persistente y monte los tres directorios de datos, diario y registros en un mismo Volumen Persistente.
Nota
Debes establecer los valores en esta colección
spec.persistent: truesi.Puedes definir esta colección o bien las
persistence.multiplecolecciones pero no ambas.
EscalarTipo de datoDescripciónlabelSelectorstring
Etiqueta utilizada para vincular volúmenes montados a directorios.
storagestring
Tamaño mínimo del volumen persistente que debe montarse. Este valor se expresa como un entero seguido de una unidad de almacenamiento en notación JEDEC.
El valor por defecto es 16 Gi.
Por ejemplo, si una implementación autónoma requiere 60 gigabytes de espacio de almacenamiento, establezca este valor en
60Gi.storageClassstring
Tipo de almacenamiento especificado en una notificación de volumen persistente. Puede crear este tipo de almacenamiento como un objeto StorageClass antes de usarlo en esta especificación de objeto.
Asegúrate de establecer el StorageClass
reclaimPolicycomo Retain. Esto garantiza que los datos se conserven cuando se elimine una Solicitud de Volumen Persistente.
spec.podSpec.persistence.multiple.datatipo: colección
Hace que el operador de Kubernetes cree un reclamo de volumen persistente y monte un directorio para datos en su propio volumen persistente.
Nota
Debes establecer los valores en esta colección
spec.persistent: truesi.Puede establecer esta colección o la colección
persistence.single, pero no ambas.
EscalarTipo de datoDescripciónlabelSelectorstring
Etiqueta utilizada para vincular volúmenes montados a directorios.
storagestring
Capacidad mínima de almacenamiento que debe estar disponible en un nodo de Kubernetes para alojar una implementación independiente en Kubernetes. Este valor se expresa como un entero seguido de una unidad de almacenamiento en notación JEDEC.
El valor por defecto es 16 Gi.
Por ejemplo, si este recurso
MongoDBrequiere 60 gigabytes de espacio de almacenamiento, establezca este valor en60Gi.storageClassstring
Tipo de almacenamiento necesario para la implementación independiente. Puede crear este tipo de almacenamiento como un objeto StorageClass antes de usarlo en esta especificación de objeto.
Asegúrate de establecer el StorageClass
reclaimPolicycomo Retain. Esto garantiza que los datos se conserven cuando se elimine una Solicitud de Volumen Persistente.
spec.podSpec.persistence.multiple.journaltipo: colección
Permite que Kubernetes Operator cree un Reclamación de volumen persistente y monte un directorio para el diario en su propio Volumen persistente.
Nota
Debes establecer los valores en esta colección
spec.persistent: truesi.Puede establecer esta colección o la colección
persistence.single, pero no ambas.
EscalarTipo de datoDescripciónlabelSelectorstring
Etiqueta utilizada para vincular volúmenes montados a directorios.
storagestring
Capacidad mínima de almacenamiento que debe estar disponible en un nodo de Kubernetes para alojar una implementación independiente en Kubernetes. Este valor se expresa como un entero seguido de una unidad de almacenamiento en notación JEDEC.
El valor por defecto es 1Gi.
Por ejemplo, si este recurso
MongoDBrequiere 60 gigabytes de espacio de almacenamiento, establezca este valor en60Gi.storageClassstring
Tipo de almacenamiento necesario para la implementación independiente. Puede crear este tipo de almacenamiento como un objeto StorageClass antes de usarlo en esta especificación de objeto.
Asegúrate de establecer el StorageClass
reclaimPolicycomo Retain. Esto garantiza que los datos se conserven cuando se elimine una Solicitud de Volumen Persistente.
spec.podSpec.persistence.multiple.logstipo: colección
Hace que el operador de Kubernetes cree un Reclamo de volumen persistente y monte un directorio para los registros en su propio Volumen Persistente.
Nota
Debes establecer los valores en esta colección
spec.persistent: truesi.Puede establecer esta colección o la colección
persistence.single, pero no ambas.
EscalarTipo de datoDescripciónlabelSelectorstring
Etiqueta utilizada para vincular volúmenes montados a directorios.
storagestring
Capacidad mínima de almacenamiento que debe estar disponible en un nodo de Kubernetes para alojar una implementación independiente en Kubernetes. Este valor se expresa como un entero seguido de una unidad de almacenamiento en notación JEDEC.
El valor por defecto es 3Gi.
Por ejemplo, si este recurso
MongoDBrequiere 60 gigabytes de espacio de almacenamiento, establezca este valor en60Gi.storageClassstring
Tipo de almacenamiento necesario para la implementación independiente. Puede crear este tipo de almacenamiento como un objeto StorageClass antes de usarlo en esta especificación de objeto.
Asegúrate de establecer el StorageClass
reclaimPolicycomo Retain. Esto garantiza que los datos se conserven cuando se elimine una Solicitud de Volumen Persistente.
spec.podSpec.podTemplatetipo: colección
Plantilla para los pods de Kubernetes que el operador de controladores MongoDB para Kubernetes crea para los recursos de base de datos de MongoDB.
Los valores de la plantilla tienen prioridad sobre los valores especificados en
spec.podSpec.Nota
El Operador de Kubernetes no valida los campos que se proporcionan en
spec.podSpec.podTemplate.
spec.podSpec.podTemplate.metadatatipo: colección
Metadatos para los Pods de Kubernetes que los Controladores de MongoDB para el Operador de Kubernetes crean para los recursos de la base de datos MongoDB.
Para revisar qué campos puedes agregar a
spec.podSpec.podTemplate.metadata, consulta la documentación de Kubernetes.
spec.podSpec.podTemplate.spectipo: colección
Especificaciones de los Pods de Kubernetes que los Controladores de MongoDB del Operador de Kubernetes crean para recursos de bases de datos MongoDB.
Para revisar los campos que puedes añadir a
spec.podSpec.podTemplate.spec, consulta la Kubernetes PodSpec v1 Core API.Nota
Cuando añades contenedores a
spec.podSpec.podTemplate.spec.containers, el operador de Kubernetes los añade al pod de Kubernetes. Estos contenedores se añaden a los contenedores de recursos de bases de datos de MongoDB en el pod.Utiliza esta configuración para especificar la asignación de CPU y RAM para cada pod. Para obtener ejemplos, consulta las muestras en GitHub.
spec.podSpec.podTemplate.spec.affinity.nodeAffinityTipo: Estructura
Regla de Kubernetes para colocar pods para el conjunto de réplicas en un rango específico de nodos.
Para un rendimiento de lectura-escritura optimizado, utiliza reglas de afinidad de nodos que restrinjan los Pods para ejecutarse en nodos en particular, o para dar preferencia a la ejecución en nodos en particular.
spec.podSpec.podTemplate.spec.affinity.podAffinityTipo: Estructura
Regla de Kubernetes para determinar si varios recursos
MongoDBPods deben estar ubicados junto con otros Pods. Para obtener más información sobre los casos de uso, consulta afinidad y anti-afinidad en la documentación de Kubernetes.
spec.podSpec.podTemplate.spec.affinity.podAntiAffinityTipo: Estructura
Default: kubernetes.io/hostname
Establece una regla para distribuir Pods que alojan el recurso
MongoDBen diferentes ubicaciones. Una ubicación puede ser un solo nodo, rack o región. De forma predeterminada, el operador de Kubernetes intenta distribuir los pods entre diferentes nodos.
Configuración del conjunto de réplicas
Nota
Todas las Configuraciones autónomas también aplican a los recursos de sets de réplicas.
Las siguientes configuraciones se aplican a los tipos de recursos del conjunto de réplicas:
spec.backuptipo: colección
El contenedor de colección para
spec.backup.mode, que habilita copias de seguridad continuas para los recursos de MongoDB en Kubernetes Operator.
spec.backup.assignmentLabelsTipo: arreglo
Una lista de etiquetas separadas por comas que se asignan a los daemons de copias de seguridad, almacenes oplog, blockstores, almacén de snapshots de S3 y almacenes del sistema de archivos a Proyectos o grupos específicos. Utiliza etiquetas de asignación para identificar que almacenes de copia de seguridad específicos están asociados a proyectos concretos.
Si se establecen etiquetas de asignación mediante el operador de Kubernetes, los valores que se establecen en el archivo de configuración de Kubernetes para las etiquetas de asignación sobrescriben los valores definidos en la interfaz de usuario del Ops Manager. Las etiquetas de asignación que no configuraste usando el Operador de Kubernetes continúan usando los valores configurados en la Interfaz de usuario de Ops Manager.
Nota
Si establece este parámetro, la clave API vinculada con el valor de
spec.credentialsdebe tener unaGlobal Ownerfunción.
spec.backup.modeTipo: string
Permite realizar copias de seguridad continuas de un recurso de MongoDB. Los valores posibles son
enabled,disabledyterminated.Nota
La configuración
spec.backup.modedepende de la Copia de seguridad habilitada en el Ops Manager y requiere que el valorspec.backup.enableden la especificación de recursos del Ops Manager esté configurado entrue.Después de habilitar las copias de seguridad continuas para su recurso MongoDB con
spec.backup.mode, puede verificar el estado de la copia de seguridad.
spec.backup.encryptionTipo: objeto
Un objeto que contiene la configuración de cifrado de copias de seguridad.
spec.backup.encryption.kmipTipo: objeto
Objeto que contiene la configuración de copia de seguridad de KMIP. Para obtener más información, consulta Configuración del cifrado de copia de seguridad KMIP para Ops Manager.
spec.backup.encryption.kmip.clientTipo: objeto
Objeto que contiene los ajustes de configuración del cliente de cifrado de copia de seguridad KMIP.
spec.backup.snapshotScheduletipo: colección
Contenedor de colección para la configuración del cronograma de snapshot de copia de seguridad continuas para recursos de MongoDB en Kubernetes operador.
spec.backup.snapshotSchedule.snapshotIntervalHoursTipo: número
Número de horas entre instantáneas. Puede establecer un valor de
6,8,12o24.
spec.backup.snapshotSchedule.snapshotRetentionDaysTipo: número
Número de días para mantener las snapshot recientes. Puedes establecer un valor entre
2y5, inclusive.
spec.backup.snapshotSchedule.dailySnapshotRetentionDaysTipo: número
Número de días para conservar las instantáneas diarias. Puede establecer un valor entre
1y365, inclusivo. Establecer el valor en0desactiva esta regla.
spec.backup.snapshotSchedule.weeklySnapshotRetentionWeeksTipo: número
Número de semanas para conservar los snapshots semanales. Puedes establecer un valor entre
1y52, inclusive. Configurar el valor a0deshabilita esta regla.
spec.backup.snapshotSchedule.monthlySnapshotRetentionMonthsTipo: número
Número de meses para conservar copias de seguridad mensuales. Puede establecer un valor entre
1y36, inclusivo. Establecer el valor en0desactiva esta regla.
spec.backup.snapshotSchedule.pointInTimeWindowHoursTipo: número
Número de horas en el pasado para las que puedes crear una snapshot puntual.
spec.backup.snapshotSchedule.referenceHourOfDayTipo: número
HoraUTC del día para programar instantáneas con formato de 24 horas. Puede establecer un valor entre
0y,23ambos inclusive.
spec.backup.snapshotSchedule.referenceMinuteOfHourTipo: número
UTC minuto de la hora para programar snapshot. Puede establecer un valor entre
0y59, ambos inclusive.
spec.backup.snapshotSchedule.fullIncrementalDayOfWeekTipo: string
Día de la semana en que Ops Manager toma una snapshot completa. Esta configuración garantiza una copia de seguridad completa reciente. Ops Manager establece el valor por defecto en
SUNDAY.
spec.clusterNameTipo: string
por defecto: clúster.local
Nombre de dominio del clúster de Kubernetes donde se implementa el Operador de Kubernetes. Cuando Kubernetes crea un StatefulSet, Kubernetes asigna a cada Pod un FQDN. Para actualizar Cloud Manager u Ops Manager, el Operador de Kubernetes calcula el FQDN para cada pod usando un nombre de clúster proporcionado. Kubernetes no proporciona una API para query estos nombres de host.
Advertencia
Debes configurar
spec.clusterDomainsi tu clúster de Kubernetes tiene un dominio por defecto distinto del por defectocluster.local. Si no utilizas la opción por defecto ni configuras la opciónspec.clusterDomain, el operador de Kubernetes podría no funcionar como se espera.
spec.connectivity.replicaSetHorizonstipo: colección
Te permite proporcionar distintas configuraciones DNS para aplicaciones clientes y los Agentes de MongoDB. El operador de Kubernetes utiliza DNS de horizonte dividido para los miembros de los conjuntos de réplicas. Esta funcionalidad permite la comunicación tanto dentro del clúster de Kubernetes como desde fuera de Kubernetes.
Puede agregar múltiples asignaciones externas por host.
Requisitos de Split Horizon:
Asegúrese de que cada valor en este arreglo sea único.
Asegúrate de que el número de entradas en este arreglo coincida con el valor dado en
spec.members.Proporcione un valor para la configuración
spec.security.certsSecretPrefixpara habilitar TLS. Este método para usar horizontes divididos requiere la extensión de Indicación de nombre de servidor del protocolo TLS.
Ejemplo
En este ejemplo, los miembros del conjunto de réplicas se comunican entre sí en el horizonte
example-localhost. Los clientes se comunican con el conjunto de réplicas mediante el horizonteexample-website.Los nombres de los horizontes mencionados son arbitrarios para los propósitos de este ejemplo. Puedes poner el nombre que quieras a tu horizonte, pero asegúrate de que el nombre del horizonte sea el mismo para todos los hostnames que forman parte de ese horizonte.
1 2 apiVersion: mongodb.com/v1 3 kind: MongoDB 4 metadata: 5 name: <my-replica-set> 6 spec: 7 members: 3 8 version: "8.0.0" 9 type: ReplicaSet 10 opsManager: 11 configMapRef: 12 name: <configMap.metadata.name> 13 credentials: <mycredentials> 14 persistent: true 15 security: 16 tls: 17 enabled: true 18 connectivity: 19 replicaSetHorizons: 20 - "example-website": "web1.example.com:30907" 21 - "example-website": "web2.example.com:32350" 22 - "example-website": "web3.example.com:31185" 23 ...
spec.externalAccess.externalDomainTipo: string
Un dominio externo utilizado para exponer externamente su implementación de set de réplicas.
De forma predeterminada, cada miembro del conjunto de réplicas usa el FQDN del pod de Kubernetes
*.svc.cluster.local() como nombre de host predeterminado. Sin embargo, si se agrega un dominio externo a esta configuración, el conjunto de réplicas usa un nombre de host que es un subdominio del dominio especificado. Este nombre de host tiene el siguiente formato:<replica-set-name>-<pod-idx>.<externalDomain>Por ejemplo:
replica-set-1.example.comDespués de implementar el set de réplicas con esta configuración, el Operador de Kubernetes utiliza el nombre de host con el dominio externo para anular el campo
processes[n].hostnameen el configuración de automatización de Ops Manager. Luego, el agente de MongoDB utiliza este nombre de host para conectarse amongod.Para especificar otros nombres de host para conectarse al set de réplicas, se puede utilizar la configuración de
spec.connectivity.replicaSetHorizons. Sin embargo, las siguientes conexiones aún usan el nombre de host con el dominio externo:ADVERTENCIA: Especificar este campo cambia la forma en que Ops Manager registra los procesos
mongod. No puedes cambiar el valor de este campo ni de ninguno de los camposprocesses[n].hostnameen la configuración de automatización de Ops Manager para una implementación activa de un set de réplicas.
spec.memberConfigtipo: colección
Especificación para cada miembro del set de réplicas de MongoDB implementado a partir del recurso
MongoDB.El orden de los elementos en el arreglo debe reflejar el orden de los miembros en el set de réplicas. Por ejemplo, el primer elemento del arreglo afecta al Pod en el índice
0, el segundo elemento afecta al índice1y así sucesivamente.Ejemplo
Considere la siguiente especificación de ejemplo para un conjunto de réplicas de tres nodos:
spec: memberConfig: - votes: 1 priority: "0.5" tags: tag1: "value1" environment: "prod" - votes: 1 priority: "1.5" tags: tag2: "value2" environment: "prod" - votes: 0 priority: "0.5" tags: tag2: "value2" environment: "prod"
spec.memberConfig.priorityTipo: string
Número que indica la probabilidad relativa de que un set de réplicas de MongoDB se convierta en el primario.
Para aumentar la probabilidad relativa de que un miembro del set de réplicas se convierta en el primario, es necesario especificar un valor de
prioritymás alto.Para disminuir la probabilidad relativa de que un miembro del conjunto de réplicas se convierta en el principal, especifique un valor
prioritymás bajo.
Por ejemplo, un nodo con un
memberConfig.priorityde1.5es más probable que se convierta en primario que un nodo con unmemberConfig.priorityde0.5.Un nodo con un
memberConfig.priorityde0no es elegible para convertirse en el titular primario. Para obtener más información, consulta Prioridad de nodos.
spec.memberConfig.tagsTipo: mapa
Mapa de etiquetas de set de réplicas para dirigir las operaciones de lectura y escritura a nodos específicos de su set de réplicas de MongoDB.
spec.memberConfig.votesTipo: número
Determina si un miembro de un conjunto de réplicas de MongoDB puede votar en una elección. Configura en
1para permitir que el nodo vote. Configura en0para excluir al nodo de una elección.
La configuración siguiente se aplica únicamente a los tipos de recursos de sets de réplicas:
spec.backup.autoTerminateOnDeletionTipo: booleano
Bandera que controla si el Operador de Kubernetes se detiene y finaliza la copia de seguridad cuando elimina un recurso de MongoDB. Si se omite, el valor por defecto es
false. Activar este indicador entruees útil cuando se desea borrar el recurso personalizado de MongoDB mientras laspec.backup.modeconfiguración está establecida enenabled.
Configuración de clúster fragmentado
Nota
Todos los ajustes de set de réplicas también se aplican a los recursos de clúster, salvo que se indique lo contrario.
Las siguientes configuraciones se aplican únicamente a los tipos de recursos de clúster fragmentados:
spec.backup.snapshotSchedule.clusterCheckpointIntervalMinTipo: número
Número de minutos entre los puntos de control sucesivos del clúster. Esta configuración solo se aplica a los clústeres fragmentados que ejecutan MongoDB con una versión de compatibilidad de características entre versiones 4.0 o anterior. Este número determina el nivel de detalle de las restauraciones a un punto específico del tiempo para los clústeres. Puede establecer un valor de
15,30o60.
spec.configServerCountTipo: entero
Obligatorio. Número de nodos en el servidor de configuración.
spec.configSrv.additionalMongodConfigtipo: colección
Opciones de configuración adicionales con las que se desee iniciar cada nodo del servidor de configuración.
El operador de Kubernetes admite todas las opciones de configuración que admite la versión de MongoDB que implementa a través del agente de MongoDB, excepto que el operador de Kubernetes anula los valores que proporciona para cualquiera de las siguientes opciones:
Para obtener más información sobre las opciones de configuración que posee el operador de Kubernetes, consulte Configuración exclusiva del operador de Kubernetes de MongoDB.
Para saber qué opciones de configuración puedes utilizar, consulta Opciones avanzadas para implementaciones de MongoDB en la documentación de Ops Manager.
spec.configSrv.agenttipo: colección
Configuración del MongoDB Agent para cada nodo del servidor de configuración.
spec.configSrv.agent.startupOptionstipo: colección
MongoDB Agent settings con la que desea iniciar cada nodo de servidor de configuración.
Debe proporcionar la configuración de MongoDB Agent como pares clave-valor. Los valores deben ser cadenas.
Para obtener una lista de la configuración admitida de MongoDB Agent, consulta:
Configuración del agente MongoDB para proyectos de Cloud Manager.
Configuración del MongoDB Agent para la versión de Ops Manager que implementaste con el operador de Kubernetes.
1 2 apiVersion: mongodb.com/v1 3 kind: MongoDB 4 metadata: 5 name: my-sharded-cluster-options 6 spec: 7 version: "8.0.0" 8 type: ShardedCluster 9 opsManager: 10 configMapRef: 11 name: my-project 12 credentials: my-credentials 13 persistent: true 14 shardCount: 2 15 mongodsPerShardCount: 3 16 mongosCount: 2 17 configServerCount: 1 18 19 mongos: 20 agent: 21 startupOptions: 22 maxLogFiles: "30" 23 24 configSrv: 25 agent: 26 startupOptions: 27 dialTimeoutSeconds: "40" 28 shard: 29 agent: 30 startupOptions: 31 serverSelectionTimeoutSeconds: "20" 32 ...
spec.configSrvPodSpecTipo: objeto
El objeto que contiene las especificaciones para los Pods del servidor de configuración de MongoDB CustomResourceDefinition.
spec.configSrvPodSpec.persistence.singletipo: colección
Haga que el Operador de Kubernetes cree un Reclamo de Volumen Persistente y monte los tres directorios de datos, diario y registros en un mismo Volumen Persistente.
Nota
Debes establecer los valores en esta colección
spec.persistent: truesi.Puedes definir esta colección o bien las
persistence.multiplecolecciones pero no ambas.
EscalarTipo de datoDescripciónlabelSelectorstring
Etiqueta utilizada para vincular volúmenes montados a directorios.
storagestring
Tamaño mínimo del volumen persistente que debe montarse. Este valor se expresa como un entero seguido de una unidad de almacenamiento en notación JEDEC.
El valor por defecto es 5 Gi.
Por ejemplo, si cada nodo de servidor de configuración necesita 60 gigabytes de espacio de almacenamiento, configure este valor en
60Gi.storageClassstring
Tipo de almacenamiento especificado en una notificación de volumen persistente. Puede crear este tipo de almacenamiento como un objeto StorageClass antes de usarlo en esta especificación de objeto.
Asegúrate de establecer el StorageClass
reclaimPolicycomo Retain. Esto garantiza que los datos se conserven cuando se elimine una Solicitud de Volumen Persistente.
spec.configSrvPodSpec.persistence.multiple.datatipo: colección
Hace que el operador de Kubernetes cree un reclamo de volumen persistente y monte un directorio para datos en su propio volumen persistente.
Nota
Debes establecer los valores en esta colección
spec.persistent: truesi.Puede establecer esta colección o la colección
persistence.single, pero no ambas.
EscalarTipo de datoDescripciónlabelSelectorstring
Etiqueta utilizada para vincular volúmenes montados a directorios.
storagestring
Capacidad mínima de almacenamiento que debe estar disponible en un nodo de Kubernetes para alojar cada miembro del servidor de configuración en Kubernetes. Este valor se expresa como un entero seguido de una unidad de almacenamiento en notación JEDEC.
El valor por defecto es 16 Gi.
Por ejemplo, si este recurso
MongoDBrequiere 60 gigabytes de espacio de almacenamiento, establezca este valor en60Gi.storageClassstring
Tipo de almacenamiento necesario para cada nodo del servidor de configuración. Puedes crear este tipo de almacenamiento como un StorageClass objeto antes de usarlo en esta especificación de objeto.
Asegúrate de establecer el StorageClass
reclaimPolicycomo Retain. Esto garantiza que los datos se conserven cuando se elimine una Solicitud de Volumen Persistente.
spec.configSrvPodSpec.persistence.multiple.journaltipo: colección
Permite que Kubernetes Operator cree un Reclamación de volumen persistente y monte un directorio para el diario en su propio Volumen persistente.
Nota
Debes establecer los valores en esta colección
spec.persistent: truesi.Puede establecer esta colección o la colección
persistence.single, pero no ambas.
EscalarTipo de datoDescripciónlabelSelectorstring
Etiqueta utilizada para vincular volúmenes montados a directorios.
storagestring
Capacidad mínima de almacenamiento que debe estar disponible en un nodo de Kubernetes para alojar cada miembro del servidor de configuración en Kubernetes. Este valor se expresa como un entero seguido de una unidad de almacenamiento en notación JEDEC.
El valor por defecto es 1Gi.
Por ejemplo, si este recurso
MongoDBrequiere 60 gigabytes de espacio de almacenamiento, establezca este valor en60Gi.storageClassstring
Tipo de almacenamiento necesario para cada nodo del servidor de configuración. Puedes crear este tipo de almacenamiento como un StorageClass objeto antes de usarlo en esta especificación de objeto.
Asegúrate de establecer el StorageClass
reclaimPolicycomo Retain. Esto garantiza que los datos se conserven cuando se elimine una Solicitud de Volumen Persistente.
spec.configSrvPodSpec.persistence.multiple.logstipo: colección
Hace que el operador de Kubernetes cree un Reclamo de volumen persistente y monte un directorio para los registros en su propio Volumen Persistente.
Nota
Debes establecer los valores en esta colección
spec.persistent: truesi.Puede establecer esta colección o la colección
persistence.single, pero no ambas.
EscalarTipo de datoDescripciónlabelSelectorstring
Etiqueta utilizada para vincular volúmenes montados a directorios.
storagestring
Capacidad mínima de almacenamiento que debe estar disponible en un nodo de Kubernetes para alojar cada miembro del servidor de configuración en Kubernetes. Este valor se expresa como un entero seguido de una unidad de almacenamiento en notación JEDEC.
El valor por defecto es 3Gi.
Por ejemplo, si este recurso
MongoDBrequiere 60 gigabytes de espacio de almacenamiento, establezca este valor en60Gi.storageClassstring
Tipo de almacenamiento necesario para cada nodo del servidor de configuración. Puedes crear este tipo de almacenamiento como un StorageClass objeto antes de usarlo en esta especificación de objeto.
Asegúrate de establecer el StorageClass
reclaimPolicycomo Retain. Esto garantiza que los datos se conserven cuando se elimine una Solicitud de Volumen Persistente.
spec.configSrvPodSpec.podTemplatetipo: colección
Plantilla para los pods de Kubernetes que el operador de controladores MongoDB para Kubernetes crea para cada miembro del servidor de configuración.
Los valores de la plantilla tienen prioridad sobre los valores especificados en
spec.configSrvPodSpec.Nota
El Operador de Kubernetes no valida los campos que se proporcionan en
spec.configSrvPodSpec.podTemplate.
spec.configSrvPodSpec.podTemplate.metadatatipo: colección
Metadatos para los Pods de Kubernetes que el MongoDB Controllers for Kubernetes Operator crea para cada nodo del servidor de configuración.
Para revisar qué campos puedes agregar a
spec.configSrvPodSpec.podTemplate.metadata, consulta la documentación de Kubernetes.
spec.configSrvPodSpec.podTemplate.spectipo: colección
Especificaciones de los pods de Kubernetes que el operador de controladores MongoDB para Kubernetes crea para cada miembro del servidor de configuración.
Para revisar los campos que puedes añadir a
spec.configSrvPodSpec.podTemplate.spec, consulta la Kubernetes PodSpec v1 Core API.Nota
Cuando añades contenedores a
spec.configSrvPodSpec.podTemplate.spec.containers, el Kubernetes operador los agrega al pod de Kubernetes. Estos contenedores se agregan a cada contenedor de nodos del servidor de configuración en el pod.Utiliza esta configuración para especificar la asignación de CPU y RAM para cada pod. Para obtener ejemplos, consulta las muestras en GitHub.
spec.configSrvPodSpec.podTemplate.spec.affinity.podAffinitytipo: colección
Regla de Kubernetes para determinar si varios recursos
MongoDBPods deben estar ubicados junto con otros Pods. Para obtener más información sobre los casos de uso, consulta afinidad y anti-afinidad en la documentación de Kubernetes.
spec.configSrvPodSpec.podTemplate.spec.affinity.nodeAffinitytipo: colección
Regla de Kubernetes para colocar pods para el conjunto de réplicas en un rango específico de nodos.
Para un rendimiento de lectura-escritura optimizado, utiliza reglas de afinidad de nodos que restrinjan los Pods para ejecutarse en nodos en particular, o para dar preferencia a la ejecución en nodos en particular.
spec.configSrvPodSpec.podTemplate.spec.affinity.podAntiAffinityTipo: string
Default: kubernetes.io/hostname
Establece una regla para distribuir Pods que alojan el recurso
MongoDBen diferentes ubicaciones. Una ubicación puede ser un solo nodo, rack o región. De forma predeterminada, el operador de Kubernetes intenta distribuir los pods entre diferentes nodos.
spec.configSrvPodSpec.podTemplate.spec.affinity.podAntiAffinity.requiredDuringSchedulingIgnoredDuringExecution.topologyKeyTipo: string
Default: kubernetes.io/hostname
Esta clave define qué etiqueta se usa para determinar a qué dominio de la topología pertenece un nodo.
spec.mongodsPerShardCountTipo: entero
Obligatorio. Número de miembros por fragmento.
spec.mongosCountTipo: entero
Obligatorio. Número de
mongosinstancias en el clúster particionado.
spec.mongos.additionalMongodConfigtipo: colección
Opciones de configuración adicionales con las que desea iniciar cada instancia de mongos.
El operador de Kubernetes admite todas las opciones de configuración que admite la versión de MongoDB que implementa a través del agente de MongoDB, excepto que el operador de Kubernetes anula los valores que proporciona para cualquiera de las siguientes opciones:
Para obtener más información sobre las opciones de configuración que posee el operador de Kubernetes, consulte Configuración exclusiva del operador de Kubernetes de MongoDB.
Para saber qué opciones de configuración puedes utilizar, consulta Opciones avanzadas para implementaciones de MongoDB en la documentación de Ops Manager.
spec.mongos.agenttipo: colección
Configuración de MongoDB Agent para cada instancia
mongos.
spec.mongos.agent.startupOptionstipo: colección
Configuración de MongoDB Agent con la que se desea iniciar cada instancia de
mongos.Debe proporcionar la configuración de MongoDB Agent como pares clave-valor. Los valores deben ser cadenas.
Para obtener una lista de la configuración admitida de MongoDB Agent, consulta:
Configuración del agente MongoDB para proyectos de Cloud Manager.
Configuración del MongoDB Agent para la versión de Ops Manager que implementaste con el operador de Kubernetes.
1 2 apiVersion: mongodb.com/v1 3 kind: MongoDB 4 metadata: 5 name: my-sharded-cluster-options 6 spec: 7 version: "8.0.0" 8 type: ShardedCluster 9 opsManager: 10 configMapRef: 11 name: my-project 12 credentials: my-credentials 13 persistent: true 14 shardCount: 2 15 mongodsPerShardCount: 3 16 mongosCount: 2 17 configServerCount: 1 18 19 mongos: 20 agent: 21 startupOptions: 22 maxLogFiles: "30" 23 24 configSrv: 25 agent: 26 startupOptions: 27 dialTimeoutSeconds: "40" 28 shard: 29 agent: 30 startupOptions: 31 serverSelectionTimeoutSeconds: "20" 32 ...
spec.mongosPodSpecTipo: objeto
Objeto que contiene las especificaciones para los Pods de mongos de MongoDB CustomResourceDefinition.
spec.mongosPodSpec.podTemplatetipo: colección
Plantilla para los Pods de Kubernetes que los Controladores de MongoDB para el Operador de Kubernetes crean para cada instancia
mongos.Los valores de la plantilla tienen prioridad sobre los valores especificados en
spec.mongosPodSpec.Nota
El Operador de Kubernetes no valida los campos que se proporcionan en
spec.mongosPodSpec.podTemplate.
spec.mongosPodSpec.podTemplate.metadatatipo: colección
Metadatos para los Kubernetes Pods que los Controladores de MongoDB para el Operador de Kubernetes crea para cada instancia
mongos.Para revisar qué campos puedes agregar a
spec.mongosPodSpec.podTemplate.metadata, consulta la documentación de Kubernetes.
spec.mongosPodSpec.podTemplate.spectipo: colección
Especificaciones de los Pods de Kubernetes que los Controladores de MongoDB operador crean para cada
mongosinstancia.Para revisar los campos que puedes añadir a
spec.mongosPodSpec.podTemplate.spec, consulta la Kubernetes PodSpec v1 Core API.Nota
Cuando añades contenedores a
spec.mongosPodSpec.podTemplate.spec.containers, el Kubernetes operador los agrega al pod de Kubernetes. Estos contenedores se anexan a cadamongosde contenedores de instancias del pod.Utiliza esta configuración para especificar la asignación de CPU y RAM para cada pod. Para obtener ejemplos, consulta las muestras en GitHub.
spec.mongosPodSpec.podTemplate.spec.affinity.podAffinitytipo: colección
opcional. Kubernetes regla para determinar si varios Pods de recursos
MongoDBdeben ubicarse junto con otros Pods.
spec.mongosPodSpec.podTemplate.spec.affinity.nodeAffinitytipo: colección
Regla de Kubernetes para colocar pods para el conjunto de réplicas en un rango específico de nodos.
Para un rendimiento de lectura-escritura optimizado, utiliza reglas de afinidad de nodos que restrinjan los Pods para ejecutarse en nodos en particular, o para dar preferencia a la ejecución en nodos en particular.
spec.mongosPodSpec.podTemplate.spec.affinity.podAntiAffinityTipo: string
Default: kubernetes.io/hostname
Establece una regla para distribuir Pods que alojan el recurso
MongoDBen diferentes ubicaciones. Una ubicación puede ser un solo nodo, rack o región. De forma predeterminada, el operador de Kubernetes intenta distribuir los pods entre diferentes nodos.
spec.mongosPodSpec.podTemplate.spec.affinity.podAntiAffinity.requiredDuringSchedulingIgnoredDuringExecution.topologyKeyTipo: string
Default: kubernetes.io/hostname
Esta clave define qué etiqueta se usa para determinar a qué dominio de la topología pertenece un nodo.
spec.shardCountTipo: entero
Obligatorio. Número de particiones en el clúster.
spec.shard.additionalMongodConfigtipo: colección
Opciones de configuración adicionales con las que desea iniciar cada miembro del fragmento del clúster fragmentado.
El operador de Kubernetes admite todas las opciones de configuración que admite la versión de MongoDB que implementa a través del agente de MongoDB, excepto que el operador de Kubernetes anula los valores que proporciona para cualquiera de las siguientes opciones:
Para obtener más información sobre las opciones de configuración que posee el operador de Kubernetes, consulte Configuración exclusiva del operador de Kubernetes de MongoDB.
Para saber qué opciones de configuración puedes utilizar, consulta Opciones avanzadas para implementaciones de MongoDB en la documentación de Ops Manager.
spec.shard.agenttipo: colección
Configuración del agente MongoDB para cada miembro del fragmento del clúster fragmentado.
spec.shard.agent.startupOptionstipo: colección
Ajustes del MongoDB Agent con los que deseas iniciar cada nodo del la partición del clúster.
Debe proporcionar la configuración de MongoDB Agent como pares clave-valor. Los valores deben ser cadenas.
Para obtener una lista de la configuración admitida de MongoDB Agent, consulta:
Configuración del agente MongoDB para proyectos de Cloud Manager.
Configuración del MongoDB Agent para la versión de Ops Manager que implementaste con el operador de Kubernetes.
1 2 apiVersion: mongodb.com/v1 3 kind: MongoDB 4 metadata: 5 name: my-sharded-cluster-options 6 spec: 7 version: "8.0.0" 8 type: ShardedCluster 9 opsManager: 10 configMapRef: 11 name: my-project 12 credentials: my-credentials 13 persistent: true 14 shardCount: 2 15 mongodsPerShardCount: 3 16 mongosCount: 2 17 configServerCount: 1 18 19 mongos: 20 agent: 21 startupOptions: 22 maxLogFiles: "30" 23 24 configSrv: 25 agent: 26 startupOptions: 27 dialTimeoutSeconds: "40" 28 shard: 29 agent: 30 startupOptions: 31 serverSelectionTimeoutSeconds: "20" 32 ...
spec.shardPodSpecTipo: objeto
Objeto que contiene las especificaciones para el MongoDB CustomResourceDefinition partición Pods.
spec.shardPodSpec.persistence.multiple.datatipo: colección
Hace que el operador de Kubernetes cree un reclamo de volumen persistente y monte un directorio para datos en su propio volumen persistente.
Nota
Debes establecer los valores en esta colección
spec.persistent: truesi.Puede establecer esta colección o la colección
persistence.single, pero no ambas.
EscalarTipo de datoDescripciónlabelSelectorstring
Etiqueta utilizada para vincular volúmenes montados a directorios.
storagestring
Capacidad mínima de almacenamiento que debe estar disponible en un nodo de Kubernetes para alojar cada nodo de un clúster en Kubernetes. Este valor se expresa como un número entero seguido de una unidad de almacenamiento en notación JEDEC.
El valor por defecto es 16 Gi.
Por ejemplo, si este recurso
MongoDBrequiere 60 gigabytes de espacio de almacenamiento, establezca este valor en60Gi.storageClassstring
Tipo de almacenamiento necesario para cada miembro del fragmento del clúster fragmentado. Puede crear este tipo de almacenamiento como un objeto StorageClass antes de usarlo en esta especificación de objeto.
Asegúrate de establecer el StorageClass
reclaimPolicycomo Retain. Esto garantiza que los datos se conserven cuando se elimine una Solicitud de Volumen Persistente.
spec.shardPodSpec.persistence.multiple.journaltipo: colección
Permite que Kubernetes Operator cree un Reclamación de volumen persistente y monte un directorio para el diario en su propio Volumen persistente.
Nota
Debes establecer los valores en esta colección
spec.persistent: truesi.Puede establecer esta colección o la colección
persistence.single, pero no ambas.
EscalarTipo de datoDescripciónlabelSelectorstring
Etiqueta utilizada para vincular volúmenes montados a directorios.
storagestring
Capacidad mínima de almacenamiento que debe estar disponible en un nodo de Kubernetes para alojar cada nodo de un clúster en Kubernetes. Este valor se expresa como un número entero seguido de una unidad de almacenamiento en notación JEDEC.
El valor por defecto es 1Gi.
Por ejemplo, si este recurso
MongoDBrequiere 60 gigabytes de espacio de almacenamiento, establezca este valor en60Gi.storageClassstring
Tipo de almacenamiento necesario para cada miembro del fragmento del clúster fragmentado. Puede crear este tipo de almacenamiento como un objeto StorageClass antes de usarlo en esta especificación de objeto.
Asegúrate de establecer el StorageClass
reclaimPolicycomo Retain. Esto garantiza que los datos se conserven cuando se elimine una Solicitud de Volumen Persistente.
spec.shardPodSpec.persistence.multiple.logstipo: colección
Hace que el operador de Kubernetes cree un Reclamo de volumen persistente y monte un directorio para los registros en su propio Volumen Persistente.
Nota
Debes establecer los valores en esta colección
spec.persistent: truesi.Puede establecer esta colección o la colección
persistence.single, pero no ambas.
EscalarTipo de datoDescripciónlabelSelectorstring
Etiqueta utilizada para vincular volúmenes montados a directorios.
storagestring
Capacidad mínima de almacenamiento que debe estar disponible en un nodo de Kubernetes para alojar cada nodo de un clúster en Kubernetes. Este valor se expresa como un número entero seguido de una unidad de almacenamiento en notación JEDEC.
El valor por defecto es 3Gi.
Por ejemplo, si este recurso
MongoDBrequiere 60 gigabytes de espacio de almacenamiento, establezca este valor en60Gi.storageClassstring
Tipo de almacenamiento necesario para cada miembro del fragmento del clúster fragmentado. Puede crear este tipo de almacenamiento como un objeto StorageClass antes de usarlo en esta especificación de objeto.
Asegúrate de establecer el StorageClass
reclaimPolicycomo Retain. Esto garantiza que los datos se conserven cuando se elimine una Solicitud de Volumen Persistente.
spec.shardPodSpec.podTemplatetipo: colección
Plantilla para los pods de Kubernetes que el operador de controladores MongoDB para Kubernetes crea para cada miembro del fragmento del clúster fragmentado.
Los valores de la plantilla tienen prioridad sobre los valores especificados en
spec.shardPodSpec.Nota
El Operador de Kubernetes no valida los campos que se proporcionan en
spec.shardPodSpec.podTemplate.
spec.shardPodSpec.podTemplate.metadatatipo: colección
Metadatos para los pods de Kubernetes que el operador MongoDB Controllers for Kubernetes crea para cada nodo de particiones de clúster.
Para revisar qué campos puedes agregar a
spec.shardPodSpec.podTemplate.metadata, consulta la documentación de Kubernetes.
spec.shardPodSpec.podTemplate.spectipo: colección
Especificaciones de los pods de Kubernetes que los controladores de MongoDB para el operador de Kubernetes crean para cada nodo de clúster.
Para revisar los campos que puedes añadir a
spec.shardPodSpec.podTemplate.spec, consulta la Kubernetes PodSpec v1 Core API.Nota
Cuando añades contenedores a
spec.shardPodSpec.podTemplate.spec.containers, el Kubernetes operador los agrega al pod de Kubernetes. Estos contenedores se anexan a cada uno de los contenedores de los nodos de particiones del clúster en el pod.Utiliza esta configuración para especificar la asignación de CPU y RAM para cada pod. Para obtener ejemplos, consulta las muestras en GitHub.
spec.shardPodSpec.podTemplate.spec.affinity.podAffinityTipo: string
Regla de Kubernetes para determinar si varios recursos
MongoDBPods deben estar ubicados junto con otros Pods. Para obtener más información sobre los casos de uso, consulta afinidad y anti-afinidad en la documentación de Kubernetes.
spec.shardPodSpec.podTemplate.spec.affinity.nodeAffinityTipo: string
Regla de Kubernetes para colocar pods para el conjunto de réplicas en un rango específico de nodos.
Para un rendimiento de lectura-escritura optimizado, utiliza reglas de afinidad de nodos que restrinjan los Pods para ejecutarse en nodos en particular, o para dar preferencia a la ejecución en nodos en particular.
spec.shardPodSpec.podTemplate.spec.affinity.podAntiAffinityTipo: string
Default: kubernetes.io/hostname
Establece una regla para distribuir Pods que alojan el recurso
MongoDBen diferentes ubicaciones. Una ubicación puede ser un solo nodo, rack o región. De forma predeterminada, el operador de Kubernetes intenta distribuir los pods entre diferentes nodos.
spec.shardPodSpec.podTemplate.spec.affinity.podAntiAffinity.requiredDuringSchedulingIgnoredDuringExecution.topologyKeyTipo: string
Default: kubernetes.io/hostname
Esta clave define qué etiqueta se usa para determinar a qué dominio de la topología pertenece un nodo.
spec.shardSpecificPodSpecTipo: arreglo
Lista que contiene anulaciones de StatefulSet por fragmento.
spec.shardSpecificPodSpec.podTemplatetipo: colección
Plantilla para los Pods de Kubernetes que los Controladores MongoDB para Kubernetes operador crean para la partición específica.
Los valores de la plantilla tienen prioridad sobre los valores especificados en
spec.shardSpecificPodSpec.Nota
El Operador de Kubernetes no valida los campos que se proporcionan en
spec.shardSpecificPodSpec.podTemplate.
spec.shardSpecificPodSpec.podTemplate.metadatatipo: colección
Metadatos para los pods de Kubernetes que los controladores de MongoDB para el operador de Kubernetes crean para la partición específica.
Para revisar qué campos puedes agregar a
spec.shardSpecificPodSpec.podTemplate.metadata, consulta la documentación de Kubernetes.
spec.shardSpecificPodSpec.podTemplate.spectipo: colección
Especificaciones de los pods de Kubernetes que los controladores de MongoDB del operador de MongoDB para Kubernetes crean para la partición específica.
Para revisar los campos que puedes añadir a
spec.shardSpecificPodSpec.podTemplate.spec, consulta la Kubernetes PodSpec v1 Core API.Nota
Al agregar contenedores a
spec.shardSpecificPodSpec.podTemplate.spec.containers, el operador de Kubernetes los agrega al pod de Kubernetes. Estos contenedores se agregan a los contenedores de fragmentos específicos del pod.Utiliza esta configuración para especificar la asignación de CPU y RAM para cada pod. Para obtener ejemplos, consulta las muestras en GitHub.
spec.shardSpecificPodSpec.podTemplate.spec.affinity.podAffinityTipo: string
Regla de Kubernetes para determinar si varios recursos
MongoDBPods deben estar ubicados junto con otros Pods. Para obtener más información sobre los casos de uso, consulta afinidad y anti-afinidad en la documentación de Kubernetes.
spec.shardSpecificPodSpec.podTemplate.spec.affinity.podAntiAffinityTipo: string
Default: kubernetes.io/hostname
Establece una regla para distribuir Pods que alojan el recurso
MongoDBen diferentes ubicaciones. Una ubicación puede ser un solo nodo, rack o región. De forma predeterminada, el operador de Kubernetes intenta distribuir los pods entre diferentes nodos.
spec.shardSpecificPodSpec.podTemplate.spec.affinity.podAntiAffinity.requiredDuringSchedulingIgnoredDuringExecution.topologyKeyTipo: string
Default: kubernetes.io/hostname
Esta clave define qué etiqueta se usa para determinar a qué dominio de la topología pertenece un nodo.
spec.topologyTipo: string
Opcional
Por defecto:
SingleClusterDefine la topología del clúster fragmentado. No puede cambiarse para una implementación existente. Si se establece en
MultiCluster:Todos los componentes del clúster fragmentado deben tener
clusterSpecListdefinido:spec.mongos.clusterSpecListspec.configSrv.clusterSpecListspec.shard.clusterSpecList
Los siguientes campos se ignoran, ya que sus valores equivalentes se pasan para cada clúster en los objetos
spec.<section>.clusterSpecList:spec.mongodsPerShardCountse define enspec.shard.clusterSpecList.membersspec.mongosCountse define enspec.mongos.clusterSpecList.membersspec.configServerCountse define enspec.configSrv.clusterSpecList.membersspec.shardOverrides.memberConfigse define enspec.shardOverrides.clusterSpecList.memberConfigspec.shardOverrides.membersse define enspec.shardOverrides.clusterSpecList.membersspec.shardOverrides.statefulSetse define enspec.shardOverrides.clusterSpecList.statefulSet
Ejemplo:
apiVersion: mongodb.com/v1 kind: MongoDB metadata: name: sc spec: shardCount: 3 # we don't specify mongodsPerShardCount, mongosCount and configServerCount as they don't make sense for multi-cluster topology: MultiCluster type: ShardedCluster version: 7.0.12 cloudManager: configMapRef: name: my-project credentials: my-credentials persistent: true shard: clusterSpecList: - clusterName: member-cluster-0 members: 2 # each shard will have 2 members in cluster 0, unless overriden - clusterName: member-cluster-1 members: 2 - clusterName: member-cluster-2 members: 1 shardOverrides: - shardNames: [sc-2] # this override will apply to the third shard (here, shards are indexed from 0 to 2 as we have 3 shards) clusterSpecList: - clusterName: member-cluster-0 # all other fields are optional, if not provided the fields from matching member cluster from shard.clusterSpecList will be taken by default members: 3 - clusterName: member-cluster-1 # we don't deploy this shard to member-cluster-1 # Note that it is also possible to make it explicit with members: 0 # we don't provide entry for clusterName: member-cluster-1, so it won't be deployed there - clusterName: member-cluster-2 members: 2 configSrv: clusterSpecList: - clusterName: member-cluster-0 members: 2 # config server will have 2 members in this cluster - clusterName: member-cluster-1 members: 1 - clusterName: member-cluster-2 members: 2 mongos: clusterSpecList: - clusterName: member-cluster-0 members: 2 # router will have 2 members in this cluster - clusterName: member-cluster-1 members: 1 Los siguientes campos se refieren exclusivamente a implementaciones en las que
topology=MultiCluster:spec.configSrv.clusterSpecListNota
Este campo está disponible exclusivamente para implementaciones de clústeres fragmentados de múltiples clústeres.
Tipo: arreglo de objetos
Obligatorio si
topology=MultiClusterUn arreglo de objetos para uso en implementaciones de clústeres particionados multiclúster con los siguientes campos de nivel superior:
clusterNameTipo: string
Nombre del clúster donde el operador de controladores MongoDB para Kubernetes programa el StatefulSet.
externalAccesstipo: colección
Especificación para exponer tu implementación de MongoDB en multi-Kubernetes para conexiones externas. Para aprender cómo conectarse a su implementación de MongoDB Multi-Kubernetes desde fuera del clúster de Kubernetes, consulte Conectarse al recurso multi-clúster desde fuera de Kubernetes.
Esta configuración se aplica a los servicios de todos los clústeres. Para anular esta configuración global en un clúster específico, utilice spec.clusterSpecList.externalAccess.externalService.
Si añades
spec.externalAccess, el Operador de Kubernetes crea un servicio externo para cada Pod en un set de réplicas. Los servicios externos proporcionan un punto de entrada externo para cada pod de la base de datos MongoDB en un clúster. Cada servicio externo tiene selectores que emparejan el servicio externo con un Pod específico.Si agrega esta configuración sin ningún valor, el Operador de Kubernetes crea un servicio externo con los siguientes valores por defecto:
CampoValorDescripciónName<pod-name>-svc-externalNombre del Servicio externo. No puedes cambiar este valor.
TypeLoadBalancerCrea un servicio externo LoadBalancer.
Port<Port Number>Un puerto para
mongod.publishNotReadyAddresstrueEspecifica que registros DNS se crean incluso si el Pod no está listo. No configures
falsepara ningún Pod de base de datos.Nota
Si establece spec.clusterSpecList.externalAccess.externalDomain, el servicio externo agrega otro puerto (
Port Number + 1) para copias de seguridad.
membersTipo: número
Número de miembros en el set de réplicas de MongoDB.
memberConfigtipo: colección
Especificación para cada partición de MongoDB y sus miembros en tu implementación de clúster multi-Kubernetes de MongoDB.
El orden de los elementos en el objeto para partición debe reflejar el orden de los miembros en el set de réplicas. Por ejemplo, el primer elemento afecta al Pod en el índice
0, el segundo elemento afecta al índice1, y así sucesivamente.Ejemplo
Se debe considerar el siguiente ejemplo de especificación para una implementación de MongoDB en un clúster multi-Kubernetes con tres sets de réplicas:
apiVersion: mongodb.com/v1 kind: MongoDBMultiCluster metadata: name: multi-replica-set spec: version: 8.0.0 type: ReplicaSet duplicateServiceObjects: false credentials: my-credentials opsManager: configMapRef: name: my-project clusterSpecList: - clusterName: cluster1.example.com members: 2 memberConfig: - votes: 1 priority: "0.5" tags: tag1: "value1" environment: "prod" - votes: 1 priority: "1.5" tags: tag2: "value2" environment: "prod" - clusterName: cluster2.example.com members: 1 memberConfig: - votes: 1 priority: "0.5" tags: tag1: "value1" environment: "prod" - clusterName: cluster3.example.com members: 1 memberConfig: - votes: 1 priority: "0.5" tags: tag1: "value1" environment: "prod"
podSpec.persistencetipo: colección
Solo disponible en
clusterSpecItemlos objetos transferidos aspec.configSrv.clusterSpecListspec.shard.clusterSpecListy. Anula la configuración de persistencia existente para un clúster determinado.
statefulSettipo: colección
Proporciona la configuración para la anulación de StatefulSet para cada uno de los StatefulSets del clúster en una implementación de MongoDB en clústeres múltiples de Kubernetes. Para configurar la configuración global que se aplica a todos los clústeres en tu implementación de clústeres múltiples de MongoDB en Kubernetes, consulta spec.statefulSet.spec.
Esta configuración se aplica solo a tipos de recursos de sets de réplicas en implementaciones de MongoDB multiclúster en Kubernetes.
spec.duplicateServiceObjectsNota
Este campo está disponible exclusivamente para implementaciones de clústeres fragmentados de múltiples clústeres.
Tipo: booleano
Opcional
Por defecto:
trueSe ignora si la topología no es
MultiCluster. Se aplica a los servicios para todos los componentes del clúster fragmentado:mongos,configSrvyshards.- Si se configura en
true: - El operador de Kubernetes crea todos los
Pod Servicesde todos los clústeres miembros en cada clúster miembro. - Si se configura en
false: - El Operador de Kubernetes crea solo
- Si se configura en
spec.mongos.clusterSpecListNota
Este campo está disponible exclusivamente para implementaciones de clústeres fragmentados de múltiples clústeres.
Tipo: arreglo de objetos
Obligatorio si
topology=MultiClusterUn arreglo de objetos para uso en implementaciones de clústeres particionados multiclúster con los siguientes campos de nivel superior:
clusterNameTipo: string
Nombre del clúster donde el operador de controladores MongoDB para Kubernetes programa el StatefulSet.
externalAccesstipo: colección
Especificación para exponer tu implementación de MongoDB en multi-Kubernetes para conexiones externas. Para aprender cómo conectarse a su implementación de MongoDB Multi-Kubernetes desde fuera del clúster de Kubernetes, consulte Conectarse al recurso multi-clúster desde fuera de Kubernetes.
Esta configuración se aplica a los servicios de todos los clústeres. Para anular esta configuración global en un clúster específico, utilice spec.clusterSpecList.externalAccess.externalService.
Si añades
spec.externalAccess, el Operador de Kubernetes crea un servicio externo para cada Pod en un set de réplicas. Los servicios externos proporcionan un punto de entrada externo para cada pod de la base de datos MongoDB en un clúster. Cada servicio externo tiene selectores que emparejan el servicio externo con un Pod específico.Si agrega esta configuración sin ningún valor, el Operador de Kubernetes crea un servicio externo con los siguientes valores por defecto:
CampoValorDescripciónName<pod-name>-svc-externalNombre del Servicio externo. No puedes cambiar este valor.
TypeLoadBalancerCrea un servicio externo LoadBalancer.
Port<Port Number>Un puerto para
mongod.publishNotReadyAddresstrueEspecifica que registros DNS se crean incluso si el Pod no está listo. No configures
falsepara ningún Pod de base de datos.Nota
Si establece spec.clusterSpecList.externalAccess.externalDomain, el servicio externo agrega otro puerto (
Port Number + 1) para copias de seguridad.
membersTipo: número
Número de miembros en el set de réplicas de MongoDB.
memberConfigtipo: colección
Especificación para cada partición de MongoDB y sus miembros en tu implementación de clúster multi-Kubernetes de MongoDB.
El orden de los elementos en el objeto para partición debe reflejar el orden de los miembros en el set de réplicas. Por ejemplo, el primer elemento afecta al Pod en el índice
0, el segundo elemento afecta al índice1, y así sucesivamente.Ejemplo
Se debe considerar el siguiente ejemplo de especificación para una implementación de MongoDB en un clúster multi-Kubernetes con tres sets de réplicas:
apiVersion: mongodb.com/v1 kind: MongoDBMultiCluster metadata: name: multi-replica-set spec: version: 8.0.0 type: ReplicaSet duplicateServiceObjects: false credentials: my-credentials opsManager: configMapRef: name: my-project clusterSpecList: - clusterName: cluster1.example.com members: 2 memberConfig: - votes: 1 priority: "0.5" tags: tag1: "value1" environment: "prod" - votes: 1 priority: "1.5" tags: tag2: "value2" environment: "prod" - clusterName: cluster2.example.com members: 1 memberConfig: - votes: 1 priority: "0.5" tags: tag1: "value1" environment: "prod" - clusterName: cluster3.example.com members: 1 memberConfig: - votes: 1 priority: "0.5" tags: tag1: "value1" environment: "prod"
statefulSettipo: colección
Proporciona la configuración para la anulación de StatefulSet para cada uno de los StatefulSets del clúster en una implementación de MongoDB en clústeres múltiples de Kubernetes. Para configurar la configuración global que se aplica a todos los clústeres en tu implementación de clústeres múltiples de MongoDB en Kubernetes, consulta spec.statefulSet.spec.
Esta configuración se aplica solo a tipos de recursos de sets de réplicas en implementaciones de MongoDB multiclúster en Kubernetes.
spec.shard.clusterSpecListNota
Este campo está disponible exclusivamente para implementaciones de clústeres fragmentados de múltiples clústeres.
Tipo: arreglo de objetos
Obligatorio si
topology=MultiClusterUn arreglo de objetos para uso en implementaciones de clústeres particionados multiclúster con los siguientes campos de nivel superior:
clusterNameTipo: string
Nombre del clúster donde el operador de controladores MongoDB para Kubernetes programa el StatefulSet.
externalAccesstipo: colección
Especificación para exponer tu implementación de MongoDB en multi-Kubernetes para conexiones externas. Para aprender cómo conectarse a su implementación de MongoDB Multi-Kubernetes desde fuera del clúster de Kubernetes, consulte Conectarse al recurso multi-clúster desde fuera de Kubernetes.
Esta configuración se aplica a los servicios de todos los clústeres. Para anular esta configuración global en un clúster específico, utilice spec.clusterSpecList.externalAccess.externalService.
Si añades
spec.externalAccess, el Operador de Kubernetes crea un servicio externo para cada Pod en un set de réplicas. Los servicios externos proporcionan un punto de entrada externo para cada pod de la base de datos MongoDB en un clúster. Cada servicio externo tiene selectores que emparejan el servicio externo con un Pod específico.Si agrega esta configuración sin ningún valor, el Operador de Kubernetes crea un servicio externo con los siguientes valores por defecto:
CampoValorDescripciónName<pod-name>-svc-externalNombre del Servicio externo. No puedes cambiar este valor.
TypeLoadBalancerCrea un servicio externo LoadBalancer.
Port<Port Number>Un puerto para
mongod.publishNotReadyAddresstrueEspecifica que registros DNS se crean incluso si el Pod no está listo. No configures
falsepara ningún Pod de base de datos.Nota
Si establece spec.clusterSpecList.externalAccess.externalDomain, el servicio externo agrega otro puerto (
Port Number + 1) para copias de seguridad.
membersTipo: número
Número de miembros en el set de réplicas de MongoDB.
memberConfigtipo: colección
Especificación para cada partición de MongoDB y sus miembros en tu implementación de clúster multi-Kubernetes de MongoDB.
El orden de los elementos en el objeto para partición debe reflejar el orden de los miembros en el set de réplicas. Por ejemplo, el primer elemento afecta al Pod en el índice
0, el segundo elemento afecta al índice1, y así sucesivamente.Ejemplo
Se debe considerar el siguiente ejemplo de especificación para una implementación de MongoDB en un clúster multi-Kubernetes con tres sets de réplicas:
apiVersion: mongodb.com/v1 kind: MongoDBMultiCluster metadata: name: multi-replica-set spec: version: 8.0.0 type: ReplicaSet duplicateServiceObjects: false credentials: my-credentials opsManager: configMapRef: name: my-project clusterSpecList: - clusterName: cluster1.example.com members: 2 memberConfig: - votes: 1 priority: "0.5" tags: tag1: "value1" environment: "prod" - votes: 1 priority: "1.5" tags: tag2: "value2" environment: "prod" - clusterName: cluster2.example.com members: 1 memberConfig: - votes: 1 priority: "0.5" tags: tag1: "value1" environment: "prod" - clusterName: cluster3.example.com members: 1 memberConfig: - votes: 1 priority: "0.5" tags: tag1: "value1" environment: "prod"
podSpec.persistencetipo: colección
Solo disponible en
clusterSpecItemlos objetos transferidos aspec.configSrv.clusterSpecListspec.shard.clusterSpecListy. Anula la configuración de persistencia existente para un clúster determinado.
statefulSettipo: colección
Proporciona la configuración para la anulación de StatefulSet para cada uno de los StatefulSets del clúster en una implementación de MongoDB en clústeres múltiples de Kubernetes. Para configurar la configuración global que se aplica a todos los clústeres en tu implementación de clústeres múltiples de MongoDB en Kubernetes, consulta spec.statefulSet.spec.
Esta configuración se aplica solo a tipos de recursos de sets de réplicas en implementaciones de MongoDB multiclúster en Kubernetes.
spec.shardOverridesTipo: arreglo de objetos
Opcional
Lista que contiene las anulaciones por fragmento. Cada objeto contiene los siguientes campos:
shardNamesRequerido
El nombre de la partición al que se aplica esta anulación.
podSpec.PersistenceOpcional
Define cómo el operador de Kubernetes crea y vincula volúmenes persistentes a fragmentos. Para
topology=MultiCluster, establece la configuración de persistencia para todos los clústeres miembros. Puede definir la configuración de persistencia para un clúster miembro específico enspec.shardOverrides.clusterSpecList.persistence.additionalMongodConfigOpcional
Anulación específica de la partición para
spec.shard.additionalMongodConfig.agentOpcional
Anulación específica de la partición para
spec.shard.agent.statefulSetOpcional
Instrucción específica de partición para
spec.shardPodSpec.podTemplateyspec.shard.clusterSpecList.statefulSet.membersOpcional
Disponible solo cuando
topology=SingleCluster. Anulación específica de partición para anulación paraspec.mongodsPerShardCount.memberConfigOpcional
Disponible solo cuando
topology=SingleCluster. Anulación específica de partición paraspec.shard.memberConfig.
spec.shardPodSpec.persistence.singletipo: colección
Haga que el Operador de Kubernetes cree un Reclamo de Volumen Persistente y monte los tres directorios de datos, diario y registros en un mismo Volumen Persistente.
Nota
Debes establecer los valores en esta colección
spec.persistent: truesi.Puedes definir esta colección o bien las
persistence.multiplecolecciones pero no ambas.
EscalarTipo de datoDescripciónlabelSelectorstring
Etiqueta utilizada para vincular volúmenes montados a directorios.
storagestring
Tamaño mínimo del volumen persistente que debe montarse. Este valor se expresa como un entero seguido de una unidad de almacenamiento en notación JEDEC.
El valor por defecto es 16 Gi.
Por ejemplo, si cada nodo de partición de clúster requiere 60 gigabytes de espacio de almacenamiento, establezca este valor en
60Gi.storageClassstring
Tipo de almacenamiento especificado en una notificación de volumen persistente. Puede crear este tipo de almacenamiento como un objeto StorageClass antes de usarlo en esta especificación de objeto.
Asegúrate de establecer el StorageClass
reclaimPolicycomo Retain. Esto garantiza que los datos se conserven cuando se elimine una Solicitud de Volumen Persistente.
Configuraciones de Prometheus
Puedes utilizar Prometheus con tu recurso autónomo, sets de réplicas o clústeres. Para saber más, consulta Implementar un recurso para usar con Prometheus. Para ver un ejemplo, consulte Recurso MongoDB con Prometheus.
Las siguientes configuraciones se aplican cuando se utiliza Prometheus con tu recurso de MongoDB:
spec.prometheusTipo: arreglo
Opcional
Lista que contiene los parámetros para exponer métricas a Prometheus.
spec.prometheus.metricsPathTipo: string
Opcional
Por defecto:
"/metrics"string legible por humanos que indica la ruta al endpoint de métricas. Si no especificas este ajuste, se aplicará el valor por defecto.
spec.prometheus.passwordSecretRefTipo: objeto
Condicional
Objeto que contiene los detalles del secreto para la autenticación HTTP básica. Si deseas utilizar Prometheus con tu recurso de MongoDB, debes especificar esta configuración.
spec.prometheus.passwordSecretRef.keyTipo: string
Opcional
Por defecto:
"password"string legible por seres humanos que identifica la clave en el secreto que almacena la contraseña para la autenticación HTTP básica. Si no especifica esta configuración, se aplicará por defecto.
spec.prometheus.passwordSecretRef.nameTipo: string
Condicional
Etiqueta legible por humanos que identifica el secreto que contiene la contraseña para la autenticación HTTP básica. Si deseas utilizar Prometheus con tu recurso de MongoDB, debes especificar esta configuración.
spec.prometheus.portTipo: entero
Opcional
Predeterminado: 9216
Número que identifica el puerto al que se vinculará el endpoint de métricas. Si no se especifica esta configuración, se aplica el valor por defecto.
spec.prometheus.tlseSecretKeyRefTipo: objeto
Opcional
Objeto que contiene los detalles del secreto para autenticación TLS.
spec.prometheus.tlseSecretKeyRef.keyTipo: string
Opcional
Por defecto:
"password"Cadena legible que identifica la clave en el secreto que almacena la contraseña para la autenticación TLS. Si no se especifica esta configuración, se aplica la predeterminada.
spec.prometheus.tlseSecretKeyRef.nameTipo: string
Condicional
Etiqueta legible por humanos que identifica el secreto que contiene la contraseña para la autenticación TLS. Si desea utilizar Prometheus con su recurso MongoDB y desea utilizar autenticación TLS, debe especificar esta configuración.
Configuración de seguridad
Las siguientes configuraciones de seguridad se aplican solo a los tipos de recursos de set de réplicas y clúster:
spec.security.tls.caTipo: string
Proporciona el nombre del ConfigMap que almacena el CA para el recurso
MongoDB.Importante
Si utilizas una CA personalizada para firmar tus certificados TLS para el recurso
MongoDB, debes especificar este parámetro.El operador de Kubernetes requiere que usted nombre el certificado de recurso
MongoDBcomoca-pemen ConfigMap.
spec.security.certsSecretPrefixTipo: string
Texto para agregar como prefijo a los secretos de Kubernetes que creó y que contienen las claves y certificados TLS de su conjunto de réplicas o clúster fragmentado.
Debes anteponer a tus secretos el prefijo
<prefix>-<metadata.name>.Por ejemplo, si llama a su implementación
my-deploymenty establece el prefijo,mdbdebe asignarle al secreto TLS para las comunicaciones TLS del cliente elmdb-my-deployment-certnombre. Además, debe asignarle al secreto TLS para la autenticación interna del clúster (si está habilitada) elmdb-my-deployment-clusterfilenombre.Para aprender más sobre cómo nombrar los secretos que contienen tus certificados TLS, consulta el tema en Implementar un set de réplicas que se aplica a tu implementación.
spec.security.tls.additionalCertificateDomainsTipo: booleano
Lista de todos los dominios que deben agregarse a los certificados TLS de cada pod en esta implementación. Al configurar este parámetro, cada CSR que el operador de Kubernetes transforma en un certificado TLS incluye un SAN con el
<pod name>.<additional cert domain>formato.Los recursos del set de réplicas no necesitan este parámetro. Utiliza
spec.connectivity.replicaSetHorizonsen su lugar.Nota
Si añades este parámetro a un recurso habilitado para TLS, Kubernetes mostrará un error cuando el recurso alcance el estado
Pending. Se muestra este error:Please manually remove the |csr| in order to proceed.Para solucionar este problema:Remueve cualquier CSRexistente para que Kubernetes pueda generar nuevos CSR. Para aprender a borrar un recurso, consulta el borrado de recursos en la documentación de Kubernetes.
Aprobar los CSRdespués de que Kubernetes los genere.
spec.additionalMongodConfig.net.ssl.modeTipo: string
Por defecto:
requireSSLEspecifica qué
sslModese usa para las conexiones de red. Las siguientes son opciones válidas:ValorDescripciónallowSSLLas conexiones entre servidores no utilizan TLS. Para las conexiones entrantes, el servidor acepta tanto TLS como no TLS.
preferSSLLas conexiones entre servidores usan TLS. Para las conexiones entrantes, el servidor admite tanto conexiones TLS como no TLS.
requireSSLEl servidor utiliza y acepta únicamente conexiones encriptadas TLS.
spec.additionalMongodConfig.net.tls.disabledProtocolsTipo: string
Novedades en MongoDB versión 4.2.
Evita que un servidor de MongoDB que se ejecuta con TLS acepte conexiones entrantes que utilicen un protocolo o protocolos específicos. Para especificar varios protocolos, ingresa una lista de protocolos separada por comas. Por ejemplo,
TLS1_0,TLS1_1.Esta configuración reconoce los siguientes protocolos:
TLS1_0,TLS1_1,TLS1_2y, a partir de MongoDB 4.0.4 (y 3.6.9),TLS1_3. Si especifica un protocolo no reconocido, el servidor no se iniciará.En macOS, no se puede desactivar
TLS1_1y habilitar ambosTLS1_0yTLS1_2. También debes desactivar al menosTLS1_0oTLS1_2. Por ejemplo,TLS1_0,TLS1_1desactivaTLS1_2en macOS.La lista de protocolos que deshabilita reemplaza la lista predeterminada de protocolos deshabilitados.
A partir de la versión 4.0 de MongoDB, MongoDB desactiva el uso de TLS 1.0 si TLS 1.1+ está disponible en el sistema. Para habilitar el TLS deshabilitado 1.0, especifica
nonecomo el valor paraspec.additionalMongodConfig.net.tls.disabledProtocols.Los nodos de los sets de réplicas y los clústeres fragmentados deben tener al menos un protocolo en común.
spec.security.authenticationtipo: colección
Especificaciones de autenticación para tu implementación de MongoDB.
spec.security.authentication.enabledTipo: booleano
Por defecto:
falseEspecifica si la autenticación está habilitada en el proyecto de Cloud Manager u Ops Manager. Si se configura en
true, debes establecer un mecanismo de autenticación enspec.security.authentication.modes.Importante
El operador de Kubernetes gestiona la autenticación para este recurso de MongoDB si se incluye esta configuración, incluso si está establecida en
false. No puedes configurar la autenticación para este recurso utilizando la Interfaz de Usuario o API de Cloud Manager u Ops Manager mientras esta configuración exista en las especificaciones del recurso.Omite este ajuste si prefieres gestionar la autenticación utilizando la Interfaz de Usuario de Cloud Manager u Ops Manager o sus API.
spec.security.authentication.modesTipo: arreglo
Especifica el mecanismo de autenticación que utiliza su implementación de MongoDB. Los valores válidos son
SCRAM,SCRAM-SHA-1,MONGODB-CR,X509,LDAPyOIDC. RecomendamosSCRAM-SHA-256(SCRAM) en lugar deSCRAM-SHA-1. Si especificaSCRAM-SHA-1, también debe especificarMONGODB-CR.Nota
Autenticación interna del clúster X.509
Para habilitar la autenticación del clúster interno X.509 para el proyecto Cloud Manager u Ops Manager, configure este valor en
["X509"]y especifique las siguientes configuraciones:Proporcione un valor para la
spec.security.certsSecretPrefixconfiguración.
Si proporciona más de un valor para, también debe especificar un
spec.security.authentication.modesvalorspec.security.authentication.agents.modepara.
spec.security.authentication.internalClusterTipo: string
Especifica si X.509 autenticación interna de clúster está habilitada.
Para habilitar la autenticación interna del clúster X.509, configúrelo en
"X509". Requiere que se especifiquen los siguientes ajustes:El Operador de Kubernetes acepta los siguientes valores:
["X509"]: La autenticación interna de clúster X.509 está habilitada.""u omitido: la autenticación interna del clúster no está habilitada.
Importante
Después de habilitar la autenticación interna del clúster, no se puede deshabilitar.
spec.security.authentication.requireClientTLSAuthenticationTipo: booleano
Por defecto:
falseEspecifica si el host de MongoDB requiere que los clientes se conecten usando un certificado TLS. Los valores predeterminados serán
truesi habilitas la autenticación TLS.Para habilitar la autenticación TLS, proporciona un valor para la configuración
spec.security.certsSecretPrefix.
spec.security.authentication.ldaptipo: colección
Requerido para la autenticación LDAP.
Configura la autenticación LDAP para el proyecto de Cloud Manager u Ops Manager. Para habilitar la autenticación LDAP,
spec.security.authentication.modesconfigure["LDAP"]en.
spec.security.authentication.ldap.serversTipo: arreglo de cadenas
Requerido para la autenticación LDAP.
Lista de nombres de host y puertos de los servidores LDAP. Especifica los nombres de host con sus respectivos puertos en el siguiente formato:
spec: security: authentication: ldap: servers: - "<hostname1>:<port1>" - "<hostname2>:<port2>"
spec.security.authentication.ldap.timeoutMSTipo: entero
Especifica cuántos milisegundos debe esperar una solicitud de autenticación antes de agotar el tiempo de espera.
spec.security.authentication.ldap.transportSecurityTipo: string
Requerido para la autenticación LDAP.
Especifica si el servidor LDAP acepta TLS.
Si el servidor LDAP acepta TLS, establezca el valor en
tls. Si el servidor LDAP no acepta TLS, deje este valor en blanco o establezca el valor ennone.Nota
Si se especifica un string diferente de
noneotls, Kubernetes Operator aún establece la configuración entls.
spec.security.authentication.ldap.caConfigMapReftipo: colección
Se requiere para la autenticación LDAP con TLS.
ConfigMap que contiene una CA que valida el LDAP del servidor TLS certificado.
spec.security.authentication.ldap.caConfigMapRef.nameTipo: string
Se requiere para la autenticación LDAP con TLS.
Nombre del ConfigMap que contiene una CA que valida el certificado TLS del servidor LDAP.
spec.security.authentication.ldap.caConfigMapRef.keyTipo: string
Se requiere para la autenticación LDAP con TLS.
Nombre del campo que almacena la CA que valida el servidor LDAP del certificado TLS.
spec.security.authentication.ldap.bindQueryUserTipo: string
Requerido para la autenticación LDAP.
LDAP nombre distinguido al que MongoDB se conecta al conectarse al servidor LDAP.
spec.security.authentication.ldap.bindQueryPasswordSecretReftipo: colección
Requerido para la autenticación LDAP.
Especifica el secreto que contiene la contraseña con la que MongoDB se vincula al conectarse al servidor LDAP.
spec.security.authentication.ldap.bindQueryPasswordSecretRef.nameTipo: string
Requerido para la autenticación LDAP.
Nombre del secreto que contiene la contraseña con la que MongoDB se vincula al conectarse al servidor LDAP.
El secreto debe contener solo un
passwordcampo que almacena la contraseña.
spec.security.authentication.ldap.authzQueryTemplateTipo: string
Requerido para la autorización LDAP.
Una plantilla de URL de consulta LDAP con formato RFC4515 y RFC, ejecutada por MongoDB para obtener los grupos LDAP a los que pertenece el usuario. La consulta es relativa al host o hosts especificados en. Puede usar los siguientes tokens en la4516
spec.security.authentication.ldap.serversplantilla:{USER}- Sustituye el nombre de usuario autenticado, o el nombre de usuario
transformed, en la consulta LDAP.
{PROVIDED_USER}- Sustituye el nombre de usuario proporcionado, antes de la autenticación o la transformación de LDAP, en la query LDAP. (Disponible a partir de la versión 4.2 de MongoDB)
Tip
Plantillas de query LDAP en el Manual de MongoDB
spec.security.authentication.agents.automationLdapGroupDNTipo: string
El nombre distintivo (DN) del grupo LDAP al que pertenece el usuario del Agente MongoDB.
Esta configuración es necesaria si:
spec.security.authentication.ldap.authzQueryTemplateestá presente, yspec.security.authentication.agents.modeesLDAPoX509.
spec.security.authentication.ldap.userToDNMappingTipo: string
Asigna el nombre de usuario proporcionado a
mongodo paramongosla autenticación a un nombre distinguido (DN) LDAP.Tip
security.ldap.userToDNMapping en el Manual de MongoDB
spec.security.authentication.ldap.userCacheInvalidationIntervalTipo: entero
Especifica cuántos segundos espera MongoDB para vaciar la caché de usuarios LDAP. Por defecto, 30 segundos.
spec.security.authentication.oidcProviderConfigstipo: colección
Requerido
La versión de MongoDB debe ser 7.0.11+ o 8.0.0+
Solo se admite MongoDB Enterprise
Nota
Se requiere al menos un elemento en la colección cuando
spec.security.authentication.modeestá configurado enOIDC.
spec.security.authentication.oidcProviderConfigs.audienceTipo: string
Requerido
Entidad para la cual tu proveedor de identidad externo (IdP) destina el token. Introduce el valor de audiencia de la aplicación que registraste con tu proveedor de identidad externo. Cuando se define más de un proveedor de identidad, este debe ser un valor único para cada configuración que comparta un
issuerURI.
spec.security.authentication.oidcProviderConfigs.authorizationMethodTipo: string
Requerido
Los valores válidos son
WorkforceIdentityFederationyWorkloadIdentityFederation. Configura el inicio de sesión único para el acceso de usuarios humanos a las implementaciones con la Federación de Identidad de la Fuerza Laboral. Para acceder programáticamente a implementaciones, utiliza la federación de identidad de cargas de trabajo. Solo se puede configurar un proveedor de identidades (IdP) de Workforce Identity Federation por cada recurso MongoDB. Para saber más, visita Autenticación y autorización con OIDC/OAuth 2.0.
spec.security.authentication.oidcProviderConfigs.authorizationTypeTipo: string
Requerido
Los valores válidos son
GroupMembershipyUserID. SeleccioneGroupMembershippara conceder autorización basada en la membresía del grupo de usuarios de proveedor de identidad o seleccioneUserIDpara conceder autorización a un usuario individual.
spec.security.authentication.oidcProviderConfigs.clientIDTipo: string
Requerido
Identificador único para su aplicación registrada. Ingresa el valor
clientIdde la aplicación registrada en un proveedor de identidad externo.
spec.security.authentication.oidcProviderConfigs.configurationNameTipo: string
Requerido
Etiqueta única que identifica esta configuración. Esta etiqueta es visible para los usuarios de Ops Manager y se utiliza al crear usuarios y roles para la autorización. Distingue entre mayúsculas y minúsculas y solo puede contener los siguientes caracteres:
caracteres alfanuméricos (combinación de a a z y 0 a 9)
guiones (-)
guiones bajos (_)
spec.security.authentication.oidcProviderConfigs.groupsClaimTipo: string
Opcional
El identificador del reclamo que incluye la identidad principal del usuario. Acepta el valor por defecto a menos que tu proveedor de identidad utilice un reclamo diferente.
spec.security.authentication.oidcProviderConfigs.issuerURITipo: string
Requerido
Valor de emisor proporcionado por tu aplicación de proveedor de identidad registrada. Usando este URI, MongoDB encuentra un Documento de Configuración del Proveedor OpenID, que está disponible en el endpoint
/.wellknown/open-id-configuration. Para MongoDB8.0+, la combinación deissuerURIy público debe ser única en todas las configuraciones del proveedor OIDC. Para otras versiones de MongoDB, el propioissuerURIdebe ser único.
spec.security.roleRefsTipo: arreglo
Matriz que hace referencia a
ClusterMongoDBRolerecursos personalizados que le brindan control de acceso detallado sobre su implementación de MongoDB.
spec.security.roleRefs.kindTipo: string
El tipo del recurso personalizado referenciado. Por ejemplo,
ClusterMongoDBRole.
spec.security.roleRefs.kindTipo: string
El tipo del recurso personalizado referenciado. Por ejemplo,
ClusterMongoDBRole.
spec.security.authentication.oidcProviderConfigs.requestedScopesTipo: string
Opcional
Tokens que otorgan a los usuarios permiso para solicitar datos del punto final de autorización. Solo se utilizan para el método de autorización Workforce Identity Federation.
spec.security.authentication.oidcProviderConfigs.userClaimTipo: string
Requerido
El identificador del reclamo que incluye la identidad principal del usuario. Acepta el valor por defecto a menos que tu proveedor de identidad utilice un reclamo diferente.
spec.security.authentication.agentstipo: colección
Configuración de autenticación del agente MongoDB para el proyecto Cloud Manager o Ops Manager.
spec.security.authentication.agents.modeTipo: string
El mecanismo de autenticación que utilizan los agentes de MongoDB para su implementación. Los valores válidos son,,,,
SCRAMSCRAM-SHA-1MONGODB-CRX509OIDCLDAPy. El valor que especifique también debe estar presente en.spec.security.authentication.modesRecomendamosSCRAM-SHA-256()SCRAMSCRAM-SHA-1en lugar de. SiSCRAM-SHA-1especifica, también debeMONGODB-CRespecificar.Esta configuración es obligatoria si se ha especificado más de un valor para
spec.security.authentication.modes.
spec.security.authentication.agents.automationUserNameTipo: string
Nombre del usuario que los agentes de MongoDB utilizan para interactuar con tu implementación de MongoDB. El nombre de usuario se asigna a un Nombre Distinguido (DN) de LDAP según lo establecido en
spec.security.authentication.ldap.userToDNMapping. El nombre distinguido resultante debe estar ya en tu implementación de LDAP.Este ajuste es obligatorio si
spec.security.authentication.agents.modeesLDAP.
spec.security.authentication.agents.automationPasswordSecretReftipo: colección
Detalles del secreto que contiene la contraseña para el usuario
spec.security.authentication.agents.automationUserName.Este ajuste es obligatorio si
spec.security.authentication.agents.modeesLDAP.
spec.security.authentication.agents.automationPasswordSecretRef.nameTipo: string
Nombre del secreto que contiene la contraseña para el usuario
spec.security.authentication.agents.automationUserName. Debes crear este secreto en el mismo namespace en el que implementes el operador de Kubernetes:kubectl create secret generic ldap-agent-user \ --from-literal="password=<password>" -n <metadata.namespace> Este secreto debe contener una clave, cuyo valor coincida con la contraseña del usuario en su implementación de
spec.security.authentication.agents.automationUserNameLDAP.Este ajuste es obligatorio si
spec.security.authentication.agents.modeesLDAP.
spec.security.authentication.agents.automationPasswordSecretRef.keyTipo: string
Introduce la
spec.security.authentication.agents.automationPasswordSecretRef.nameclave secreta que contiene la contraseña del usuario enspec.security.authentication.agents.automationUserName.Este ajuste es obligatorio si
spec.security.authentication.agents.modeesLDAP.
spec.security.authentication.agents.clientCertificateSecretRef.nameTipo: string
Especifica el secreto que contiene el certificado TLS del MongoDB Agent. Si se omite, el valor por defecto es
agent-certs.Debe crear este secreto en el mismo espacio de nombres en el que implementa el operador de Kubernetes y el secreto debe ser del tipo
kubernetes.io/tls.
spec.security.rolesTipo: arreglo
Arreglo que define Roles definidos por el usuario que te dan un control de acceso detallado sobre tu implementación de MongoDB.
Para habilitar los roles definidos por el usuario, la
spec.security.authentication.enableddebe estartrue.Ejemplo
En este ejemplo, un rol definido por el usuario llamado
customRolepermite a los usuarios asignados a este rol:Inserte documentos en la colección
catsen la base de datospetsyBuscar e insertar documentos en la colección
dogsen la base de datospets.
1 2 apiVersion: mongodb.com/v1 3 kind: MongoDB 4 metadata: 5 name: <my-replica-set> 6 spec: 7 members: 3 8 version: "8.0.0" 9 type: ReplicaSet 10 opsManager: 11 configMapRef: 12 name: <configMap.metadata.name> 13 credentials: <mycredentials> 14 persistent: true 15 security: 16 authentication: 17 enabled: true 18 modes: 19 - "SCRAM" 20 roles: 21 - role: "customRole" 22 db: admin 23 privileges: 24 - actions: 25 - insert 26 resource: 27 collection: cats 28 db: pets 29 - actions: 30 - insert 31 - find 32 resource: 33 collection: dogs 34 db: pets 35 ...
spec.security.roles.dbTipo: string
La base de datos en la que desea almacenar el rol definido por el usuario.
Ejemplo
admin
spec.security.roles.authenticationRestrictionsTipo: arreglo
Arreglo que define la dirección IP desde y hacia la que los usuarios asignados pueden conectarse a este
spec.security.roles.role.
spec.security.roles.authenticationRestrictions.clientSourceTipo: arreglo
Matriz de direcciones IP o bloques CIDR desde los que los usuarios asignados a este pueden
spec.security.roles.roleconectarse.Los servidores de MongoDB rechazan las solicitudes de conexión de usuarios con este rol si estas solicitudes provienen de un cliente que no esté presente en este arreglo.
spec.security.roles.authenticationRestrictions.serverAddressTipo: arreglo
Arreglo de direcciones IP o bloques CIDR a los que los usuarios asignados a este
spec.security.roles.rolepueden conectarse.Los servidores MongoDB rechazan las solicitudes de conexión de los usuarios con este rol si el cliente solicita conectarse a un servidor que no está presente en esta matriz.
spec.security.roles.privilegesTipo: arreglo
Arreglo que describe los privilegios que poseen los usuarios a quienes se les otorgó este rol.
spec.security.roles.privileges.actionsTipo: arreglo
Lista de acciones que pueden realizar los usuarios con este rol. Para ver la lista de valores aceptados, consulte "Acciones de privilegios" en el Manual de MongoDB para las versiones de MongoDB que implemente con el operador de Kubernetes.
spec.security.roles.privileges.resourcetipo: colección
Recursos para los que se
actionsaplica el privilegio.Esta colección debe incluir cualquiera de lo siguiente:
La
spec.security.roles.privileges.resource.databasey laspec.security.roles.privileges.resource.collectionconfiguración, oLa
spec.security.roles.privileges.resource.clusterconfiguración con un valor detrue.
spec.security.roles.privileges.resource.databaseTipo: string
Base de datos a la que se aplica el privilegio
actions.Si proporcionas un valor para esta configuración, también debes proporcionar un valor para
spec.security.roles.privileges.resource.collection.
spec.security.roles.privileges.resource.collectionTipo: string
Colección en el
databasepara la que se aplica el privilegioactions.Si proporcionas un valor para esta configuración, también debes proporcionar un valor para
spec.security.roles.privileges.resource.database.
spec.security.roles.privileges.resource.clusterTipo: booleano
Por defecto: False
Marca que indica que el privilegio se aplica a todas las bases de datos y colecciones de la implementación de MongoDB. Si se omite, el valor
actionspredeterminadofalsees.Si está configurado como verdadero, no se deben proporcionar valores para
spec.security.roles.privileges.resource.databaseyspec.security.roles.privileges.resource.collection.
Ejemplos
El siguiente ejemplo muestra una especificación de recurso para una implementación autónomo con todas las configuraciones proporcionadas:
apiVersion: mongodb.com/v1 kind: MongoDB metadata: name: my-standalone spec: version: "8.0.0" service: my-service opsManager: # Alias of cloudManager configMapRef: name: my-project credentials: my-credentials persistent: true type: Standalone additionalMongodConfig: systemLog: logAppend: true verbosity: 4 operationProfiling: mode: slowOp podSpec: persistence: single: storage: "12Gi" storageClass: standard labelSelector: matchExpressions: - {key: environment, operator: In, values: [dev]} podTemplate: metadata: labels: label1: mycustomlabel spec: affinity: podAffinity: requiredDuringSchedulingIgnoredDuringExecution: - labelSelector: matchExpressions: - key: security operator: In values: - S1 topologyKey: failure-domain.beta.kubernetes.io/zone nodeAffinity: requiredDuringSchedulingIgnoredDuringExecution: nodeSelectorTerms: - matchExpressions: - key: kubernetes.io/e2e-az-name operator: In values: - e2e-az1 - e2e-az2 podAntiAffinity: preferredDuringSchedulingIgnoredDuringExecution: - podAffinityTerm: topologyKey: "mykey" weight: 50 ...
El siguiente ejemplo muestra una especificación de recurso para un set de réplicas con todas las configuraciones proporcionadas:
apiVersion: mongodb.com/v1 kind: MongoDB metadata: name: my-replica-set spec: members: 3 version: "8.0.0" service: my-service opsManager: # Alias of cloudManager configMapRef: name: my-project credentials: my-credentials persistent: true type: ReplicaSet podSpec: persistence: multiple: data: storage: "10Gi" journal: storage: "1Gi" labelSelector: matchLabels: app: "my-app" logs: storage: "500M" storageClass: standard podTemplate: metadata: labels: label1: mycustomlabel spec: affinity: podAffinity: requiredDuringSchedulingIgnoredDuringExecution: - labelSelector: matchExpressions: - key: security operator: In values: - S1 topologyKey: failure-domain.beta.kubernetes.io/zone nodeAffinity: requiredDuringSchedulingIgnoredDuringExecution: nodeSelectorTerms: - matchExpressions: - key: kubernetes.io/e2e-az-name operator: In values: - e2e-az1 - e2e-az2 podAntiAffinity: preferredDuringSchedulingIgnoredDuringExecution: - podAffinityTerm: topologyKey: "mykey" weight: 50 security: certsSecretPrefix: "prefix" tls: ca: custom-ca authentication: enabled: true modes: ["X509"] internalCluster: "X509" statefulSet: spec: serviceName: my-service additionalMongodConfig: net: ssl: mode: preferSSL ...
El siguiente ejemplo muestra una especificación de recursos para un clúster particionado con todas las configuraciones proporcionadas:
apiVersion: mongodb.com/v1 kind: MongoDB metadata: name: my-sharded-cluster spec: shardCount: 2 mongodsPerShardCount: 3 mongosCount: 2 configServerCount: 3 version: "8.0.0" service: my-service type: ShardedCluster ## Please Note: The default Kubernetes cluster name is ## `cluster.local`. ## If your cluster has been configured with another name, you can ## specify it with the `clusterDomain` attribute. opsManager: # Alias of cloudManager configMapRef: name: my-project credentials: my-credentials persistent: true configSrvPodSpec: # if "persistence" element is omitted then Operator uses the # default size (5Gi) for mounting single Persistent Volume podTemplate: spec: affinity: podAffinity: requiredDuringSchedulingIgnoredDuringExecution: - labelSelector: matchExpressions: - key: security operator: In values: - S1 topologyKey: failure-domain.beta.kubernetes.io/zone nodeAffinity: requiredDuringSchedulingIgnoredDuringExecution: nodeSelectorTerms: - matchExpressions: - key: kubernetes.io/e2e-az-name operator: In values: - e2e-az1 - e2e-az2 podAntiAffinity: requiredDuringSchedulingIgnoredDuringExecution: - podAffinityTerm: topologyKey: nodeId mongosPodSpec: podTemplate: spec: affinity: podAffinity: requiredDuringSchedulingIgnoredDuringExecution: - labelSelector: matchExpressions: - key: security operator: In values: - S1 topologyKey: failure-domain.beta.kubernetes.io/zone nodeAffinity: requiredDuringSchedulingIgnoredDuringExecution: nodeSelectorTerms: - matchExpressions: - key: kubernetes.io/e2e-az-name operator: In values: - e2e-az1 - e2e-az2 podAntiAffinity: requiredDuringSchedulingIgnoredDuringExecution: - podAffinityTerm: topologyKey: nodeId shardPodSpec: persistence: multiple: # if the child of "multiple" is omitted then the default size will be used. # 16GB for "data", 1GB for "journal", 3GB for "logs" data: storage: "20Gi" logs: storage: "4Gi" storageClass: standard podTemplate: spec: affinity: podAffinity: requiredDuringSchedulingIgnoredDuringExecution: - labelSelector: matchExpressions: - key: security operator: In values: - S1 topologyKey: failure-domain.beta.kubernetes.io/zone nodeAffinity: requiredDuringSchedulingIgnoredDuringExecution: nodeSelectorTerms: - matchExpressions: - key: kubernetes.io/e2e-az-name operator: In values: - e2e-az1 - e2e-az2 podAntiAffinity: requiredDuringSchedulingIgnoredDuringExecution: - podAffinityTerm: topologyKey: nodeId mongos: additionalMongodConfig: systemLog: logAppend: true verbosity: 4 configSrv: additionalMongodConfig: operationProfiling: mode: slowOp shard: additionalMongodConfig: storage: journal: commitIntervalMs: 50 security: certsSecretPrefix: "prefix" tls: ca: custom-ca authentication: enabled: true modes: ["X509"] internalCluster: "X509" statefulSet: spec: serviceName: my-service ...
Configuración de StatefulSet
Las siguientes configuraciones de statefulSets se aplican únicamente a los tipos de recursos de conjuntos de réplicas y clústeres fragmentados.
spec.statefulSet.spectipo: colección
Especificación para el StatefulSet que los controladores de MongoDB para Kubernetes **operador** crean para los recursos
MongoDB.
spec.statefulSet.spec.serviceNameTipo: string
por defecto:
<resource_name>-svcy<resource_name>-svc-externalNombre del servicio de Kubernetes que se va a crear o utilizar para un StatefulSet. Si el servicio con este nombre ya existe, el MongoDB Controllers for Kubernetes operador no lo borra ni lo recrea. Esta configuración le permite crear sus propios servicios personalizados y permite que el Operador de Kubernetes los reutilice.