PedroGeoGISdev wiki
  • Linux OS
    • Linux: concepts
    • Linux: basic concepts
    • Linux: Bash
    • Linux: su and sudo
    • Linux: pipes
    • Linux: File System
    • Linux: Virtual Machines

    • Linux: distros
    • Linux Distros: Ubuntu
    • Linux Distros: Mint
    • Linux Distros: Debian
    • Linux Distros: openSuse
    • Linux Distros: Manjaro
    • Linux Distros: Red Hat Enterprise

    • Linux: laboratories
    • Linux Lab#LI01-1: Choose Linux
    • Linux Lab#LI01-2: Install at least three distributions
    • Linux Lab#LI01-3: Adjust user permissions
    • Linux Lab#LI02-1: Export env user with grep and pipe
    • Linux Lab#LI03-1: Manage users and groups
    • Linux Lab#LI03-2: Manage files
    • Linux Lab#LI03-3: Manage software
    • Linux Lab#LI03-4: Manage hardware
    • Linux Lab#LI04-1: Bash scripting, qtool
    • Linux Lab#LI04-2: Bash scripts as terminal tool
    • Linux Lab#LI04-3: Distribute the terminal app

    • Linux readings
    • Linux Resources
  • DevOps
    • What is DevOps
    • DevOps: Introduction
    • DevOps: Agile and Microservices
    • Infrastructure as code (IaC)
    • Immutable Infrastructure
    • Software Lifecycle

    • Documentation
    • How to document: Quarto and Obsidian

    • Network protocols
    • Network: Basics
    • Network: Client-server
    • Network Protocols
    • Network: DNS
    • Network: API Rest
    • Network: gRPC
    • Network: Websocket
    • Network: SMTP
    • Network: Ping
    • Network: UDP
    • Network: webhook
    • Network: SOAP
    • Network: graphQL

    • Version Control
    • Git
    • GitHub
    • Idea and GitHub 2023
    • Git and GitHub 2023 CLI

    • IDEs
    • IDE: Visual Code
    • IDE: IntellJIdea

    • DevOps tools
    • Amazon Web Services AWS
    • Docker
    • Jenkins pipelines
    • Kubernetes k8s
    • Digital Ocean
    • Nagios
    • Ansible

    • DevOps Laboratories
    • Lab 1: chat App
    • Lab 2: Spring Boot AWS AEB manually
    • Lab 3: Spring Boot and AWS S3 publisher
    • Lab 4: Spring Boot Docker/Jenkins
    • Lab 5: k8s on Digital Ocean
    • Lab 6: Spring Boot AWS codecommit

    • DevOps readings
    • DevOps Resources
  • MarkUp
    • MarkUp Languages
    • Introduction Markup
    • HTML Markup
    • Markdown Markup
    • Markdown and HTML working together, good idea?

    • Quarto Markdown
    • Quarto Markdown: basics
    • Quarto Markdown: creating
    • Quarto Markdown: publishing
    • Quarto Markdown: code & data
    • Quarto Markdown: api rest call
    • Quarto Markdown: OJS Cells
    • Quarto Markdown: cheat-sheet

    • Styling: CSS
    • Cascade Style Sheet
    • Cascade Style Sheet: Box Model and Containers
    • CSS: W3.css

    • MarkUp Languages Laboratories
    • Lab#MD01-1: Create and publish by Quarto

    • MarkUp Languages readings
    • MarkUp Languages Resources
  • Java SE
    • What is Java SE
    • Java Standard Edition: Basics
    • Java Standard Edition: Principles
    • Java MOOC Helsinki
    • Java MOOC Helsinki Syllabus

    • Java Create Project
    • Java SE: Maven
    • Java SE: Create Maven Project
    • Java SE: Project push GitHub
    • Java SE: JUnit and TDD

    • Java Concepts
    • Java SE: Class and Objects
    • Java SE: Scope
    • Java SE: static modifier
    • Java SE: Coupling and DDD
    • Java SE: Packages
    • Java SE: Abstract/Interface
    • Java SE: Java 8

    • Java Principles
    • Java SE: Encapsulation
    • Java SE: Abstraction
    • Java SE: Inherence
    • Java SE: Polymorphism

    • Java Design Patterns
    • Java Patterns: UML
    • Java Patterns: Types
    • Singleton
    • Factory
    • Abstract Factory
    • Builder
    • Facade
    • Bridge
    • Decorator
    • Composite
    • Observer
    • Strategy
    • State
    • Commander

    • Java SE Laboratories
    • Lab#SE00-1: Maven Person
    • Lab#SE00-2: Maven Clinic
    • Lab#SE00-3: Library Model
    • Lab#SE00-4: Abstract/Interface Human
    • Lab#SE01-1: Maven/Gradle Person and Account
    • Lab#SE01-2: Maven/Gradle Person and Account stored in JSON
    • Lab#SE02-1: Movie/Review, Model
    • Lab#SE02-2: Movie/Review, CRUD Operations
    • Lab#SE02-3: Movie/Review, factory
    • Lab#SE02-4: Movie/Review, interactivity and coupling
    • Lab#SE02-5: Movie/Review, simulate interactivity by console
    • Lab#SE03-1: Library/Book, Core-Model
    • Lab#SE03-2: Library/Book, Sprint Zero
    • Lab#SE03-3: Library/Book, Expand Model
    • Lab#SE04-1: healthyFood Restaurant, Core Model

    • Java SE readings
    • Java SE Resources
  • Python
    • Python Basics
    • Python: Basic Concepts
    • Python: Tips
  • JavaScript
    • JavaScript Basics
    • JavaScript: Basic Concepts
    • JavaScript: Tips

    • React Framework

    • ReactJS: Principles
    • React JS: Introduction
    • React JS: render virtual DOM
    • React JS: Create a React project
    • React JS: Components
    • React JS: JSX
    • React JS: props and state

    • JavaScript: web scripting
    • JavaScript: basics
    • JavaScript: functions
    • JavaScript: objects
    • JavaScript: variables
    • JavaScript: flux control

    • ES6: ECMAScript 6
    • React JS ES6: arrow functions
    • React JS ES6: import modules
    • React JS ES6: array, data and key
    • React JS ES6: destructuring
    • React JS ES6: spread operator

    • ReacJS 18: Hooks
    • React JS: Rules of Hooks
    • ReactJS: useState
    • React JS: useReducer
    • React JS: useRef
    • React JS: useEffect
    • React JS: useContext
    • ReactJS: useMemo
    • ReactJS: custom hooks

    • ReactJS: Designing an App
    • React JS App: async
    • React JS App: events
    • React JS App: router
    • React JS App: conditional render
    • React JS App: styling

    • React JS: Laboratories
    • Lab#RE01-1: API Rest Axios
    • Lab#RE02-1: Router & Hooks
    • Lab#RE03-1: to-do app
    • Lab#RE03-2: HighCharts
    • Lab#RE03-3: API Rest Mono
    • Lab#RE03-4: API Rest Domains
    • Lab#RE03-5: data management
    • Lab#RE04-1: todo & server
    • Lab#RE04-2: Spring Boot & ReactJS
    • Lab#RE05-1: chat & websockets
    • Lab#RE05-2: chat: backend
    • Lab#RE05-3: chat & AWS
    • Lab#RE05-4: chat: test ws AWS
    • Lab#RE05-5: chat & front
    • Lab#RE05-6: chat & ws: front
    • Lab#RE06-1: healthyFood Restaurant
    • Lab#RE06-1-PR: create a pull request
    • Lab#RE07-1: traffic lights simulation

    • React JS readings
    • ReactJS Resources
  • Backend
    • Spring Legacy
    • Spring Framework
    • Spring MVC
    • Springs Servlets

    • Spring Boot Basics
    • Spring Boot: fundamentals
    • Spring Boot: create a Project
    • Spring Boot: H2 DB and Thymeleaf
    • Spring Boot: cycle

    • Spring Boot Concepts
    • Spring Boot: Dependency Injection
    • Spring Boot: Annotations
    • Spring Boot: Controller
    • Spring Boot: View
    • Spring Boot: Thymeleaf
    • Spring Boot: Vaadin Flow
    • Spring Boot: Vaadin Hilla
    • Spring Boot: Model
    • Spring Boot: Rest
    • Spring Boot: Data & DB
    • Spring Boot: JPA & DI
    • Spring Boot: JPA Mappings
    • Spring Boot: JPA Relationships
    • Spring Boot: JPA Queries
    • Spring Boot: JPA Inherence
    • Spring Boot: Scaling

    • Spring Boot Laboratories
    • Lab#SB00-1: Library UML
    • Lab#SB00-2: CRUD User
    • Lab#SB00-3: LibraryManagement
    • Lab#SB00-4: API Rest
    • Lab#SB00-5: Rest & JPA-H2
    • Lab#SB00-6: Rest & MongoDB
    • Lab#SB00-7: Styling
    • Lab#SB01-1: DataBase
    • Lab#SB02-1: JPA Relationships
    • Lab#SB03-1: APIs & cloud
    • Lab#SB04-1: JPA Inherence
    • Lab#SB05-1: API Rest
    • Lab#SB06-1: employeeCourse
    • Lab#SB07-1: monitor Book
    • Lab#SB08-1: Restaurant UML
    • Lab#SB08-2: Vaadin
    • Lab#SB08-3: H2 and API Rest
    • Lab#SB08-4: JPA
    • Lab#SB08-5: Test API Rest
    • Lab#SB09-1: SpringIO Conference

    • Spring Boot readings
    • Spring Boot Resources
  • Learning
    • Vocabulary
    • General Vocabulary
    • SCRUM Vocabulary
    • DevOps Vocabulary
    • Java SE Vocabulay
    • Spring Boot Vocabulary
    • DataBase Vocabulary
    • ReactJS Vocabulary
    • Web Vocabulary

    • Learning
    • Useful Questions
    • Learning: tips
    • Writing
    • Taking Notes
    • Comments
    • Document
    • Auto-Evaluate

    • Books & Articles
    • Books
    • Articles

    • What is SCRUM
    • SCRUM Agile Methodology
    • Agile Manifesto & Values
    • SCRUM Guide

    • Scrum Steps
    • Meetings, Impediments and Iterations
    • User stories, Tasks and Habits
    • Delivering Value & Communication
    • ScrumMaster, how it works
    • Mindset, the key to everything
    • Product Owner, how it works
    • Managing Time & Mind
    • Team & the Specialist
    • Albertus’ Dilemma
    • Before SCRUM
    • Team Dynamics
    • Emotions and Thoughts
    • Decision Making and Intuition
    • Beyond SCRUM
    • Balances, atmosphere and tools

    • Resources
    • SCRUM Resources
  • QGIS
    • QGIS basics
    • QGIS: basic concepts

    • QGIS laboratories
    • QGIS Laboratory 1: Introduction to Open Source GIS
  • ArcGIS Pro
    • ArcGIS Pro basics
    • ArcGIS Pro: basic concepts

    • ArcGIS Pro laboratories
    • ArcGIS Pro Laboratory 1: Getting Started
  • Bookmarks
    • Online Resources
    • Online Resources
  • About
    • About me and this site
    • About me
    • About this site
    • About images credit
  • Maps
  • Featured Projects
    • ✈️ Flight tracker
    • 🧑 People tracker
    • 🚗 Renting Car
    • Email
    • GitHub
    • LinkedIn

On this page

  • 1 Introduction to JAR File Creation
    • 1.1 Key Benefits of JAR Deployment
  • 2 Understanding JAR Types
    • 2.1 Regular JAR
    • 2.2 Fat JAR (Executable JAR)
  • 3 Spring Boot Application Deployment
    • 3.1 Technology Stack Components
      • 3.1.1 Spring Boot
      • 3.1.2 Maven Build Tool
      • 3.1.3 Vaadin Framework
  • 4 Build Process and Configuration
    • 4.1 Maven Configuration Analysis
    • 4.2 Build Command Structure
  • 5 Common Issues and Solutions
    • 5.1 Java Environment Configuration
      • 5.1.1 Java Version Compatibility
      • 5.1.2 Environment Variable Importance
  • 6 Deployment and Execution
    • 6.1 JAR File Characteristics
    • 6.2 Execution Commands
      • 6.2.1 Basic Execution
      • 6.2.2 Custom Port Configuration
      • 6.2.3 Memory Optimization
  • 7 Popular Java Build Tools
    • 7.1 Maven
    • 7.2 Gradle
    • 7.3 Spring Boot Maven Plugin
  • 8 Best Practices and Recommendations
    • 8.1 Build Optimization
    • 8.2 Deployment Strategies
    • 8.3 Troubleshooting Guidelines
      • 8.3.1 Build Issues
      • 8.3.2 Runtime Issues
  • 9 Conclusion
  • Edit this page
  • View source
  • Report an issue

JAR Creation Guide: Spring Boot Application Deployment

Spring Boot JAR Creation and Deployment

devops
java
spring-boot
maven
deployment
A comprehensive guide to creating runnable JAR files for Spring Boot applications with Maven
Author

pedromartinezduran

Published

Tuesday, July 29, 2025

Modified

Tuesday, August 12, 2025

1 Introduction to JAR File Creation

In modern Java development, creating runnable JAR files is essential for application deployment and distribution.

A JAR (Java ARchive) file is like a shipping container for your Java application - everything needed to run your program is packaged together in one convenient file.

1.1 Key Benefits of JAR Deployment

  1. Portability: Run anywhere Java is installed
  2. Self-contained: All dependencies included
  3. Simplified Deployment: Single file deployment
  4. Version Control: Easy to manage application versions
  5. Production Ready: Optimized for production environments

2 Understanding JAR Types

There are two main types of JAR files in Java development:

2.1 Regular JAR

  • Contains only your application code
  • Requires external dependencies to be available
  • Smaller file size
  • Suitable for library distribution

2.2 Fat JAR (Executable JAR)

  • Contains your code + all dependencies + embedded server
  • Also called “uber JAR” or “shaded JAR”
  • Self-contained and executable
  • This is what we create for Spring Boot applications

3 Spring Boot Application Deployment

Spring Boot applications are particularly well-suited for JAR deployment due to their embedded server architecture.

3.1 Technology Stack Components

3.1.1 Spring Boot

Spring Boot provides: - Pre-configured settings - Embedded web server (Tomcat) - Dependency management - Simplified deployment

3.1.2 Maven Build Tool

Maven handles: - Dependency management - Code compilation - Test execution - JAR packaging

3.1.3 Vaadin Framework

Vaadin enables: - Java-based web UI development - Production-optimized frontend builds - Component-based architecture

4 Build Process and Configuration

4.1 Maven Configuration Analysis

The pom.xml file serves as Maven’s “recipe book” for building the project:

<groupId>com.pedro.apps</groupId>
<artifactId>world-renting-car</artifactId>
<version>1.0-SNAPSHOT</version>
<packaging>jar</packaging>

Configuration breakdown: - groupId: Organization identifier - artifactId: Application name - version: Current version (SNAPSHOT = development) - packaging: Output format (JAR)

4.2 Build Command Structure

JAVA_HOME=/usr/lib/jvm/java-21-openjdk-amd64 ./mvnw clean package -Pproduction

Command components: - JAVA_HOME: Java installation path - ./mvnw: Maven wrapper (portable Maven) - clean: Remove previous build artifacts - package: Compile and create JAR - -Pproduction: Use production profile

5 Common Issues and Solutions

5.1 Java Environment Configuration

5.1.1 Java Version Compatibility

Common Error:

[ERROR] Fatal error compiling: error: release version 21 not supported

Solution Steps:

  1. Verify Java Installation:
java -version
  1. Set JAVA_HOME Environment Variable:
export JAVA_HOME=/usr/lib/jvm/java-21-openjdk-amd64
  1. Verify Maven Configuration:
./mvnw -version

5.1.2 Environment Variable Importance

JAVA_HOME is crucial because: - Maven is a Java program itself - It needs to compile Java code - It must know which Java version to use - Provides consistent build environment

6 Deployment and Execution

6.1 JAR File Characteristics

Property Description
File Size ~68 MB (includes all dependencies)
Type Executable JAR (Fat JAR)
Dependencies All included
Server Embedded Tomcat
Frontend Production-optimized

6.2 Execution Commands

6.2.1 Basic Execution

java -jar target/world-renting-car-1.0-SNAPSHOT.jar

6.2.2 Custom Port Configuration

java -jar target/world-renting-car-1.0-SNAPSHOT.jar --server.port=9090

6.2.3 Memory Optimization

java -Xmx1g -jar target/world-renting-car-1.0-SNAPSHOT.jar

7 Popular Java Build Tools

Several tools are available for Java project builds:

  • Maven: https://maven.apache.org
  • Gradle: https://gradle.org
  • SBT: https://www.scala-sbt.org
  • Ant: https://ant.apache.org

These tools demonstrate different approaches to Java project management and build automation.

7.1 Maven

  • Purpose: Dependency management and build automation
  • Advantage: Standardized project structure and lifecycle

Key Features: - Declarative build configuration - Extensive plugin ecosystem - Repository-based dependency management - Multi-module project support

7.2 Gradle

  • Specialty: Flexible build automation
  • Strength: Groovy/Kotlin-based DSL

Key Features: - Incremental builds for performance - Flexible project structure - Advanced dependency management - Build cache optimization

7.3 Spring Boot Maven Plugin

The Spring Boot Maven plugin provides essential functionality:

  • Executable JAR creation: Packages application with dependencies
  • Development tools: Hot reload and debugging support
  • Production optimization: Minimized and optimized builds
  • Docker integration: Container-ready artifacts

8 Best Practices and Recommendations

8.1 Build Optimization

  1. Use Production Profiles: Enable optimizations for deployment
  2. Dependency Management: Keep dependencies up to date
  3. Testing Integration: Include comprehensive test suites
  4. Environment Configuration: Externalize configuration properties

8.2 Deployment Strategies

  1. Environment Consistency: Use same Java version across environments
  2. Resource Management: Configure appropriate memory settings
  3. Monitoring: Implement application health checks
  4. Security: Follow security best practices for production

8.3 Troubleshooting Guidelines

8.3.1 Build Issues

  • Clean build artifacts regularly
  • Verify Java environment configuration
  • Check dependency conflicts
  • Review Maven/Gradle logs

8.3.2 Runtime Issues

  • Monitor application logs
  • Verify port availability
  • Check resource utilization
  • Validate configuration properties

9 Conclusion

Creating runnable JAR files for Spring Boot applications provides a robust deployment strategy that combines:

  • Simplicity: Single file deployment
  • Portability: Cross-platform compatibility
  • Self-containment: All dependencies included
  • Production readiness: Optimized for deployment

This approach enables efficient application distribution and deployment across various environments while maintaining consistency and reliability.

The combination of Spring Boot’s embedded server architecture with Maven’s build automation creates a powerful deployment pipeline suitable for modern DevOps practices.

Back to top

This website is built with Quarto.

Difficulties are just things to overcome, after all. Ernest Shackleton

  • Edit this page
  • View source
  • Report an issue