A resposta canônica de alternar / ler / manipular diferentes ambientes de kubernetes (também conhecidos como contextos de kubernetes) deve ser usada, como Mark mencionou kubectl config
, veja abaixo:
$ 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]
Nos bastidores, há um ~/.kube/config
arquivo YAML que armazena todos os contextos disponíveis com suas credenciais e endpoints correspondentes para cada contexto.
O Kubectl pronto para uso não facilita o gerenciamento de diferentes contextos de kubernetes, como você provavelmente já sabe. Em vez de lançar seu próprio script para gerenciar tudo isso, uma abordagem melhor é usar uma ferramenta madura chamada kubectx
, criada por um Googler chamado "Ahmet Alp Balkan", que está na equipe de experiências de desenvolvedor do Kubernetes / Google Cloud Platform que cria ferramentas como esta. Eu recomendo.
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