Як згадував Марк, канонічну відповідь про перемикання / читання / маніпулювання різними середовищами кубернетів (також контекстів кубернетів) можна використовувати kubectl config
, див. Нижче:
$ kubectl config
Modify kubeconfig files using subcommands like "kubectl config set current-context my-context"
Available Commands:
current-context Displays the current-context
delete-cluster Delete the specified cluster from the kubeconfig
delete-context Delete the specified context from the kubeconfig
get-clusters Display clusters defined in the kubeconfig
get-contexts Describe one or many contexts
rename-context Renames a context from the kubeconfig file.
set Sets an individual value in a kubeconfig file
set-cluster Sets a cluster entry in kubeconfig
set-context Sets a context entry in kubeconfig
set-credentials Sets a user entry in kubeconfig
unset Unsets an individual value in a kubeconfig file
use-context Sets the current-context in a kubeconfig file
view Display merged kubeconfig settings or a specified kubeconfig file
Usage:
kubectl config SUBCOMMAND [options]
За сценою є ~/.kube/config
файл YAML, який зберігає всі наявні контексти з відповідними обліковими записами та кінцевими точками для кожного контексту.
Kubectl з полиці не дозволяє легко керувати різними контекстами кубернетів, як ви, напевно, вже знаєте. Замість того, щоб прокручувати власний сценарій, щоб керувати усім цим, кращим підходом є використання зрілого інструменту під назвоюkubectx
, створеного Googler на ім'я "Ahmet Alp Balkan", який працює в Kubernetes / Google Cloud Platform, розробник команди, яка створює подібні інструменти. Я дуже рекомендую його.
https://github.com/ahmetb/kubectx
$ kctx --help
USAGE:
kubectx : list the contexts
kubectx <NAME> : switch to context <NAME>
kubectx - : switch to the previous context
kubectx <NEW_NAME>=<NAME> : rename context <NAME> to <NEW_NAME>
kubectx <NEW_NAME>=. : rename current-context to <NEW_NAME>
kubectx -d <NAME> [<NAME...>] : delete context <NAME> ('.' for current-context)
(this command won't delete the user/cluster entry
that is used by the context)
kubectx -h,--help : show this message