diff --git a/.github/workflows/native-netty-plot.yml b/.github/workflows/archive-native-netty-plot.yml similarity index 72% rename from .github/workflows/native-netty-plot.yml rename to .github/workflows/archive-native-netty-plot.yml index 423287ea7..33883aa82 100644 --- a/.github/workflows/native-netty-plot.yml +++ b/.github/workflows/archive-native-netty-plot.yml @@ -1,38 +1,33 @@ -name: native-netty-plot +name: archive/native-netty-plot on: push: paths: - - 'native-netty-plot/**' - - '.github/workflows/native-netty-plot.yml' + - 'archive/native-netty-plot/**' + - '.github/workflows/archive-native-netty-plot.yml' pull_request: paths: - - 'native-netty-plot/**' - - '.github/workflows/native-netty-plot.yml' - schedule: - - cron: "0 0 1 * *" # run every month + - 'archive/native-netty-plot/**' + - '.github/workflows/archive-native-netty-plot.yml' workflow_dispatch: permissions: contents: read jobs: run: - name: Run 'native-netty-plot' + name: Run 'archive/native-netty-plot' runs-on: ubuntu-latest timeout-minutes: 20 - strategy: - matrix: - java-version: ['21', 'dev'] steps: - uses: actions/checkout@v4 - uses: graalvm/setup-graalvm@v1 with: - java-version: ${{ matrix.java-version }} + java-version: '21' distribution: 'graalvm' github-token: ${{ secrets.GITHUB_TOKEN }} cache: 'maven' native-image-job-reports: 'true' - - name: Run 'native-netty-plot' + - name: Run 'archive/native-netty-plot' run: | - cd native-netty-plot + cd archive/native-netty-plot mvn --no-transfer-progress package java -agentlib:native-image-agent=config-output-dir=src/main/resources/META-INF/native-image/com.oracle.substratevm/netty-plot -jar target/netty-plot-0.1-jar-with-dependencies.jar & pid=$! diff --git a/README.md b/README.md index e37cb960f..36c90836e 100644 --- a/README.md +++ b/README.md @@ -56,8 +56,8 @@ cd graalvm-demos Demonstrates how you can influence the classes initialization at the image build time
Technologies: Native Image, Maven
Reference: Understanding Class Initialization in GraalVM Native Image Generation - native-netty-plot
native-netty-plot - A web server application, using the Netty framework, to demonstrate the use of isolates with Native Image
Technologies: Native Image, Maven, Netty
Reference: Instant Netty Startup using GraalVM Native Image Generation + javagdbnative
javagdbnative + Demonstrates how to debug a Java application, built into a native executable in VS Code
Technologies: Native Image, Maven, GraalVM Tools for Java
Reference: Native Image Debugging in VS Code native-image/add-logging
add-logging diff --git a/archive/native-netty-plot/.gitignore b/archive/native-netty-plot/.gitignore new file mode 100644 index 000000000..fd94e1973 --- /dev/null +++ b/archive/native-netty-plot/.gitignore @@ -0,0 +1,2 @@ +target/ +netty-plot \ No newline at end of file diff --git a/native-netty-plot/README.md b/archive/native-netty-plot/README.md similarity index 68% rename from native-netty-plot/README.md rename to archive/native-netty-plot/README.md index 6e8cfd676..b1196635c 100644 --- a/native-netty-plot/README.md +++ b/archive/native-netty-plot/README.md @@ -1,4 +1,4 @@ -# Isolates for GraalVM Native Images +# Use of Isolates with Native Image This application demonstrates the use of _isolates_ with [GraalVM Native Image](https://www.graalvm.org/latest/reference-manual/native-image/). The code implements a web service that renders plots of mathematical functions, such as _sin(x)_. @@ -22,33 +22,34 @@ There is also the [Maven plugin for GraalVM Native Image building](https://graal git clone https://github.com/graalvm/graalvm-demos ``` ```bash - cd graalvm-demos/native-netty-plot + cd graalvm-demos/archive/native-netty-plot ``` + For compilation, the `native-image` depends on the local toolchain. -Please make sure that `glibc-devel`, `zlib-devel` (header files for the C library and zlib), and `gcc` are available on your system. Some Linux distributions may additionally require `libstdc++-static`. +Make sure that `glibc-devel`, `zlib-devel` (header files for the C library and zlib), and `gcc` are available on your system. Some Linux distributions may additionally require `libstdc++-static`. See [Prerequisites for Native Image](https://www.graalvm.org/latest/reference-manual/native-image/#prerequisites). -## Build the Project +## Build the Application The example is built with Maven: ```bash mvn package ``` -This creates a JAR file with all dependencies embedded: `target/netty-plot-0.1-jar-with-dependencies.jar`. +This creates a JAR file with all dependencies embedded in the _target/_ directory. ## Generate a Native Executable If the application is expected to use some dynamic features at run time (e.g., Reflection, Java Native Interface, class path resources), they have to be provided to the `native-image` tool in the form of configuration files. To avoid writing the configuration file yourself, apply the [tracing agent](https://www.graalvm.org/latest/reference-manual/native-image/metadata/AutomaticMetadataCollection/) when running on the Java HotSpot VM. It will observe the application behavior and create configuration files (_jni-config.json_, _reflect-config.json_, _proxy-config.json_ and _resource-config.json_) in the _META-INF/native-image_ directory on the class path. -The _reflect-config.json_ file specifies classes which must be available via Java reflection at runtime. +The _reflect-config.json_ file specifies classes which must be available via Java reflection at run time. -1. Run the application on GraalVM JDK applying the tracing agent: +1. Run the application on the GraalVM JDK applying the tracing agent: ```bash java -agentlib:native-image-agent=config-output-dir=src/main/resources/META-INF/native-image -jar target/netty-plot-0.1-jar-with-dependencies.jar ``` - The server is started. Open _http://127.0.0.1:8080/?useIsolate=false_ in the browser to see the output. + The server is started. Open [http://127.0.0.1:8080/?useIsolate=false](http://127.0.0.1:8080/?useIsolate=false) in the browser to see the output. 2. Terminate the application, `CTRL+C`. @@ -58,33 +59,34 @@ The _reflect-config.json_ file specifies classes which must be available via Jav ``` The result is an executable file that is around 22 MByte in size: ```bash - du -h netty-plot - 22M netty-plot + du -h target/netty-plot ``` 4. You can now run the executable: ```bash ./netty-plot ``` - Open your web browser and navigate to http://127.0.0.1:8080/ + Open your web browser and navigate to [http://127.0.0.1:8080/](http://127.0.0.1:8080/) -5. Finally, you can open your browser and request rendering of a function, for example, by browsing to `http://127.0.0.1:8080/?function=abs((x-31.4)sin(x-pi/2))&xmin=0&xmax=31.4`. +5. Finally, you can open your browser and request rendering of a function, for example, by browsing to [http://127.0.0.1:8080/?function=abs((x-31.4)sin(x-pi/2))&xmin=0&xmax=31.4](http://127.0.0.1:8080/?function=abs((x-31.4)sin(x-pi/2))&xmin=0&xmax=31.4). ### Background Information Instead of specifying any additional parameters on the command line, they may provided in a properties file in the input JAR file. -The `native-image` builder automatically looks for files named `native-image.properties` and for any other configuration file under `META-INF/native-image` including subdirectories, and processes their contents. +The `native-image` builder automatically looks for files named _native-image.properties_ and for any other configuration file under _META-INF/native-image_ including subdirectories, and processes their contents. The tracing agent writes the _reflect-config.json_ file specifying classes which must be available via Java reflection at run time. -With Maven projects, the path convention is `META-INF/native-image/${groupId}/${artifactId}/native-image.properties`. -In this example, the `META-INF/native-image/com.oracle.substratevm/netty-plot/native-image.properties` file contains the following: +With Maven projects, the path convention is _META-INF/native-image/${groupId}/${artifactId}/native-image.properties_. +In this example, the _META-INF/native-image/com.oracle.substratevm/netty-plot/native-image.properties_ file contains the following: ```bash ImageName = netty-plot Args = --link-at-build-time ``` The `ImageName` property specifies the name of the resulting executable, while `Args` are treated like additional command-line arguments. -### A note about the application +#### A note about the application -This example cannot run as a regular Java application (on the JVM) and it cannot be profiled. +This example cannot run as a regular Java application (on HotSpot) and it cannot be profiled. It will fail because the program tries to create an [isolate which is a Native Image specific feature](https://medium.com/graalvm/isolates-and-compressed-references-more-flexible-and-efficient-memory-management-for-graalvm-a044cc50b67e). + +Read more in the blog post [Instant Netty Startup using GraalVM Native Image Generation](https://medium.com/graalvm/instant-netty-startup-using-graalvm-native-image-generation-ed6f14ff7692). \ No newline at end of file diff --git a/native-netty-plot/pom.xml b/archive/native-netty-plot/pom.xml similarity index 97% rename from native-netty-plot/pom.xml rename to archive/native-netty-plot/pom.xml index 9663858e2..e00808064 100644 --- a/native-netty-plot/pom.xml +++ b/archive/native-netty-plot/pom.xml @@ -9,7 +9,7 @@ UTF-8 21 - 0.9.28 + 0.10.4 ${java.specification.version} ${java.specification.version} @@ -60,7 +60,7 @@ ${imageName} false - --no-fallback + --no-fallback true diff --git a/native-netty-plot/src/main/java/com/oracle/svm/nettyplot/FunctionPlotter.java b/archive/native-netty-plot/src/main/java/com/oracle/svm/nettyplot/FunctionPlotter.java similarity index 100% rename from native-netty-plot/src/main/java/com/oracle/svm/nettyplot/FunctionPlotter.java rename to archive/native-netty-plot/src/main/java/com/oracle/svm/nettyplot/FunctionPlotter.java diff --git a/native-netty-plot/src/main/java/com/oracle/svm/nettyplot/PlotServer.java b/archive/native-netty-plot/src/main/java/com/oracle/svm/nettyplot/PlotServer.java similarity index 100% rename from native-netty-plot/src/main/java/com/oracle/svm/nettyplot/PlotServer.java rename to archive/native-netty-plot/src/main/java/com/oracle/svm/nettyplot/PlotServer.java diff --git a/archive/native-netty-plot/src/main/resources/META-INF/native-image/com.oracle.substratevm/netty-plot/native-image.properties b/archive/native-netty-plot/src/main/resources/META-INF/native-image/com.oracle.substratevm/netty-plot/native-image.properties new file mode 100644 index 000000000..0728080b7 --- /dev/null +++ b/archive/native-netty-plot/src/main/resources/META-INF/native-image/com.oracle.substratevm/netty-plot/native-image.properties @@ -0,0 +1,2 @@ +ImageName = netty-plot +Args = --link-at-build-time=com.oracle.svm.nettyplot \ No newline at end of file diff --git a/native-netty-plot/.gitignore b/native-netty-plot/.gitignore deleted file mode 100644 index 434368352..000000000 --- a/native-netty-plot/.gitignore +++ /dev/null @@ -1,4 +0,0 @@ - -target/ -netty-plot - diff --git a/native-netty-plot/src/main/resources/META-INF/native-image/com.oracle.substratevm/netty-plot/native-image.properties b/native-netty-plot/src/main/resources/META-INF/native-image/com.oracle.substratevm/netty-plot/native-image.properties deleted file mode 100644 index 8b93bd90b..000000000 --- a/native-netty-plot/src/main/resources/META-INF/native-image/com.oracle.substratevm/netty-plot/native-image.properties +++ /dev/null @@ -1,2 +0,0 @@ -ImageName = netty-plot -Args = --link-at-build-time=com.oracle.svm.nettyplot