Este é um exemplo de teste de carga em Go para clusters Kubernetes. O teste cria deployments de forma contínua em intervalos regulares para simular carga no cluster.
- Go instalado na máquina local
- Acesso a um cluster Kubernetes (local ou remoto)
- Configuração do Kubernetes (
kubectl
) ou arquivokubeconfig
para autenticação e autorização
O código cria deployments no cluster Kubernetes em intervalos regulares. No exemplo fornecido, ele cria deployments usando a imagem nginx
, mas pode ser adaptado para outras imagens e tipos de recursos do Kubernetes.
-
Caso não seja setado no momento da execução o caminho do KUBECONFIG ele herdará das variáveis de ambiente.
-
O teste é para criação de deployments, caso deseje mudar o Namespace, Name, Imagem e etc realize a alteração entre as linhas 67-89.
git clone https://github.com/Tech-Preta/kubecarga.git
cd kubecarga
Execute o seguinte comando para inicializar um novo módulo Go:
go mod init
Para instalar as dependências necessárias, execute os seguintes comandos:
go get k8s.io/client-go/kubernetes
go get k8s.io/client-go/rest
go get k8s.io/client-go/tools/clientcmd
Esses comandos irão baixar e instalar os pacotes e suas dependências, e também atualizarão os arquivos go.mod e go.sum.
Agora que temos todas as dependências instaladas, podemos criar o executável para isso utilize o comando abaixo:
go build -o kube-carga .
Isso irá compilar o código e criar o executável no diretório atual.
Finalmente podemos executar a nossa aplicação com o comando abaixo:
sudo chmod +x kube-carga
./kube-carga -kubeconfig /caminho/para/seu/kubeconfig
## Próximas Funcionalidades
Aqui estão algumas funcionalidades que podem ser adicionadas no futuro:
### Limpeza dos Deployments
Adicionar uma funcionalidade para limpar os deployments criados pelo `kube-carga` no cluster após a execução do teste de carga.
#### Tarefas:
- [ ] Implementar a lógica para deletar os deployments após a conclusão do teste.
- [ ] Adicionar suporte para exclusão de outros recursos criados durante o teste, como Services e Pods.
### Verificação do Tempo de Implantação
Adicionar uma funcionalidade para verificar quanto tempo cada deployment demora para ser implantado no cluster.
#### Tarefas:
- [ ] Registrar o tempo de início da criação de cada deployment.
- [ ] Registrar o tempo de conclusão da criação de cada deployment.
- [ ] Calcular e registrar a diferença de tempo entre o início e a conclusão da implantação de cada deployment.
## Contato
- [email protected]