Introduction to Spring Boot CLI

1. Introduction

Spring Boot CLI is a command-line abstraction that allows us to easily run Spring micro-services expressed as Groovy scripts. It also provides simplified and enhanced dependency management for those services.

This short article takes a quick look at how to configure Spring Boot CLI and execute simple terminal commands to run pre-configured micro-services.

We’ll use Spring Boot CLI 2.0.0.RELEASE for this article. The newest version of Spring Boot CLI can be found over at Maven Central.

2. Setting Up Spring Boot CLI

One of the easiest ways to set up Spring Boot CLI is to use SDKMAN. Setup and installation instructions for SDKMAN can be found here.

After installing SDKMAN, run the following command to automatically install and configure Spring Boot CLI:

$ sdk install springboot

To verify the install, run the command:

$ spring --version

We can also install Spring Boot CLI by compiling from source, and Mac users can use pre-built packages from Homebrew or MacPorts. See the official docs for all installation options.

3. Common Terminal Commands

Spring Boot CLI provides several useful commands and features out-of-the-box. One of the most helpful features is Spring Shell, which wraps commands with the necessary spring prefix.

To start the embedded shell, we run:

spring shell

From here, we can directly enter desired commands without pre-pending the spring keyword (since we’re now in spring shell).

For example, we can display the current version of the running CLI by typing:

version

One of the most important commands is telling Spring Boot CLI to run a Groovy script:

run [SCRIPT_NAME].groovy

Spring Boot CLI will either automatically infer the dependencies or will do so given the correctly supplied annotations. After this, it will launch an embedded web container and app.

Let’s take a closer look at how to use Groovy script with Spring Boot CLI!

4. Essential Groovy Scripts

Groovy and Spring come together with Spring Boot CLI to allow powerful, performant micro-services to be quickly scripted in single-file Groovy deployments.

Support for multiply-scripted applications usually requires additional build tools like Maven or Gradle.

Below we’ll cover some of the most common use-cases for Spring Boot CLI, reserving more complex setups for other articles.

For a list of all Spring-supported Groovy annotations, please check out the official docs.

4.1. @Grab

The @Grab annotation and Groovy’s Java-esque import clauses allow for easy dependency management and injection.

In fact, most annotations abstract, simplify, and automatically include the necessary import statements. This allows us to spend more time thinking about architecture and the underlying logic of the services we want to deploy.

Let’s take a look at how to use the @Grab annotation:

package org.test

@Grab("spring-boot-starter-actuator")

@RestController
class ExampleRestController{
  //...
}

As we can see, spring-boot-starter-actuator comes pre-configured allowing for succinct script deployment without requiring a customized application or environmental properties, XML, or other programmatic configuration, though each of those things can be specified when necessary.

The full list of @Grab arguments — each specifying a library to download and import — is available here.

4.2. @Controller, @RestController, and @EnableWebMvc

To further expedite deployment, we can alternatively utilize Spring Boot CLI’s provided “grab hints” to automatically infer correct dependencies to import.

We’ll go over some of the most common use cases below.

For example, we can use the familiar @Controller and @Service annotations to quickly scaffold a standard MVC controller and service:

@RestController
class Example {
 
    @Autowired
    private MyService myService;

    @GetMapping("/")
    public String helloWorld() {
        return myService.sayWorld();
    }
}

@Service
class MyService {
    public String sayWorld() {
        return "World!";
    }
}

Spring Boot CLI supports all default configuration for Spring Boot. So, we can our Groovy apps will automatically access static resources from their usual default locations.

4.3. @EnableWebSecurity

To add Spring Boot Security options to our app, we can use the @EnableWebSecurity annotation, which will then be automatically downloaded by Spring Boot CLI.

Below, we’ll abstract part of this process using the spring-boot-starter-security dependency, which leverages the @EnableWebSecurity annotation under the hood:

package vietmx.security

@Grab("spring-boot-starter-security")

@RestController
class SampleController {

    @RequestMapping("/")
    public def example() {
        [message: "Hello World!"]
    }
}

For more details on how to protect resources and handle security, please check out the official documentation.

4.4. @Test

To set up a simple JUnit test, we can add the @Grab(‘junit’) or @Test annotations:

package vietmx.test

@Grab('junit')
class Test {
    //...
}

This will allow us to execute JUnit tests easily.

4.5. DataSource and JdbcTemplate

Persistent data options can be specified including DataSource or JdbcTemplate without explicitly using the @Grab annotation:

package vietmx.data

@Grab('h2')
@Configuration
@EnableWebMvc
@ComponentScan('vietmx.data')
class DataConfig {

    @Bean
    DataSource dataSource() {
        return new EmbeddedDatabaseBuilder()
          .setType(EmbeddedDatabaseType.H2).build();
    }

}

By simply using familiar Spring bean configuration conventions, we’ve grabbed the H2 embedded database and set it as the DataSource.

5. Custom Configuration

There are two primary ways to configure a Spring Boot micro-service using Spring Boot CLI:

  1. we can add argument parameters to our terminal commands
  2. we can use a customized YAML file to provide an application configuration

Spring Boot will automatically search the /config directory for application.yml or application.properties

├── app
    ├── app.groovy
    ├── config
        ├── application.yml
    ...

We can also set up:

├── app
    ├── example.groovy
    ├── example.yml
    ...

A full list of application properties can be found here at Spring.

6. Conclusion

This concludes our quick walk-through of Spring Boot CLI! For more details, check out the official docs.

And as usual, the source code for this article can be found over on GitHub.

Related posts:

Java Program to Implement ScapeGoat Tree
Show Hibernate/JPA SQL Statements from Spring Boot
Map to String Conversion in Java
Serve Static Resources with Spring
SOAP Web service: Upload và Download file sử dụng MTOM trong JAX-WS
Java Program to Find the Shortest Path Between Two Vertices Using Dijkstra’s Algorithm
Hướng dẫn sử dụng Lớp FilePermission trong java
The Thread.join() Method in Java
Java Program to Implement Circular Singly Linked List
Guide to the Synchronized Keyword in Java
Using the Map.Entry Java Class
What is Thread-Safety and How to Achieve it?
How to use the Spring FactoryBean?
Interface trong Java 8 – Default method và Static method
Guide to PriorityBlockingQueue in Java
Introduction to Netflix Archaius with Spring Cloud
Java Program to Check if a Given Binary Tree is an AVL Tree or Not
Map Serialization and Deserialization with Jackson
Java Program to find the peak element of an array using Binary Search approach
Java Program to Generate Random Hexadecimal Byte
Java Program to Perform Postorder Recursive Traversal of a Given Binary Tree
Hướng dẫn Java Design Pattern – Service Locator
Immutable Map Implementations in Java
Java Program to Remove the Edges in a Given Cyclic Graph such that its Linear Extension can be Found
Intro to the Jackson ObjectMapper
Send an email using the SMTP protocol
Guide to java.util.concurrent.BlockingQueue
Spring Boot - Code Structure
Tìm hiểu cơ chế Lazy Evaluation của Stream trong Java 8
Java Program to Check if a Matrix is Invertible
Optional trong Java 8
Migrating from JUnit 4 to JUnit 5