Set up Quarkus in Codespace environment
Setup
Create a repository “workshop”:
data:image/s3,"s3://crabby-images/8c4f9/8c4f97965867c9d41dccd8332f100f2adfd42ed8" alt=""
Open codespace and setup Linux in Terminal:
sudo apt update && \ sudo apt upgrade -y && \ sudo apt install httpie -y
Setup Quarkus Project
Getting started → 4. Bootstrapping the project → Maven
copy and change ArtifactId to workshop
cd .. # pwd -> /workspaces mvn io.quarkus.platform:quarkus-maven-plugin:3.10.2:create \ -DprojectGroupId=org.acme \ -DprojectArtifactId=workshop
data:image/s3,"s3://crabby-images/43b52/43b52b4046eb367f730c79cfa5860f44196d95a4" alt=""
We can not just delete the workshop folder, because GIT information are inside this folder.
Workaround:
cd /workspaces/workshop/ mvn io.quarkus.platform:quarkus-maven-plugin:3.10.2:create \ -DprojectGroupId=org.acme \ -DprojectArtifactId=workshop mv workshop/* . ls -lisah workshop/ # hidden files/directory still there mv workshop/.* . ls -lisah workshop/ # now everthing has moved rmdir workshop
Stage, commit and push to repository:
data:image/s3,"s3://crabby-images/a7456/a7456cba8831694a7fd65d76d3f94a686250e6bd" alt=""
Open GreetingResource, this will force Visual Code to ask to install Extension Pack for Java:
data:image/s3,"s3://crabby-images/14037/140372c4765559a74428ad9e02fadb11e01f5370" alt=""
data:image/s3,"s3://crabby-images/3e93e/3e93e22f4cab983f595a02234d8352ee061fa6d5" alt=""
Go to Explorer → Java Projects → Import Projects
data:image/s3,"s3://crabby-images/1cded/1cded32148347ab4c1f4c1ae49f3b6f4def8e249" alt=""
It takes a minute or two to show our workshop project:
data:image/s3,"s3://crabby-images/73771/7377100e34a131d6796ba2871124ef116992cb5c" alt=""
Start Quarkus
./mvnw quarkus:dev
data:image/s3,"s3://crabby-images/b03cc/b03cc41b9b2cf90fbe8feba671db69fc2158fae9" alt=""
In Ports Port 5005 is automatically added, but not Port 8080.
data:image/s3,"s3://crabby-images/ad6c8/ad6c80c7f6d61724a4f71e0c19d4a9c687126479" alt=""
We need to add Port 8080 manually.
data:image/s3,"s3://crabby-images/7c009/7c009b19fa9a78af0c4bedcbe93bf41744d2491a" alt=""
Click on the Globus Icon and Quarkus welcome page opens:
data:image/s3,"s3://crabby-images/dc98c/dc98c0b3185213e48e8093ac957206192d360414" alt=""
Go to Visit the dev UI → Endpoints
data:image/s3,"s3://crabby-images/53a67/53a6753561ba12f33d9cc5f23fdab54983b930f2" alt=""
Click on /hello:
data:image/s3,"s3://crabby-images/0836a/0836a36104bcc978b0d22c165e466ddecab83df0" alt=""
Test from terminal
Open new Terminal
## "&& echo" for additional linebreak curl localhost:8080/hello && echo http localhost:8080/hello
data:image/s3,"s3://crabby-images/484ce/484ce2e5c9e2f914df883f28a6a71888ae18eb36" alt=""
WebSockets with Quarkus
Quarkus Guide for using WebSockets
Setup ChatSocket
First we need to install extensions:
./mvnw quarkus:add-extension -Dextensions='websockets' ./mvnw quarkus:add-extension -Dextensions='websockets-next'
Create simple ChatSocket:
package org.acme; import io.quarkus.websockets.next.OnTextMessage; import io.quarkus.websockets.next.WebSocket; @WebSocket(path = "/chatsocket") public class ChatSocket { @OnTextMessage public String onMessage(String userMessage){ return "You said: " + userMessage; } }
Test from terminal
npm install -g wscat
wscat -c ws://localhost:8080/chatsocket wscat -c ws://localhost:8080/chatsocket > Hello World! < You said: Hello World!
Build html client
mkdir -p src/main/resources/META-INF/resources touch src/main/resources/META-INF/resources/chat.html
WebSocket Chat Example WebSocket Chat Example
Connecting...
data:image/s3,"s3://crabby-images/983d3/983d3325cb21829430b714819d63fb10d24b4461" alt=""
CONTEXTS AND DEPENDENCY INJECTION Example
Add a ChatService for the 'logic' and inject it into the Chat Socket:
package org.acme; import io.quarkus.runtime.StartupEvent; import jakarta.enterprise.context.ApplicationScoped; import jakarta.enterprise.event.Observes; @ApplicationScoped public class ChatService { protected void startup(@Observes StartupEvent event) { System.out.println("Startuuuuuuuuuup event"); } public String chat(String message) { return message + " you said."; } }
package org.acme; import io.quarkus.websockets.next.OnTextMessage; import io.quarkus.websockets.next.WebSocket; import jakarta.inject.Inject; @WebSocket(path = "/chatsocket") public class ChatSocket { @Inject ChatService chatService; @OnTextMessage public String onMessage(String userMessage){ return chatService.chat(userMessage); } }
data:image/s3,"s3://crabby-images/f4810/f48107e51b2e9c54796eec47c4008a34278e14c4" alt=""
data:image/s3,"s3://crabby-images/c3f44/c3f44b93357fca3e036d9be54027d8197c458a55" alt=""
Build and run native Image
Building a Native Executable - Quarkus
Build:
# Ich muss vermutlich nur den zweiten Befehl ausführen? # ./mvnw install -Dnative ./mvnw package -Dnative -Dquarkus.native.container-build=true -Dquarkus.container-image.build=true
Open another terminal and see how much codespace machine is sweating:
htop
Run:
target/workshop-1.0.0-SNAPSHOT-runner
data:image/s3,"s3://crabby-images/6a3c6/6a3c608b7836c79641002cb78eb62c783dd34cf4" alt=""
The project generation has provided a Dockerfile.native-micro
in the src/main/docker
directory.
# build docker build -f src/main/docker/Dockerfile.native-micro -t deringo/workshop . # run docker run -i --rm -p 8080:8080 deringo/workshop
data:image/s3,"s3://crabby-images/68007/68007ecdaf94c50f5e8650ea93027ec213f9f81d" alt=""