mirror of
https://github.com/Unleash/unleash.git
synced 2025-01-01 00:08:27 +01:00
acb663df7a
<!-- Thanks for creating a PR! To make it easier for reviewers and everyone else to understand what your changes relate to, please add some relevant content to the headings below. Feel free to ignore or delete sections that you don't think are relevant. Thank you! ❤️ --> ## About the changes <!-- Describe the changes introduced. What are they and why are they being introduced? Feel free to also add screenshots or steps to view the changes if they're visual. --> <!-- Does it close an issue? Multiple? --> Closes # <!-- (For internal contributors): Does it relate to an issue on public roadmap? --> <!-- Relates to [roadmap](https://github.com/orgs/Unleash/projects/10) item: # --> ### Important files <!-- PRs can contain a lot of changes, but not all changes are equally important. Where should a reviewer start looking to get an overview of the changes? Are any files particularly important? --> ## Discussion points <!-- Anything about the PR you'd like to discuss before it gets merged? Got any questions or doubts? --> Adding our YouTube link: https://www.youtube.com/watch?v=Hq1g9QyPw14 <img width="731" alt="Screenshot 2024-05-15 at 7 46 12 AM" src="https://github.com/Unleash/unleash/assets/22972707/32c0e9e5-931d-40ad-9f23-a110d2ae3fb8">
253 lines
13 KiB
Markdown
253 lines
13 KiB
Markdown
---
|
||
title: How to Implement Feature Flags in Java
|
||
slug: /feature-flag-tutorials/java
|
||
---
|
||
|
||
import VideoContent from '@site/src/components/VideoContent.jsx';
|
||
|
||
[Java](https://www.java.com/en/) is an object-oriented programming language often used for mobile development and large-scale enterprise applications. [Spring Boot](https://spring.io/projects/spring-boot) is a popular Java framework used to get apps up and running with minimal configuration.
|
||
|
||
Leveraging feature flags allows developers to toggle new features on and off, whether you’re experimenting in your local environment, testing for QA purposes, or rolling out changes to users in production. With Unleash, an open-source feature flag service, you can use our tooling to implement feature flags into your application and release new features faster, strategically, and safely. But how can you do this in Java?
|
||
|
||
In this tutorial, you will learn how to set up and use Java feature flags with Unleash. We will use the [SpringBoot Example app](https://github.com/jecklgamis/spring-boot-java-example) to log the status of a feature flag while your app is running.
|
||
|
||
Here are the steps we will cover in this tutorial:
|
||
|
||
1. [Feature flag best practices for back-end applications](#1-feature-flag-best-practices-for-backend-apps)
|
||
2. [Spin up a local flag provider](#2-install-a-local-feature-flag-provider)
|
||
3. [Configure a feature flag](#3-create-and-configure-the-feature-flag)
|
||
4. [Add Unleash to a Java app](#4-add-unleash-to-a-java-app)
|
||
5. [Log a feature flag status in your Java app](#5-log-feature-flag-status-in-java-app)
|
||
6. [Verify the toggle experience](#6-verify-the-toggle-experience)
|
||
|
||
Watch the video tutorial and follow along with the code from this documentation.
|
||
|
||
<VideoContent videoUrls={["https://www.youtube.com/embed/Hq1g9QyPw14?si=azduTa_lQsDBmOdm"]}/>
|
||
|
||
## Prerequisites
|
||
|
||
In this tutorial, you will need the following:
|
||
|
||
- A web browser like Chrome or Firefox
|
||
- Git
|
||
- Docker
|
||
- (Optional) a code editor like IntelliJ IDEA
|
||
|
||
![An architectural diagram shows how the Java SDK, application and unleash server control feature experiences.](/img/java-tutorial-architecture-diagram.png)
|
||
|
||
This architecture diagram breaks down how the Java app works with Unleash to control feature flags. We connect the Unleash service to your Java app using the Java SDK.
|
||
|
||
The Unleash Server acts as a Feature Flag Control Service, managing and storing your feature flags. It enables the retrieval of flag data and, particularly when not utilizing a user interface, supports the sending of data to and from the service. The Unleash Server has a UI for creating and managing projects and feature flags. There are also [API commands available](https://docs.getunleash.io/reference/api/unleash) to perform the same actions straight from your CLI or server-side app.
|
||
|
||
## 1. Feature Flag best practices for backend apps
|
||
|
||
Since Java is a backend language, there are special security considerations to plan around when implementing feature flags.
|
||
|
||
Most importantly, you must:
|
||
|
||
- Limit feature flag payloads for scalability, security, and efficiency
|
||
- Improve architectural resiliency with graceful degradation
|
||
|
||
As your application scales, performance and resiliency become more critical and costly if not addressed. A feature flagging system should not be the reason your app slows down or fails. That’s why we recommend you account for this by reducing the size of your feature flag payloads. For example, instead of making one large call to retrieve flag statuses for all users as part of your configuration, group your users by specific attributes as part of your targeting rules that would be most relevant to your application.
|
||
|
||
Additionally, you can cache your feature flag configuration to help reduce network round trips and dependency on external services. You can rely on the cache if your Feature Flag Control Service is not available, which will mitigate potential failure in your application.
|
||
|
||
For a complete list of architectural guidelines, see our [best practices for building and scaling feature flag systems](https://docs.getunleash.io/topics/feature-flags/feature-flag-best-practices).
|
||
|
||
## 2. Install a local feature flag provider
|
||
|
||
This section guides you through installing Unleash, setting up a local instance, logging in, and creating a feature flag. However, if you prefer, you can substitute Unleash with a different feature flag tool of your choice. Should you choose an alternative, you will need to modify the code to accommodate the new tool, but the fundamental steps are likely to remain similar.
|
||
|
||
Use Git to clone the Unleash repository and Docker to build and run it. Open a terminal window and run the following commands:
|
||
|
||
```
|
||
git clone git@github.com:Unleash/unleash.git
|
||
cd unleash
|
||
docker compose up -d
|
||
```
|
||
|
||
You will now have Unleash installed onto your machine and running in the background. You can access this instance in your web browser at http://localhost:4242
|
||
|
||
Log in to the platform using these credentials:
|
||
|
||
```
|
||
Username: admin
|
||
Password: unleash4all
|
||
```
|
||
|
||
Click the ‘New feature toggle’ button to create a new feature flag. Once you have created a flag, you will see it here.
|
||
|
||
![This is an image of the Unleash platform to create a new Java feature flag.](/img/tutorial-create-flag.png)
|
||
|
||
## 3. Create and configure the feature flag
|
||
|
||
Next, you will create a feature flag and turn it on for your Java app.
|
||
|
||
For the purpose of this tutorial, name the feature flag `endpointFlag`. Use the default values in the rest of the feature flag form.
|
||
|
||
![You can view the Java feature flag form in Unleash.](/img/java-tutorial-flag-form.png)
|
||
|
||
Your new feature flag has been created and is ready to be used. Enable the flag for your development environment, which makes it accessible for use in the Java app we will clone into your local environment.
|
||
|
||
![Enable your new flag in the development environment in your flag view.](/img/java-tutorial-enable-flag.png)
|
||
|
||
Next, generate an API token to authenticate calls made to Unleash servers from your project. This API token will eventually be pulled into a configuration object within your Java application to toggle features. We require an API token as part of your flag configuration to ensure that only applications with the correct authentication can access your feature flags in Unleash. API tokens are created by users with API management access and this controls how they can be distributed to applications that need it, and by whom.
|
||
|
||
From your project view on the platform, go to Project Settings and then API Access.
|
||
|
||
Select the ‘New API token’ button.
|
||
|
||
![Create a new API token in the API Access view for your Java application.](/img/tutorial-create-api-token.png)
|
||
|
||
Name the API token and select the “Server-side SDK” token type, since we’ll be doing our flag evaluation on the server using the Java SDK. You can read more about Unleash API tokens here: https://docs.getunleash.io/reference/api-tokens-and-client-keys#client-tokens
|
||
|
||
The token should have access to the “development” environment, as shown in the platform screenshot below.
|
||
|
||
![Name your API token and make sure it is a server-side SDK token.](/img/java-tutorial-api-token-form.png)
|
||
|
||
The API token you generated can be managed in the API Access view in your project settings. It will be handy in Step 4.
|
||
|
||
## 4. Add Unleash to a Java app
|
||
|
||
In this section, you will clone an open-source Java application called [Spring Boot Java Example](https://github.com/jecklgamis/spring-boot-java-example), which we will use to expose a metrics endpoint from its server. It uses a Jetty web container, starts HTTP and HTTPs listeners, and exposes actuator endpoints that display metrics and health statuses in the browser.
|
||
|
||
Use this command to clone the repository via your Terminal:
|
||
|
||
```
|
||
git clone git@github.com:jecklgamis/spring-boot-java-example.git
|
||
```
|
||
|
||
Next, navigate to your repository directory and check that Java 21 or later is installed. We are using [Apache Maven](https://maven.apache.org/) commands to convert your Java source code into .jar files to execute. You won’t need to have Maven installed in order to run the executable command below:
|
||
|
||
```
|
||
./mvnw clean package
|
||
```
|
||
|
||
Next, you will add the Unleash Java SDK to your dependencies so that your app can initialize the Unleash Client and use the feature flag we created.
|
||
|
||
In the file `pom.xml` on line 82, add the following code:
|
||
|
||
```xml
|
||
<dependency>
|
||
<groupId>io.getunleash</groupId>
|
||
<artifactId>unleash-client-java</artifactId>
|
||
<version>9.2.0</version>
|
||
</dependency>
|
||
```
|
||
|
||
Next, in `ExampleApp.java`, import the Unleash Java SDK with this code snippet:
|
||
|
||
```java
|
||
import io.getunleash.DefaultUnleash;
|
||
import io.getunleash.Unleash;
|
||
import io.getunleash.util.UnleashConfig;
|
||
```
|
||
|
||
In the main function of that file on line 21, set up the Unleash Client configuration that will initialize when the app runs. In this tutorial, we are using synchronized initialization.
|
||
|
||
```java
|
||
UnleashConfig config = UnleashConfig.builder()
|
||
.appName("spring-boot-java-example")
|
||
.instanceId("spring-boot-java-example")
|
||
.unleashAPI("http://localhost:4242/api")
|
||
.apiKey("<API_KEY>")
|
||
.synchronousFetchOnInitialisation(true)
|
||
.build();
|
||
|
||
Unleash unleash = new DefaultUnleash(config);
|
||
```
|
||
|
||
Read more on our [configuration examples in our Java SDK documentation](https://docs.getunleash.io/reference/sdks/java#example-configurations).
|
||
|
||
The `unleashAPI` will point your app to your local Unleash instance.
|
||
|
||
Replace the `<API_KEY>` string in the configuration’s apiKey with the API token we created on our Unleash instance. This will allow your app to communicate with the Unleash API to use the feature flag we created.
|
||
|
||
While the app is running, it will log the enabled status of the endpoint flag we created in our Unleash instance.
|
||
|
||
You can check our [API token and client keys documentation](https://docs.getunleash.io/reference/api-tokens-and-client-keys) for more specifics and see additional use cases in our [Server-Side SDK with Java](https://docs.getunleash.io/reference/sdks/java) documentation.
|
||
|
||
To run the app, use the following command:
|
||
|
||
```
|
||
java -jar target/spring-boot-java-example.jar
|
||
```
|
||
|
||
Alternatively, to run in your Docker container, run this command:
|
||
|
||
```
|
||
make dist image run
|
||
```
|
||
|
||
You can verify that your Java app is running by navigating to the health status endpoint in the browser:
|
||
|
||
http://localhost:8080/actuator/health
|
||
|
||
You’ll see JSON data in the browser:
|
||
|
||
```json
|
||
{
|
||
"status": "UP",
|
||
"components": {
|
||
"diskSpace": {
|
||
"status": "UP",
|
||
"details": {
|
||
"total": 62671097856,
|
||
"free": 51487629312,
|
||
"threshold": 10485760,
|
||
"path": "/app/.",
|
||
"exists": true
|
||
}
|
||
},
|
||
"ping": { "status": "UP" }
|
||
}
|
||
}
|
||
```
|
||
|
||
## 5. Log feature flag status in Java app
|
||
|
||
In the real world, you can incrementally introduce new features to a select group of users by adjusting the flag's deployment strategy.
|
||
|
||
In the context of our Java tutorial, we will log the status of the feature flag in the Terminal to confirm whether or not it is enabled for use.
|
||
|
||
In the main function in `ExampleApp.java`, add new conditional logic on line 33.
|
||
|
||
```java
|
||
while (true) {
|
||
Thread.sleep(2000);
|
||
if (unleash.isEnabled("endpointFlag")) {
|
||
System.out.println("STATUS: Endpoint flag is enabled...");
|
||
}
|
||
else {
|
||
System.out.println("STATUS: Endpoint flag is disabled...");
|
||
}
|
||
}
|
||
```
|
||
|
||
> :triangular_flag_on_post: **Note:** You might receive an `InterruptedException` for use of `Thread.sleep(2000)`. To mitigate this, modify your `main` function line to catch exceptions like this:
|
||
> `public static void main(String args[]) throws InterruptedException {`
|
||
|
||
Your terminal will continuously update to show the status of the feature flag, reflecting the real-time responses from Unleash as the application operates.
|
||
|
||
## 6. Verify the toggle experience
|
||
|
||
In order to verify that your flag is enabled and your Java application is reading the status of your flag, view what is logged in your Terminal output.
|
||
|
||
With the flag on, you should see the corresponding status in this screenshot:
|
||
|
||
![You can view the status of your flag in the Terminal from our log statements, which should read "STATUS: endpoint flag is enabled".](/img/java-tutorial-status-log.png)
|
||
|
||
We will use Unleash to turn off the flag and view an updated status in the Terminal.
|
||
|
||
In Unleash, toggle off the `endpointFlag` in the development environment.
|
||
|
||
![Turn off the flag in the development environment.](/img/java-tutorial-disable-flag.png)
|
||
|
||
After a few seconds, your app will update to reflect the latest flag status, which will look like this output change in your Terminal:
|
||
|
||
![The status of the feature flag will now change from "enabled" to "disabled" in your Terminal.](/img/java-tutorial-status-log-change.png)
|
||
|
||
## Conclusion
|
||
|
||
In this tutorial, we installed Unleash locally, created a new feature flag, installed Unleash into a Java app, and logged the feature flag status from Unleash to our Terminal.
|