Tutorial: Criando um CRUD utilizando Quarkus Java + REST + CDI + Panache, Hibernate com Postgres (Docker) + Postman
-
Linkedin Pulse : https://www.linkedin.com/pulse/tutorial-criando-um-crud-utilizando-quarkus-java-rest-da-silva-melo/
-
Medium : https://medium.com/@marcus.paulo/tutorial-criando-um-crud-utilizando-quarkus-java-rest-cdi-panache-hibernate-com-postgres-59793e0d7162
Tutorial: Criando um CRUD utilizando Quarkus Java + REST + CDI + Panache, Hibernate com Postgres (Docker) + Postman
Tecnologias utilizadas no projeto
- JAVA - Java é uma linguagem de programação e plataforma computacional lançada pela primeira vez pela Sun Microsystems em 1995. Existem muitas aplicações e sites que não funcionarão, a menos que você tenha o Java instalado, e mais desses são criados todos os dias;
- Quarkus - A Red Hat lançou o Quarkus, um framework Java nativo do Kubernetes feito sob medida para o GraalVM e OpenJDK HotSpot. O Quarkus visa tornar o java uma plataforma líder em ambientes serverless e Kubernetes, oferecendo aos desenvolvedores um modelo unificado de programação reativa e imperativa;
Para reproduzir o exemplo, é necessário seguir os requisitos mínimos.
- Você vai precisar de uma IDE como por exemplo: IntelliJ IDEA, Eclipse, VSCode.
- Instale a JDK 8 or 11+
- Instale o Apache Maven 3.5.3+ ou o Gradle
- (Opcional) - Você pode baixar o GraalVM 19.2.1 para compilar nativamente sua aplicação.
- Panache Entity (Possível artigo futuro)
- Escolha um cliente para conectar com o Banco de dados, exemplo: DBeaver, PGAdmin, Postico (Mac)
- Cliente para realizar requisições REST: Postman ou o Insomnia.
- Instruções Adicionais:
- Instalação do Docker (Documentação oficial)
- Instalando Docker no windows: (Youtube, ESR)
- Instalando o Docker no Linux: (Youtube: LinuxTips)
- Instalando o Docker no Mac: (Youtube: Wellington Rogati)
A estrutura de arquivos está da seguinte maneira:
quarkus-food
├── README.md
├── pom.xml
├── quarkus-food.iml
└── src
├── main
│ ├── docker
│ │ ├── Dockerfile.jvm
│ │ └── Dockerfile.native
│ ├── java
│ │ └── br
│ │ └── com
│ │ └── food
│ │ ├── controller
│ │ │ └── FoodController.java
│ │ ├── entity
│ │ │ └── Food.java
│ │ └── resource
│ │ └── FoodResource.java
│ └── resources
│ ├── META-INF
│ │ └── resources
│ │ └── index.html
│ └── application.properties
└── test
└── java
└── br
└── com
└── food
└── resource
├── FoodResourceTest.java
└── NativeFoodResourceIT.java
19 directories, 12 files
- Para criar o projeto, basta utlizar o template do Maven + Quarkus, conforme o comando abaixo:
mvn io.quarkus:quarkus-maven-plugin:1.0.1.Final:create \
-DprojectGroupId=br.com.food \
-DprojectArtifactId=quarkus-food \
-DclassName="br.com.food.resource.FoodResource" \
-Dpath="/food"
(Alternativo) - O Quarkus disponibiliza um site chamado Quarkus.code.io
, onde é posísvel configurar o projeto de uma forma mais visual, vale a pena conferir, segue o link: https://code.quarkus.io/
Para iniciar o Postgresql, basta rodar o comando abaixo (O Docker precisa estar instalado):
docker run --name postgres-food -e "POSTGRES_PASSWORD=postgres" -p 5433:5432 -v ~/developer/PostgreSQL:/var/lib/postgresql/data -d postgres
Para executar um projeto em Quarkus, basta executar o comando:
mvn compile quarkus:dev
Fique a vontade para contribuir com o projeto.
- Faça um Fork do projeto
- Crie uma Branch para sua Feature (
git checkout -b feature/newFeature
) - Adicione suas mudanças (
git add .
) - Comite suas mudanças (
git commit -m 'Nova funcionalidade para facilitar ...
) - Faça o Push da Branch (
git push origin feature/newFeature
) - Abra um Pull Request
Distribuído sob a licença MIT. Veja LICENSE
para mais informações.
Marcus Paulo - Github