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

Guia da certificação Java SE 8 Programmer l - Parte 1: Conhecendo a certificação

Seja bem-vindo a série de postagens sobre a certificação Java. Como funciona, o que fazer para comprar, marcar o dia da prova e o principal, o que estudar.

Para ver o índice da série e as datas das publicações, acesse este link

Parte 1 – Conhecendo a certificação
Nesta primeira parte, vamos navegar pelo site da Oracle Education e da Pearson VUE para conhecer como funciona a certificação e se ambientar. Ambos os site estão em Inglês e como já dito no índice da série, a prova não tem opção em português.
Site da Oracle
O site da Oracle não é um dos melhores em usabilidade. Então se procurar por certificação Java no Google, irá encontrar diversos cursos, livros e blogs falando a respeito da certificação menos o site da Oracle.
Pois bem, abaixo o link direto para informações do exame 1Z0-808 - Java SE 8 Programmer I
https://education.oracle.com/pls/web_prod-plq-dad/db_pages.getpage?page_id=5001&get_params=p_exam_id:1Z0-808

Neste link você encontrará as informações detalhadas do exame, tais co…

Certificação Java 11 - O que mudou

Certificação Java 11 - O que mudou
A Oracle liberou recentemente uma atualização das suas certificações Java para atender a nova versão Java 11 LTS (Long Term Support). Mas o que muda em relação a certificação Java 8? Preciso me atualizar? Por onde começo? Neste post, vamos responder estas e outras questões sobre essa nova série de certificações.Caso você não tenha acompanhado a série sobre certificação, recomendo a leitura dos posts anteriores: https://www.guiadojava.com.br/2018/06/guia-da-certificacao-java-se-8.html

Também temos um bate papo com os maiores especialistas de Java do mercado. Assista o replay aqui:
https://events.genndi.com/replay/169105139238448348/23a5b3a7b0/0/83729443273C
Nomenclatura e requisitosA partir de agora, você não receberá o certificado se fizer apenas a primeira prova, como era no Java 8(1Z0-808 - Java SE 8 Programmer I). Você terá que fazer duas provas para obter o certificado "Oracle Certified Professional: Java SE 11 Developer"
Comparando os nome…

Guia da certificação Java SE 8 Programmer l

Seja bem-vindo a série de postagens sobre a certificação Java. Como funciona, o que fazer para comprar, marcar o dia da prova e o principal, o que estudar.
IntroduçãoNeste guia dividido em 7 partes, você irá saber o que é cobrado na prova denominada “OCA Oracle Certified Associate Java SE 8 Programmer I. Exam 1Z0-808”, assim como os passos para se registrar no exame e fazer a prova. Algumas dicas para ser mais ágil no momento da prova.
Primeiro detalhe importante é que a prova não tem opção em português (existe uma opção em Espanhol). Então é bom se acostumar com a leitura em inglês para poder interpretar as questões. O site para marcar a prova também é todo em Inglês.
A prova tem 70 questões de múltipla escolha que devem ser respondidas em até 150 minutos. O candidato deve obter no mínimo 65% de acerto para receber a certificação.
Vou procurar dar algumas orientações para quem irá fazer a primeira certificação, assim como os que tem certificação em outras versões do Java e querem se atua…