Skip to content

Commit

Permalink
docs: convert readme to asciidoc
Browse files Browse the repository at this point in the history
Signed-off-by: Otavio Santana <[email protected]>
  • Loading branch information
otaviojava committed Oct 6, 2024
1 parent 8610103 commit dbab4e5
Showing 1 changed file with 67 additions and 65 deletions.
132 changes: 67 additions & 65 deletions README.adoc
Original file line number Diff line number Diff line change
@@ -1,27 +1,31 @@
# intro-helidon-mongodb
= intro-helidon-mongodb

Sample Helidon MP project that includes multiple REST operations.

## Build and run
== Build and run

With JDK21:

With JDK21
```bash
[source,bash]
----
mvn package
java -jar target/intro-helidon-mongodb.jar
```
----

## Exercise the application
== Exercise the application

Basic:
```

[source,bash]
----
curl -X GET http://localhost:8080/simple-greet
Hello World!
```

----

JSON:
```

[source,bash]
----
curl -X GET http://localhost:8080/greet
{"message":"Hello World!"}
Expand All @@ -32,39 +36,36 @@ curl -X PUT -H "Content-Type: application/json" -d '{"greeting" : "Hola"}' http:
curl -X GET http://localhost:8080/greet/Jose
{"message":"Hola Jose!"}
```

----

== Try health

## Try health

```
[source,bash]
----
curl -s -X GET http://localhost:8080/health
{"outcome":"UP",...
----

```


## Building a Native Image
== Building a Native Image

The generation of native binaries requires an installation of GraalVM 22.1.0+.

You can build a native binary using Maven as follows:

```
[source,bash]
----
mvn -Pnative-image install -DskipTests
```
----

The generation of the executable binary may take a few minutes to complete depending on
your hardware and operating system. When completed, the executable file will be available
under the `target` directory and be named after the artifact ID you have chosen during the
project generation phase.

== Try metrics


## Try metrics

```
[source,bash]
----
# Prometheus Format
curl -s -X GET http://localhost:8080/metrics
# TYPE base:gc_g1_young_generation_count gauge
Expand All @@ -74,85 +75,86 @@ curl -s -X GET http://localhost:8080/metrics
curl -H 'Accept: application/json' -X GET http://localhost:8080/metrics
{"base":...
. . .
```

----

== Building the Docker Image

## Building the Docker Image

```
[source,bash]
----
docker build -t intro-helidon-mongodb .
```
----

## Running the Docker Image
== Running the Docker Image

```
[source,bash]
----
docker run --rm -p 8080:8080 intro-helidon-mongodb:latest
```
----

Exercise the application as described above.


## Run the application in Kubernetes
== Run the application in Kubernetes

If you don’t have access to a Kubernetes cluster, you can [install one](https://helidon.io/docs/latest/#/about/kubernetes) on your desktop.
If you don’t have access to a Kubernetes cluster, you can install one by following the link: https://helidon.io/docs/latest/#/about/kubernetes[install Kubernetes on your desktop].

### Verify connectivity to cluster
=== Verify connectivity to cluster

```
[source,bash]
----
kubectl cluster-info # Verify which cluster
kubectl get pods # Verify connectivity to cluster
```
----

### Deploy the application to Kubernetes
=== Deploy the application to Kubernetes

```
[source,bash]
----
kubectl create -f app.yaml # Deploy application
kubectl get pods # Wait for quickstart pod to be RUNNING
kubectl get service intro-helidon-mongodb # Get service info
kubectl get service intro-helidon-mongodb # Get service info
kubectl port-forward service/intro-helidon-mongodb 8081:8080 # Forward service port to 8081
```
----

You can now exercise the application as you did before but use the port number 8081.

After you’re done, cleanup.
After you’re done, cleanup:

```
[source,bash]
----
kubectl delete -f app.yaml
```

----

## Building a Custom Runtime Image
== Building a Custom Runtime Image

Build the custom runtime image using the jlink image profile:
Build the custom runtime image using the `jlink` image profile:

```
[source,bash]
----
mvn package -Pjlink-image
```
----

This uses the helidon-maven-plugin to perform the custom image generation.
After the build completes it will report some statistics about the build including the reduction in image size.
This uses the `helidon-maven-plugin` to perform the custom image generation. After the build completes it will report some statistics about the build including the reduction in image size.

The target/intro-helidon-mongodb-jri directory is a self contained custom image of your application. It contains your application,
its runtime dependencies and the JDK modules it depends on. You can start your application using the provide start script:
The `target/intro-helidon-mongodb-jri` directory is a self-contained custom image of your application. It contains your application, its runtime dependencies, and the JDK modules it depends on. You can start your application using the provided start script:

```
[source,bash]
----
./target/intro-helidon-mongodb-jri/bin/start
```
----

=== Class Data Sharing (CDS) Archive

Class Data Sharing (CDS) Archive
Also included in the custom image is a Class Data Sharing (CDS) archive that improves your application’s startup
performance and in-memory footprint. You can learn more about Class Data Sharing in the JDK documentation.

The CDS archive increases your image size to get these performance optimizations. It can be of significant size (tens of MB).
The size of the CDS archive is reported at the end of the build output.

If you’d rather have a smaller image size (with a slightly increased startup time) you can skip the creation of the CDS
archive by executing your build like this:
If you’d rather have a smaller image size (with a slightly increased startup time) you can skip the creation of the CDS archive by executing your build like this:

```
[source,bash]
----
mvn package -Pjlink-image -Djlink.image.addClassDataSharingArchive=false
```
----

For more information on available configuration options see the helidon-maven-plugin documentation.

For more information on available configuration options see the `helidon-maven-plugin` documentation.

0 comments on commit dbab4e5

Please sign in to comment.