El siguiente procedimiento describe cómo actualizar el operador de Kubernetes a su versión más reciente. Este proceso de actualización se parece al proceso de instalación del operador de Kubernetes.
Actualiza los controladores de MongoDB para operador de Kubernetes corriendo en Kubernetes
Nota
Se puede usar el mismo namespace siempre
De forma predeterminada, el operador de Kubernetes implementa todos los recursos en su clúster de Kubernetes en namespace mongodb. Puedes implementar los recursos del Operador de Kubernetes en un namespace diferente editando todos los valores para metadata.namespace en mongodb-kubernetes.yaml:
apiVersion: v1 kind: ServiceAccount metadata: name: mongodb-kubernetes-operator namespace: production apiVersion: apps/v1 kind: Deployment metadata: name: mongodb-kubernetes-operator namespace: production # Example truncated ...
Personalizar su operador de Kubernetes YAML antes de actualizarlo.
Si es necesario, encontrar el archivo YAML de implementación de ejemplo apropiado para la versión elegida del Operador de Kubernetes en el repositorio de GitHub. Luego, para evitar cambios disruptivos, personaliza el archivo de ejemplo YAML para que coincida con los detalles de configuración de tu Kubernetes Operator actualmente implementado.
Actualiza a la nueva versión del Operador de Kubernetes.
Implementa tu operador de Kubernetes personalizado ejecutando lo siguiente:
kubectl apply -f <customized-operator-yaml-file>.yaml
Si no necesitas modificar el YAML de implementación proporcionado, puedes aplicarlo directamente de la siguiente manera:
Multi-Clúster
kubectl apply -f https://raw.githubusercontent.com/mongodb/mongodb-kubernetes/1.6.1/mongodb-enterprise-multi-cluster.yaml
Clúster único
kubectl apply -f https://raw.githubusercontent.com/mongodb/mongodb-kubernetes/1.6.1/public/mongodb-kubernetes.yaml
Utiliza los MongoDB Helm Charts para Kubernetes.
Actualiza a la última versión de los MongoDB Helm Charts for Kubernetes.
Ejecute el siguiente comando para comprobar la versión de su plantilla Helm actual:
helm search repo mongodb/mongodb-kubernetes
Si la versión que tiene actualmente instalada no es la versión más reciente, ejecute el siguiente comando para actualizar su repositorio de Helm:
helm repo update mongodb
Si no tiene instalado el repositorio Helm localmente, puede instalarlo ejecutando:
helm repo add mongodb https://mongodb.github.io/helm-charts
Personaliza tu Helm gráfica antes de actualizarlo.
Para evitar cambios importantes, asegúrese de seleccionar la misma configuración que en su implementación actual. Para obtener más información sobre la configuración opcional de instalación del operador de Kubernetes, consulte Configuración de instalación del timón del operador.
Actualice el operador de Kubernetes.
Ejecuta el siguiente comando helm para implementar el operador de Kubernetes en el namespace por defecto de tu clúster de Kubernetes:
helm upgrade --install mongodb-kubernetes-operator mongodb/mongodb-kubernetes
Puedes pasar las banderas --namespace y --namespace-create para implementar el operador de Kubernetes en un namespace que no esté establecido por defecto, de la siguiente manera:
helm upgrade --install mongodb-kubernetes-operator mongodb/mongodb-kubernetes \ --namespace mongodb \ --create-namespace
Actualizar los controladores de MongoDB para el operador de Kubernetes que se ejecuta en OpenShift
Los siguientes pasos dependen de cómo esté configurado el entorno:
Nota
Se puede usar el mismo namespace siempre
Por defecto, el operador de Kubernetes implementa todos los recursos de tu clúster de Kubernetes en el namespace mongodb. Puedes implementar recursos de operador de Kubernetes en otro namespace diferente editando todos los valores para metadata.namespace en mongodb-kubernetes-openshift.yaml:
apiVersion: v1 kind: ServiceAccount metadata: name: mongodb-kubernetes-operator namespace: production apiVersion: apps/v1 kind: Deployment metadata: name: mongodb-kubernetes-operator namespace: production # Example truncated ...
Personaliza el YAML del Operador de Kubernetes antes de actualizarlo.
Para evitar cambios disruptivos, debe asegurarse de seleccionar la misma configuración que la de su implementación existente. Para obtener información sobre los ajustes opcionales de instalación del Operador de Kubernetes, consulta Configuraciones de instalación de Helm del Operador.
Debes añadir tu <openshift-pull-secret> a las definiciones de ServiceAccount:
apiVersion: v1 kind: ServiceAccount metadata: name: enterprise-operator namespace: mongodb imagePullSecrets: - name: <openshift-pull-secret> apiVersion: v1 kind: ServiceAccount metadata: name: mongodb-kubernetes-appdb namespace: mongodb imagePullSecrets: - name: <openshift-pull-secret> apiVersion: v1 kind: ServiceAccount metadata: name: mongodb-kubernetes-database-pods namespace: mongodb imagePullSecrets: - name: <openshift-pull-secret>
Actualiza los CustomResourceDefinitions para implementaciones de MongoDB.
Ejecute el siguiente comando oc:
Ejecuta el siguiente comando oc para implementar la versión elegida de los CRDs en tu clúster de Kubernetes:
oc apply -f https://raw.githubusercontent.com/mongodb/mongodb-kubernetes/1.6.1/public/crds.yaml
Actualiza a la nueva versión del Operador de Kubernetes.
Ejecuta el siguiente comando oc para implementar tu versión elegida del Operador de Kubernetes en tu clúster de Kubernetes:
oc apply -f https://raw.githubusercontent.com/mongodb/mongodb-kubernetes/1.6.1/public/mongodb-kubernetes-openshift.yaml
Actualiza a la última versión de los MongoDB Helm Charts for Kubernetes.
Ejecute el siguiente comando para comprobar la versión de su plantilla Helm actual:
helm search repo mongodb/mongodb-kubernetes
Si la versión que tiene actualmente instalada no es la versión más reciente, ejecute el siguiente comando para actualizar su repositorio de Helm:
helm repo update mongodb
Si no tiene instalado el repositorio Helm localmente, puede instalarlo ejecutando:
helm repo add mongodb https://mongodb.github.io/helm-charts
Personaliza tu Helm gráfica antes de actualizarlo.
Para evitar cambios disruptivos, debe asegurarse de seleccionar la misma configuración que la de su implementación existente. Para obtener información sobre los ajustes opcionales de instalación del Operador de Kubernetes, consulta Configuraciones de instalación de Helm del Operador.
Actualice el operador de Kubernetes.
Ejecuta el siguiente comando helm para implementar el operador de Kubernetes en el namespace por defecto de tu clúster de Kubernetes:
helm upgrade --install mongodb-kubernetes-operator mongodb/mongodb-kubernetes
Puedes pasar las banderas --namespace y --namespace-create para implementar el operador de Kubernetes en un namespace que no esté establecido por defecto, de la siguiente manera:
helm upgrade --install mongodb-kubernetes-operator mongodb/mongodb-kubernetes \ --namespace mongodb \ --create-namespace
Para solucionar problemas de tu operador de Kubernetes, consulta Revisión de registros del operador de Kubernetes y otros temas de solución de problemas.
Importante
Si necesitas eliminar el operador Kubernetes o el namespace, primero debes eliminar los recursos de MongoDB.
Verifica la instalación
Para verificar que el Operador de Kubernetes se instaló correctamente, ejecuta el siguiente comando y verifica el resultado:
kubectl describe deployments mongodb-kubernetes-operator -n <metadata.namespace>
oc describe deployments mongodb-kubernetes-operator -n <metadata.namespace>
Por defecto, las implementaciones existen en el namespace mongodb. Si aparece el siguiente mensaje de error, asegúrate de utilizar el namespace correcto:
Error from server (NotFound): deployments.apps "mongodb-kubernetes-operator" not found
Para solucionar problemas de tu operador de Kubernetes, consulta Revisión de registros del operador de Kubernetes y otros temas de solución de problemas.
Importante
Si necesitas eliminar el operador Kubernetes o el namespace, primero debes eliminar los recursos de MongoDB.
Próximos pasos
Después de actualizar el MongoDB Controllers para Kubernetes operador, puedes: