Pular para o conteúdo principal

Kubernetes para desenvolvedores Java - Setup


Esta é uma série de posts sobre Kubernetes para desenvolvedores Java. A série original está disponível em inglês no site dev.to

Kubernetes  é uma plataforma portátil e extensível de código aberto para gerenciamento  de containers, que facilita tanto a configuração declarativa quanto a automação. Tem um ecossistema grande e de rápido crescimento. Os serviços, suporte e ferramentas do Kubernetes estão amplamente disponíveis.

Introdução

A área de tecnologia é cíclica, de tempos em tempos as mesmas tecnologias voltam, com nomes diferentes.  (Heidemann, Vanei)

Se você tem mais de 35 anos, viu muitas tecnologias sendo re-inventadas. Nesse caso, falaremos sobre servidores de aplicação. Como podemos ver neste artigo do @rafabenehttp://rafabene.com/2019/03/15/kubernetes-servidor-aplicacao/

Como desenvolvedores, queremos executar e testar o código em nossa máquina, para ter o controle em nossas mãos. Mas agora, os programas não estão sendo executados apenas em contêineres Docker. Então, há uma série de coisas com as quais precisamos nos preocupar.

Neste tutorial, você aprenderá como preparar o ambiente local para um cluster do kubernetes. Este é o primeiro post de uma série sobre Java e Kubernetes.

Pré-requisitos

Docker

Docker  é uma plataforma de software de código aberto para criar, implantar e gerenciar contêineres de aplicações virtualizados em um sistema operacional (SO) comum, com um ecossistema de ferramentas aliadas.

Minikube

Minikube implementa um cluster local do Kubernetes no macOS, Linux e Windows.

Kubectl

A ferramenta de linha de comando do Kubernetes, kubectl, permite executar comandos em clusters do Kubernetes.

VirtualBox

O cluster do Kubernetes irá rodar dentro de uma máquina virtual. Neste caso iremos utilizar o Virtual Box
https://www.virtualbox.org/

Se você não tiver nenhuma dessas ferramentas, isso pode ajudá-lo:
github sandrogiacom/k8s

Verificando se está tudo preparado:

No terminal, digite:

$ minikube version
minikube version: v1.1.1
$ kubectl version
Client Version: version.Info{Major:"1", Minor:"14", GitVersion:"v1.14.2"...
$ virtualbox

Iniciando o minikube

Para iniciar o minikube, basta digitar minikube start no terminal.O comando acima cria a máquina virtual com valores padrões:
Se você quiser começar com diferentes flags, digite minikube start -h para ver a lista completa.

As opções mais importantes são:
  • --vm-driver: VM driver is one of: virtualbox parallels vmwarefusion kvm xhyve hyperv hyperkit kvm2 vmware none. default “virtualbox”
  • --memory int: Amount of RAM allocated to the minikube VM in MB (default 2048)
  • --cpus int: Number of CPUs allocated to the minikube VM (default 2)
  • --profile: The name of the minikube VM being used. This can be modified to allow for multiple minikube instances to be run independently (default “minikube”)
minikube start -p dev.to --cpus 2 --memory=4096

Dashboard

minikube -p dev.to dashboard

Você pode usar o Dashboard para obter uma visão geral dos serviços em execução no cluster, como para criar ou modificar recursos individuais do Kubernetes (como Deployments, Jobs, DaemonSets, etc).

Criando um namespace
É uma boa prática criar um namespace para separar seu espaço de trabalho. Tipo:

kubectl create namespace dev-to

Habilitando o ingress

minikube -p dev.to addons enable ingress

O Ingress expõe rotas HTTP e HTTPS de fora do cluster para serviços dentro do cluster. O roteamento de tráfego é controlado pelas regras definidas no recurso Ingress que veremos nos próximos posts.

Parando a máquina minikube

minikube -p dev.to stop

Excluindo a máquina minikube

minikube -p dev.to delete


Conclusão

Este é só o começo!

Neste tutorial, aprendemos como iniciar um cluster kubernetes local e preparar para implantar nosso próprio serviço. Na próxima postagem, iremos preparar um aplicativo Java para ser implantado no cluster do Kubernetes.

Te vejo em breve.

Referências

http://rafabene.com/2019/03/15/kubernetes-servidor-aplicacao/
https://github.com/arun-gupta/kubernetes-for-java-developers
https://github.com/arun-gupta/kubernetes-java-sample/blob/master/workshop.adoc#create-kubernetes-cluster


Siga no twitter para ficar informado dos novos posts:

Comentários

Postagens mais visitadas deste blog

Java Records

  Java Records Imutável, Simples e limpa Esta funcionalidade da linguagem apareceu pela primeira vez na versão 14 como experimental e assim continuou até a versão 15 . Agora liberada de forma definitiva no Java 16 . O objetivo é ser possível ter classes que atuam como portadores transparentes de dados imutáveis. Os registros podem ser considerados tuplas nominais. Ou seja, após criado, um record não pode mais ser alterado. Records oferece uma uma sintaxe compacta para declarar classes que são portadores transparentes para dados imutáveis superficiais visando reduzir significamente o detalhamento dessas classes e irá melhorar a capacidade de leitura e manutenção do código. Vamos seguir um exemplo de uma classe chamada Pessoa . O primeiro exemplo vamos utilizar o modo tradicional. public class Pessoa { private String nome; private int idade; public Pessoa (String nome, int idade) { super (); this .nome = nome; this .idade = idade; } public String getNo

Java 8 ao 18: Mudanças mais importantes na plataforma Java

    Vamos rever muitas das mudanças mais importantes na plataforma Java que aconteceram entre a versão 8 (2014) e 18 (2022)   O Java 8 foi lançado em março de 2014 e o Java 18 em março de 2022. São 8 anos de progresso, 203 JEPs (JDK Enhancement Proposals ), entre essas duas versões. Neste post, revisaremos as mudanças mais importantes e discutiremos os benefícios e desafios da adoção de versões mais recentes do JDK para novos aplicativos e para os mais antigos compilados com versões mais antigas. Desde a versão 9, o Java tem novos recursos a cada 6 meses e é muito difícil acompanhar essas novas mudanças. A maioria das informações na internet descreve as mudanças entre as duas últimas versões do Java. No entanto, se você estiver em uma situação semelhante à minha, não está usando uma das versões mais recentes do Java, mas uma das várias versões anteriores (Geralmente 8 ou 11 que são as versões de suporte estendido). Então é útil saber quais novos recursos foram adicionados d

O suporte de longo prazo e o que o LTS significa para o ecossistema Java

A arte do suporte de longo prazo e o que o LTS significa para o ecossistema Java Aqui está o que o Java 17 tem em comum com o Java 11 e o Java 8. Em junho de 2018, há pouco mais de três anos, a Oracle e outros participantes do ecossistema Java anunciaram uma mudança no modelo de cadência de lançamento para Java SE. Em vez de ter um lançamento principal planejado a cada dois ou quatro anos (que geralmente se torna de três a quatro anos), um novo modelo de lançamento de recursos de seis meses seria usado: a cada três anos, um lançamento seria designado como Long-Term Support (LTS) e receba apenas atualizações trimestrais de segurança, estabilidade e desempenho. Esse padrão foi emprestado descaradamente do modelo de lançamento do Mozilla Firefox, mas o ajustou para ficar mais alinhado com os requisitos de uma plataforma de desenvolvimento. A primeira versão do Java lançada sob esse modelo foi o Java SE 11. O lançamento do Java SE 17, o segundo lançamento do LTS sob o novo