Это третья часть серии статей по основам микросервисных архитектур, в которой вы узнаете, как создать микросервис конвертации валют. В этой серии статей вы познакомитесь с концепцией микросервисов и узнаете, как создавать микросервисы с помощью Spring Boot и Spring Cloud. Это руководство поможет вам изучить основы микросервисной архитектуры.
Мы также начнем рассматривать базовую реализацию микросервиса с помощью Spring Boot. Мы создадим пару микросервисов и заставим их взаимодействовать друг с другом, используя Eureka Naming Server и Ribbon для балансировки нагрузки на стороне клиента.
Эта статья входит в серию «Микросервисы с Spring Boot»:
- Часть 1. Начало работы с архитектурой микросервисов
- Часть 2. Создание микросервиса Форекс
- Часть 3. Создание микросервиса конвертации валют
- Часть 4. Использование ленты для балансировки нагрузки
- Часть 5. Использование сервера имен Eureka
Вы будете учиться
- Как создать микросервис с помощью Spring Boot.
- Как использовать RestTemplate для создания службы REST.
- Как использовать Feign для создания службы REST.
- Преимущества Feign перед RestTemplate.
Просмотр ресурсов
Служба конвертации валют (CCS) может конвертировать многие валюты в другие валюты.Он использует службу Форекс для получения текущих значений обмена валюты.
CCS является потребителем услуг.
Пример запроса и ответа показан ниже:
GET to http://localhost:8100/currency-converter/from/EUR/to/INR/quantity/10000
{
id: 10002,
from: "EUR",
to: "INR",
conversionMultiple: 75,
quantity: 10000,
totalCalculatedAmount: 750000,
port: 8000,
}
Запрос выше позволяет определить стоимость 10 000 евро в индийских рупиях.
Общая расчетная сумма составляет 750 000 индийских рупий.
На диаграмме ниже показана взаимосвязь между CCS и FS.
Структура кода проекта
На следующем снимке экрана показана структура проекта, который мы создадим.
Некоторые элементы проекта:
- SpringBootMicroserviceCurrencyConversionApplication.java — это класс приложения Spring Boot, созданный с использованием Spring Initializer. Этот класс действует как точка запуска приложения.
- pom.xml - содержит все зависимости, необходимые для сборки этого проекта.
Мы будем использовать Spring Boot Starter Web.
- CurrencyConversionBean.java — Компонент для хранения ответа, который мы хотим отправить.
- CurrencyExchangeServiceProxy.java — это будет Feign Proxy для вызова сервиса Форекс.
- CurrencyConversionController.java — Контроллер Spring REST, предоставляющий услугу конвертации валют. Он будет использовать CurrencyExchangeServiceProxy для вызова службы Forex.
Инструменты, которые вам понадобятся
- Maven 3.0+ — инструмент сборки
- Ваша любимая IDE. Мы используем Эклипс.
- JDK 1.8+
Готовый Maven-проект с примерами кода.
В Репозитории Github есть все примеры кода.
Создание проекта с использованием Spring Initializr
Создание микросервиса с помощью Spring Initializr — легкая прогулка.Spring Initializr — отличный инструмент для быстрого создания проектов Spring Boot. Используя Весенняя инициализация вы можете создавать самые разнообразные проекты.
Для создания проекта разработки веб-сервисов необходимо предпринять следующие шаги:
1. Запустите Spring Initializr и введите следующее:
- Набирать номер com.in28минуты.
springboot.microservice.example.currencyconversion как группа.
- Введите как артефакт весна-загрузка-микросервис-конвертация валюты .
- Выберите следующие зависимости: Интернет , Инструменты разработчика , Притворяться
3. Импортируйте проект в Eclipse: Файл -> Импорт -> Существующий проект Maven. Не забудь указывать Притворяться в зависимости.
Создание CurrencyConversionBean
Это простой компонент для создания ответа.
public class CurrencyConversionBean {
private Long id;
private String from;
private String to;
private BigDecimal conversionMultiple;
private BigDecimal quantity;
private BigDecimal totalCalculatedAmount;
private int port;
public CurrencyConversionBean() {
}
public CurrencyConversionBean(Long id, String from, String to, BigDecimal conversionMultiple, BigDecimal quantity,
BigDecimal totalCalculatedAmount, int port) {
super();
this.id = id;
this.from = from;
this.to = to;
this.conversionMultiple = conversionMultiple;
this.quantity = quantity;
this.totalCalculatedAmount = totalCalculatedAmount;
this.port = port;
}
Реализация клиента REST с помощью RestTemplate
Код ниже демонстрирует реализацию клиента REST для вызова службы Forex и обработки ответа.Как видите, для выполнения простого вызова службы необходимо написать много кода.
@RestController
public class CurrencyConversionController {
private Logger logger = LoggerFactory.getLogger(this.getClass());
@GetMapping("/currency-converter/from/{from}/to/{to}/quantity/{quantity}")
public CurrencyConversionBean convertCurrency(@PathVariable String from, @PathVariable String to,
@PathVariable BigDecimal quantity) {
Map<String, String> uriVariables = new HashMap<>();
uriVariables.put("from", from);
uriVariables.put("to", to);
ResponseEntity<CurrencyConversionBean> responseEntity = new RestTemplate().
getForEntity(
" http://localhost:8000/currency-exchange/from/{from}/to/{to }", CurrencyConversionBean.class,
uriVariables);
CurrencyConversionBean response = responseEntity.getBody();
return new CurrencyConversionBean(response.getId(), from, to, response.getConversionMultiple(), quantity,
quantity.multiply(response.getConversionMultiple()), response.getPort());
}
Установка имени приложения и порта
/spring-boot-microservice-currency-conversion-service/src/main/resources/application.properties spring.application.name=currency-conversion-service
server.port=8100
Тестирование микросервисов
Запустите приложение Spring Boot, запустив SpringBootMicroserviceCurrencyConversionApplication.java. GET to http://localhost:8100/currency-converter/from/EUR/to/INR/quantity/10000
{
id: 10002,
from: "EUR",
to: "INR",
conversionMultiple: 75,
quantity: 10000,
totalCalculatedAmount: 750000,
port: 8000,
}
Создание прокси-сервера Feign
Feign предоставляет лучшую альтернативу RestTemplate для вызова REST API. /spring-boot-microservice-currency-conversion-service/src/main/java/com/in28mines/springboot/microservice/example/currencyconversion/CurrencyExchangeServiceProxy.java package com.in28minutes.springboot.microservice.example.currencyconversion;
import org.springframework.cloud.netflix.feign.FeignClient;
import org.springframework.cloud.netflix.ribbon.RibbonClient;
import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.PathVariable;
@FeignClient(name="forex-service" url="localhost:8000")
public interface CurrencyExchangeServiceProxy {
@GetMapping("/currency-exchange/from/{from}/to/{to}")
public CurrencyConversionBean retrieveExchangeValue
(@PathVariable("from") String from, @PathVariable("to") String to);
}
Сначала мы определим простой прокси:
- @FeignClient(name="forex-service" url="localhost:8100") — заявляет, что это Feign-клиент, а URL-адрес, по которому расположен форекс-сервис, — localhost:8100
- @GetMapping("/currency-exchange/from/{from}/to/{to}") - URI сервиса, который мы хотели бы использовать.
Использование прокси-сервера Feign в контроллере микросервиса
Совершить звонок через прокси очень просто.Вы увидите это в действии в приведенном ниже коде.
Все, что нам нужно было сделать, это автоматически подключить прокси и использовать его для вызова метода.
@Autowired
private CurrencyExchangeServiceProxy proxy;
@GetMapping("/currency-converter-feign/from/{from}/to/{to}/quantity/{quantity}")
public CurrencyConversionBean convertCurrencyFeign(@PathVariable String from, @PathVariable String to,
@PathVariable BigDecimal quantity) {
CurrencyConversionBean response = proxy.retrieveExchangeValue(from, to);
logger.info("{}", response);
return new CurrencyConversionBean(response.getId(), from, to, response.getConversionMultiple(), quantity,
quantity.multiply(response.getConversionMultiple()), response.getPort());
}
Включение имитации клиентов
Прежде чем мы сможем использовать Feign, нам нужно включить его с помощью аннотации @EnableFeignClients в соответствующем пакете, где определены клиентские прокси.
@SpringBootApplication
@EnableFeignClients("com.in28minutes.springboot.microservice.example.currencyconversion")
@EnableDiscoveryClient
public class SpringBootMicroserviceCurrencyConversionApplication {
public static void main(String[] args) {
SpringApplication.run(SpringBootMicroserviceCurrencyConversionApplication.class, args);
}
}
Тестирование микросервиса с помощью Feign
GET to http://localhost:8100/currency-converter-feign/from/EUR/to/INR/quantity/10000
{
id: 10002,
from: "EUR",
to: "INR",
conversionMultiple: 75,
quantity: 10000,
totalCalculatedAmount: 750000,
port: 8000,
}
Краткое содержание
Мы создали два микросервиса и установили между ними соединение.
Однако мы жестко запрограммировали URL-адрес FS в CCS. Это значит, что при запуске новых экземпляров ФС у нас нет возможности распределить нагрузку между ними.
В следующей части мы включим балансировку нагрузки на стороне клиента с помощью Ribbon. Полный пример кода
/spring-boot-microservice-currency-conversion-service/pom.xml
<Эxml version="1.0" encoding="UTF-8"?>
<project xmlns=" http://maven.apache.org/POM/4.0.0 " xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance "
xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd ">
<modelVersion>4.0.0</modelVersion>
<groupId>com.in28minutes.springboot.microservice.example.currency-conversion</groupId>
<artifactId>spring-boot-microservice-currency-conversion</artifactId>
<version>0.0.1-SNAPSHOT</version>
<packaging>jar</packaging>
<name>spring-boot-microservice-currency-conversion</name>
<description>Microservices with Spring Boot and Spring Cloud - Currency Conversion Service</description>
<parent>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-parent</artifactId>
<version>2.0.0.M3</version>
<relativePath /> <!-- lookup parent from repository -->
</parent>
<properties>
<project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
<project.reporting.outputEncoding>UTF-8</project.reporting.outputEncoding>
<java.version>1.8</java.version>
<spring-cloud.version>Finchley.M2</spring-cloud.version>
</properties>
<dependencies>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-web</artifactId>
</dependency>
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-starter-feign</artifactId>
</dependency>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-devtools</artifactId>
<scope>runtime</scope>
</dependency>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-test</artifactId>
<scope>test</scope>
</dependency>
</dependencies>
<dependencyManagement>
<dependencies>
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-dependencies</artifactId>
<version>${spring-cloud.version}</version>
<type>pom</type>
<scope>import</scope>
</dependency>
</dependencies>
</dependencyManagement>
<build>
<plugins>
<plugin>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-maven-plugin</artifactId>
</plugin>
</plugins>
</build>
<repositories>
<repository>
<id>spring-snapshots</id>
<name>Spring Snapshots</name>
<url> https://repo.spring.io/snapshot </url>
<snapshots>
<enabled>true</enabled>
</snapshots>
</repository>
<repository>
<id>spring-milestones</id>
<name>Spring Milestones</name>
<url> https://repo.spring.io/milestone </url>
<snapshots>
<enabled>false</enabled>
</snapshots>
</repository>
</repositories>
<pluginRepositories>
<pluginRepository>
<id>spring-snapshots</id>
<name>Spring Snapshots</name>
<url> https://repo.spring.io/snapshot </url>
<snapshots>
<enabled>true</enabled>
</snapshots>
</pluginRepository>
<pluginRepository>
<id>spring-milestones</id>
<name>Spring Milestones</name>
<url> https://repo.spring.io/milestone </url>
<snapshots>
<enabled>false</enabled>
</snapshots>
</pluginRepository>
</pluginRepositories>
</project>
/spring-boot-microservice-currency-conversion-service/src/main/java/com/in28mines/springboot/microservice/example/currencyconversion/CurrencyConversionBean.java
package com.in28minutes.springboot.microservice.example.currencyconversion;
import java.math.BigDecimal;
public class CurrencyConversionBean {
private Long id;
private String from;
private String to;
private BigDecimal conversionMultiple;
private BigDecimal quantity;
private BigDecimal totalCalculatedAmount;
private int port;
public CurrencyConversionBean() {
}
public CurrencyConversionBean(Long id, String from, String to, BigDecimal conversionMultiple, BigDecimal quantity,
BigDecimal totalCalculatedAmount, int port) {
super();
this.id = id;
this.from = from;
this.to = to;
this.conversionMultiple = conversionMultiple;
this.quantity = quantity;
this.totalCalculatedAmount = totalCalculatedAmount;
this.port = port;
}
public Long getId() {
return id;
}
public void setId(Long id) {
this.id = id;
}
public String getFrom() {
return from;
}
public void setFrom(String from) {
this.from = from;
}
public String getTo() {
return to;
}
public void setTo(String to) {
this.to = to;
}
public BigDecimal getConversionMultiple() {
return conversionMultiple;
}
public void setConversionMultiple(BigDecimal conversionMultiple) {
this.conversionMultiple = conversionMultiple;
}
public BigDecimal getQuantity() {
return quantity;
}
public void setQuantity(BigDecimal quantity) {
this.quantity = quantity;
}
public BigDecimal getTotalCalculatedAmount() {
return totalCalculatedAmount;
}
public void setTotalCalculatedAmount(BigDecimal totalCalculatedAmount) {
this.totalCalculatedAmount = totalCalculatedAmount;
}
public int getPort() {
return port;
}
public void setPort(int port) {
this.port = port;
}
}
/spring-boot-microservice-currency-conversion-service/src/main/java/com/in28mines/springboot/microservice/example/currencyconversion/CurrencyConversionController.java
package com.in28minutes.springboot.microservice.example.currencyconversion;
import java.math.BigDecimal;
import java.util.HashMap;
import java.util.Map;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.http.ResponseEntity;
import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.PathVariable;
import org.springframework.web.bind.annotation.RestController;
import org.springframework.web.client.RestTemplate;
@RestController
public class CurrencyConversionController {
private Logger logger = LoggerFactory.getLogger(this.getClass());
@Autowired
private CurrencyExchangeServiceProxy proxy;
@GetMapping("/currency-converter/from/{from}/to/{to}/quantity/{quantity}")
public CurrencyConversionBean convertCurrency(@PathVariable String from, @PathVariable String to,
@PathVariable BigDecimal quantity) {
Map<String, String> uriVariables = new HashMap<>();
uriVariables.put("from", from);
uriVariables.put("to", to);
ResponseEntity<CurrencyConversionBean> responseEntity = new RestTemplate().
getForEntity(
" http://localhost:8000/currency-exchange/from/{from}/to/{to }", CurrencyConversionBean.class,
uriVariables);
CurrencyConversionBean response = responseEntity.getBody();
return new CurrencyConversionBean(response.getId(), from, to, response.getConversionMultiple(), quantity,
quantity.multiply(response.getConversionMultiple()), response.getPort());
}
@GetMapping("/currency-converter-feign/from/{from}/to/{to}/quantity/{quantity}")
public CurrencyConversionBean convertCurrencyFeign(@PathVariable String from, @PathVariable String to,
@PathVariable BigDecimal quantity) {
CurrencyConversionBean response = proxy.retrieveExchangeValue(from, to);
logger.info("{}", response);
return new CurrencyConversionBean(response.getId(), from, to, response.getConversionMultiple(), quantity,
quantity.multiply(response.getConversionMultiple()), response.getPort());
}
}
/spring-boot-microservice-currency-conversion-service/src/main/java/com/in28mines/springboot/microservice/example/currencyconversion/CurrencyExchangeServiceProxy.java
package com.in28minutes.springboot.microservice.example.currencyconversion;
import org.springframework.cloud.netflix.feign.FeignClient;
import org.springframework.cloud.netflix.ribbon.RibbonClient;
import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.PathVariable;
@FeignClient(name="forex-service" url="localhost:8000")
public interface CurrencyExchangeServiceProxy {
@GetMapping("/currency-exchange/from/{from}/to/{to}")
public CurrencyConversionBean retrieveExchangeValue
(@PathVariable("from") String from, @PathVariable("to") String to);
}
/spring-boot-microservice-currency-conversion-service/src/main/java/com/in28минуты/springboot/microservice/example/currencyconversion/SpringBootMicroserviceCurrencyConversionApplication.java
package com.in28minutes.springboot.microservice.example.currencyconversion;
import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;
import org.springframework.cloud.client.discovery.EnableDiscoveryClient;
import org.springframework.cloud.netflix.feign.EnableFeignClients;
@SpringBootApplication
@EnableFeignClients("com.in28minutes.springboot.microservice.example.currencyconversion")
public class SpringBootMicroserviceCurrencyConversionApplication {
public static void main(String[] args) {
SpringApplication.run(SpringBootMicroserviceCurrencyConversionApplication.class, args);
}
}
/spring-boot-microservice-currency-conversion-service/src/main/resources/application.properties
spring.application.name=currency-conversion-service
server.port=8100
/spring-boot-microservice-currency-conversion-service/src/test/java/com/in28minites/springboot/microservice/example/currencyconversion/SpringBootMicroserviceCurrencyConversionApplicationTests.java
package com.in28minutes.springboot.microservice.example.currencyconversion;
import org.junit.Test;
import org.junit.runner.RunWith;
import org.springframework.boot.test.context.SpringBootTest;
import org.springframework.test.context.junit4.SpringRunner;
@RunWith(SpringRunner.class)
@SpringBootTest
public class SpringBootMicroserviceCurrencyConversionApplicationTests {
@Test
public void contextLoads() {
}
}
Теги: #api #java #микросервисы #spring boot
-
Бета-Тестирование
19 Oct, 24 -
Золотой Бассейн
19 Oct, 24 -
Виоль, Жюль
19 Oct, 24 -
Вертолетный Ангар, Управляемый С Самолета
19 Oct, 24 -
Нестандартные Решения Сложных Проблем
19 Oct, 24 -
Бета-Версия Почты Yahoo
19 Oct, 24