Sample Helidon MP project that includes multiple REST operations. This project requires Oracle NoSQL for data storage, which can be run locally or online.
This application requires Oracle NoSQL Database, which can be set up to run locally using Docker.
To run Oracle NoSQL Database locally, use the following Docker command:
docker run -d --name oracle-instance -p 8080:8080 ghcr.io/oracle/nosql:latest-ce
This command starts an Oracle NoSQL instance running on port 8080
of your local machine.
Alternatively, you may run Oracle NoSQL Database online. For more details, refer to Oracle’s official documentation on running NoSQL in the cloud.
To build and run this project, use JDK 21.
mvn package
java -jar target/books.jar
The application will start on localhost
at port 8181
.
To verify if the application is running, check its health status with:
curl -s -X GET http://localhost:8181/health
Expected Output:
{"outcome":"UP",…}
You can retrieve application metrics in Prometheus or JSON format.
curl -s -X GET http://localhost:8181/metrics
Expected Output:
# TYPE base:gc_g1_young_generation_count gauge…
This project includes an OpenAPI UI, which provides an interactive interface for exploring and testing API endpoints.
To access the OpenAPI UI, navigate to the following URL in your browser:
The OpenAPI UI displays all available API endpoints and allows you to test requests directly within the browser.
Below are examples of using curl
to interact with the API.
# Example: Fetch all books
curl -X GET http://localhost:8181/books
curl -X POST -H "Content-Type: application/json" -d '{"title":"The Catcher in the Rye","genre":"FICTION","publicationYear":1951,"author":"J.D. Salinger","tags":["Classic","Literature","American"]}' http://localhost:8181/books
curl -X POST -H "Content-Type: application/json" -d '{"title":"1984","genre":"DYSTOPIAN","publicationYear":1949,"author":"George Orwell","tags":["Political","Classic","Science Fiction"]}' http://localhost:8181/books
curl -X POST -H "Content-Type: application/json" -d '{"title":"To Kill a Mockingbird","genre":"FICTION","publicationYear":1960,"author":"Harper Lee","tags":["Classic","Justice","American"]}' http://localhost:8181/books
curl -X POST -H "Content-Type: application/json" -d '{"title":"Brave New World","genre":"SCIENCE_FICTION","publicationYear":1932,"author":"Aldous Huxley","tags":["Dystopian","Classic","Philosophical"]}' http://localhost:8181/books
# Example: Update a book
curl -X PUT -H "Content-Type: application/json" -d '{"title":"The Catcher in the Rye - Updated","genre":"FICTION","publicationYear":1951,"author":"J.D. Salinger","tags":["Classic","Literature","American","Updated"]}' http://localhost:8181/books/{id}
# Example: Delete a book
curl -X DELETE http://localhost:8181/books/{id}
If you don’t have access to a Kubernetes cluster, you can install one on your desktop.
kubectl cluster-info # Verify which cluster
kubectl get pods # Verify connectivity to cluster
kubectl create -f app.yaml # Deploy application
kubectl get pods # Wait for quickstart pod to be RUNNING
kubectl get service books # Get service info
kubectl port-forward service/books 8181:8080 # Forward service port to 8181
You can now exercise the application as described above but use port 8181
.
After you’re done, clean up:
kubectl delete -f app.yaml