Quark.jar May 2026

./mvnw package Quarkus produces a directory (typically target/quarkus-app/ ) containing several files. At the root of that directory sits quarkus-app/quark-run.jar —often symlinked or referenced simply as in documentation and scripts.

In the rapidly evolving landscape of cloud-native development, Java has often been criticized for being "heavy." Enter Quarkus—the supersonic, subatomic Java framework designed specifically for Kubernetes and serverless environments. While most developers are familiar with building Quarkus applications using Maven or Gradle, a critical yet often misunderstood artifact sits at the heart of its deployment strategy: quark.jar . quark.jar

If you have ever run a Quarkus application in production, you have almost certainly interacted with quark.jar . But what exactly is it? How does it differ from a traditional "fat JAR"? And why should you care about its unique build-time optimizations? While most developers are familiar with building Quarkus

COPY target/quarkus-app/lib/ /deployments/lib/ COPY target/quarkus-app/app/ /deployments/app/ COPY target/quarkus-app/quarkus-run.jar /deployments/ WORKDIR /deployments CMD ["java", "-jar", "quarkus-run.jar"] The humble quark.jar is more than just an executable file; it is a manifesto on how Java development is changing. By moving work from runtime to build time, by separating concerns into logical folders, and by refusing to conform to the "fat JAR" standard, Quarkus has delivered a Java stack that competes head-to-head with Node.js and Go in cloud environments. How does it differ from a traditional "fat JAR"