Microsoft Azure + Spring Cloud Sample application from the scratch

 

Objectives

In this post, we will:

  • Set up an Azure Spring Cloud cluster
  • Configure a Spring Cloud Config Server
  • Use a Spring Cloud Discovery Server
  • Configure service binding
  • Create and deploy a Spring Boot microservice
  • Create and deploy a Spring Cloud Gateway

Prerequisites


Check version of Azure CLI, use Git bash to execute
az --version
az login # Sign into an azure account az account show # See the currently signed-in account.
az account set --subscription <SUBSCRIPTION_ID>
az extension add -n spring-cloud -y #If you haven't added this extension yet add it.

Congratulations, the Azure CLI is now ready to create your first cluster!

Create an Azure Spring Cloud instance

RESOURCE_GROUP_NAME=spring-cloud-sample-rsgrp SPRING_CLOUD_NAME=azure-spring-cloud-unique9563

az group create \ -g "$RESOURCE_GROUP_NAME" \ -l eastus

az spring-cloud create \ -g "$RESOURCE_GROUP_NAME" \ -n "$SPRING_CLOUD_NAME" \ --sku standard \ --enable-java-agent

prepare and set your variables in Azure CLI for next steps.
az configure --defaults group=${RESOURCE_GROUP_NAME} az configure --defaults spring-cloud=${SPRING_CLOUD_NAME}


Configure a Spring Cloud Config Server

On your GitHub account, create a new private repository where the Spring Boot configurations will be stored. In the new private GitHub repository, add a new application.yml file, which will store configuration data for all our microservices. Typically, each Spring Boot application includes such a file within the application binaries to contain application settings. A Spring Cloud Configuration Server allows such settings to be stored outside your application, which provides the following benefits: It allows storing sensitive parameters (like your database password) outside of your application. Your configuration is stored in a Git repository, so its data can be tagged or rolled back. It uses a specific Git repository, which can be secured separately. It provides a centralized place to store all your configuration data, for all your microservices. For the moment, our application.yml will just store a message to check if the configuration is successful:

application: message: Configured by Azure Spring Cloud

git add application.yml git commit -m 'Add new Spring Boot configuration file' git push

Create a github personal Token:



Configure Azure Spring Cloud to access the Git repo:
1. Go to the overview page of your Azure Spring Cloud server and select "Config server" in the menu
2. Configure the repository we previously created:
  1. Add the repository URL, for example https://github.com/<YOUR_USERNAME>/azure-spring-cloud-config or git@github.com:<YOUR_USERNAME>/azure-spring-cloud-config.git.
  2. Add your branch in Label. It defaults to main on GitHub, but older repositories or alternate Git providers might still use master.
  3. Click on Authentication and select HTTP Basic.
  4. The username is your GitHub login name.
  5. The password is the personal token we created in the previous section.
3. Click on Apply and wait for the operation to succeed.
4. Click on Validate and wait for the operation to succeed.

Build a Spring Boot microservice


Create a specific todo-service application in your Azure Spring Cloud instance:
az spring-cloud app create --name todo-service --resource-group "$RESOURCE_GROUP_NAME" --service "$SPRING_CLOUD_NAME"

Now create an Azure database for MySQL:
az mysql server create \ --name ${SPRING_CLOUD_NAME}-mysql \ --resource-group "$RESOURCE_GROUP_NAME" \ --sku-name B_Gen5_1 \ --storage-size 5120 \ --admin-user "spring"

This operation can take a few minutes, and will output a JSON document: copy the password attribute in that document, as we will use it later.

Now create a todos database in that server, and open up its firewall so that Azure Spring Cloud can access it:

az mysql db create \ --name "todos" \ --server-name ${SPRING_CLOUD_NAME}-mysql

Bind mySql database to the application now:

Azure Spring Cloud can automatically bind the MySQL database we created to our microservice.

  1. Go to Apps in your Azure Spring Cloud instance.
  2. Select the todo-service application.
  3. Go to Service bindings.
  4. Click on Create service binding.
    1. Give your binding a name, for example mysql-todos.
    2. In the Binding type list, select Azure database for MySQL.
    3. The Resource name should be the one of the MySQL database you created earlier.
    4. The Database name should be todos
    5. The User name should be spring@YOUR_DATABASE_NAME, with YOUR_DATABASE_NAME being the name of your database, that we set up earlier as ${SPRING_CLOUD_NAME}-mysql when creating it.
    6. The Password is the password attribute that we copied earlier, when creating the server.

Select Create, and your Spring Boot application will have the MySQL database connection set up.

Create a Spring Boot microservice

curl https://start.spring.io/starter.tgz -d dependencies=web,mysql,data-jpa,cloud-eureka,cloud-config-client -d baseDir=todo-service -d bootVersion=2.3.6.RELEASE -d javaVersion=1.8 | tar -xzvf -



Go to the project folder and create below classes in the same package structure.

package com.example.demo; import javax.persistence.Entity; import javax.persistence.GeneratedValue; import javax.persistence.Id; @Entity public class Todo { public Todo() { } public Todo(String description, boolean done) { this.description = description; this.done = done; } @Id @GeneratedValue private Long id; private String description; private boolean done; public Long getId() { return id; } public void setId(Long id) { this.id = id; } public String getDescription() { return description; } public void setDescription(String description) { this.description = description; } public boolean isDone() { return done; } public void setDone(boolean done) { this.done = done; } }


package com.example.demo; import org.springframework.data.jpa.repository.JpaRepository; public interface TodoRepository extends JpaRepository<Todo, Long> { }


package com.example.demo; import org.springframework.web.bind.annotation.*; import javax.annotation.PostConstruct; import java.util.Arrays; @RestController public class TodoController { private final TodoRepository todoRepository; public TodoController(TodoRepository todoRepository) { this.todoRepository = todoRepository; } @PostConstruct public void init() { todoRepository.saveAll(Arrays.asList( new Todo("First item", true), new Todo("Second item", true), new Todo("Third item", false))); } @GetMapping("/") public Iterable<Todo> getTodos() { return todoRepository.findAll(); } }


In order to automatically generate the database tables when the application is deployed, add this line to your src/main/resources/application.properties configuration file:

spring.jpa.hibernate.ddl-auto=create-drop

You can now build your "todo-service" project and send it to Azure Spring Cloud:

cd todo-service ./mvnw clean package -DskipTests az spring-cloud app deploy --name todo-service --service "$SPRING_CLOUD_NAME" --resource-group "$RESOURCE_GROUP_NAME" --jar-path target/demo-0.0.1-SNAPSHOT.jar cd ..

To check the logs in spring cloud

az spring-cloud app logs --name todo-service --service "$SPRING_CLOUD_NAME" --resource-group "$RESOURCE_GROUP_NAME" -f

Now that the application is deployed, it's time to test it!

  1. In the Azure portal, go to Apps in your Azure Spring Cloud instance.
    1. Verify todo-service has a Registered Instance that says 0/1. This shows that it is correctly registered in the Spring Cloud Service Registry.
    2. Select todo-service to have more information on the microservice.
  2. Copy/paste the "Test Endpoint" that is provided.

You can now use cURL to test the endpoint. Your test command should look like:

curl https://primary:XXXXXXXXXXXXXXXXXXXXXXXXXXXXX@azure-spring-cloud-workshop.test.azuremicroservices.io/todo-service/default/


Build a Spring Cloud Gateway

Gateways are used to route public HTTP traffic to microservices:

  • They handle the routing logic.
  • They secure the access to the microservices (which will not be publicly available).
  • They can also have Quality of Service (QoS) capabilities, like doing HTTP rate limiting.
To create spring cloud gateway:
curl https://start.spring.io/starter.tgz -d dependencies=cloud-gateway,cloud-eureka,cloud-config-client -d baseDir=todo-gateway -d bootVersion=2.3.6.RELEASE -d javaVersion=1.8 | tar -xzvf -


Go to the project directory and copy followings to application.properties file:

spring.main.allow-bean-definition-overriding=true spring.cloud.gateway.discovery.locator.enabled=true

  • The spring.main.allow-bean-definition-overriding=true part is to configure Spring Cloud Gateway to use the Spring Cloud Discovery Server bean configured in the Azure Spring Cloud Client library.
  • The spring.cloud.gateway.discovery.locator.enabled=true part is to configure Spring Cloud Gateway to use the Spring Cloud Service Registry to discover the available microservices.
create a specific todo-gateway application in your Azure Spring Cloud instance. As this application is a gateway, we add the --assign-endpoint flag so it is exposed publicly.

az spring-cloud app create --name todo-gateway --service "$SPRING_CLOUD_NAME" --resource-group "$RESOURCE_GROUP_NAME" --assign-endpoint

You can now build your "todo-gateway" project and send it to Azure Spring Cloud:

cd todo-gateway
./mvnw clean package -DskipTests
az spring-cloud app deploy --name todo-gateway --service "$SPRING_CLOUD_NAME" --resource-group "$RESOURCE_GROUP_NAME" --jar-path target/demo-0.0.1-SNAPSHOT.jar
cd ..

Test the project in the cloud

  1. Go to Apps in your Azure Spring Cloud instance.
    1. Verify todo-gateway has a Registration status that says 1/1. This shows that it is correctly registered in the Spring Cloud Service Registry.
    2. Select todo-gateway to have more information on the microservice.
  2. Copy/paste the public URL that is provided (there is a "Test Endpoint" like for microservices, but the gateway is directly exposed on the Internet, so let's use the public URL). Keep this URL handy for subsequent sections.

As the gateway is connected to the Spring Cloud Service Registry, it should have automatically opened routes to the available microservices, with URL paths in the form of /MICROSERVICE-ID/**: [The MICROSERVICE-ID must be in capital letters]

Test the todo-service microservice endpoint by doing: curl https://XXXXXXXX-todo-gateway.azuremicroservices.io/TODO-SERVICE/ (replacing XXXXXXXX with the name of your Azure Spring Cloud instance)


Distributed tracing

We now have a complete microservices stack:

  • A Spring Boot microservice, that stores its data in MySQL.
  • A todo-gateway based on Spring Cloud Gateway.

However, even with only those two components, it already is quite challenging to monitor and study performance issues in our architecture.

To solve that issue, we're going to use Application Performance Monitoring (APM):

  1. Go to the Azure portal.
  2. Go to the overview page of your Azure Spring Cloud cluster and select Application Insights in the menu.
  3. This setting should already be on Enable.
  4. You'll have access to an application map, storing your tracing data.

Scale Spring Boot microservices


Spring Boot microservices and gateways running inside Azure Spring Cloud can be scaled vertically or horizontally:

  • Vertical scaling means you increase (or decrease) the CPU and RAM of a given service.
  • Horizontal scaling means you can add (or remove) nodes for a given service.

Scaling the "todo-service" microservice

  1. Go to the Azure portal.
  2. Go to the overview page of your Azure Spring Cloud cluster and select Apps in the menu.
  3. Select the todo-service application.
  4. Select Scale up in the left hand-side menu. You can now scale your service vertically, for example you can give it 2 CPUs and 4 Gb of RAM.
  5. Select Scale out in the left hand-side menu. You can also scale your service horizontally. For example, you can select your service and use Manual scale to have 2 instances of your service.








Comments

Popular posts from this blog

Let's try to build scrum masters/project managers/software architects/even a company with training AI models

TCP Ports list

Problem Solving: Allotment calculator