微服务架构已成为构建可扩展和模块化系统的流行解决方案。通过微服务,您可以将单个应用程序分解为更小、更独立、更专业的服务,使系统更容易维护和开发。在本文中,我们将讨论如何使用它 spring boot 和 spring cloud 创建强大高效的微服务。
微服务简介 微服务背后的主要思想是将应用程序分为小型服务,可以独立开发、部署和扩展。每个微服务都应该负责特定的功能,并以轻量级的方式与其他服务进行通信,通常使用 rest api 或者信息传递。
微服务的一些优势包括:
- 独立可扩展性:每项服务都可以单独扩展。
- 持续部署:您可以在不影响其他微服务的情况下更新或修复微服务。
- 技术灵活性:每项服务都可以通过不同的技术和框架来实现。 现在,让我们来看看如何使用它 spring boot 和 spring cloud 微服务的创建和管理。
现在,让我们来看看如何使用它 spring boot 和 spring cloud 微服务的创建和管理。
使用 spring boot 创建微服务spring boot 专注于最少的配置和快速启动,可以轻松构建微服务。让我们先创建两个微服务:“用户”服务(user-service)以及“订单”服务(order-service)。
- 设置 spring boot 项目
您可以使用微服务 spring initializr 生成一个包含所需依赖项的新项目,例如 spring web 和 spring data jpa。以下是用户服务 rest 控制器的基本示例:
@restcontroller @requestmapping("/users") public class usercontroller { @getmapping("/{id}") public responseentity<user> getuserbyid(@pathvariable long id) { user user = new user(id, "matheus"); return responseentity.ok(user); } } </user>
每个微服务都可以拥有自己的数据库,以确保独立和解耦服务。我们可以使用用户服务 h2 或 postgresql 等配置。
- 公开 rest api 通过每一个微服务 rest api 公开其资源,允许其他服务或客户使用其功能。以下是 order-service 用户服务中使用 api 端点示例:
@restcontroller @requestmapping("/orders") public class ordercontroller { private final resttemplate resttemplate; public ordercontroller(resttemplate resttemplate) { this.resttemplate = resttemplate; } @getmapping("/{id}") public responseentity<order> getorderbyid(@pathvariable long id) { user user = resttemplate.getforobject("http://user-service/users/" + id, user.class); order order = new order(id, user, "order details"); return responseentity.ok(order); } } </order>
resttemplate 用于在微服务之间发送 http 请求。
使用 spring cloud 管理微服务 虽然 spring boot 但有助于快速创建微服务, spring cloud 在分布式环境中管理这些服务的通信和灵活性提供了额外的工具。让我们介绍一些基本组件。
- 尤里卡发现了服务器 服务发现是微服务的挑战之一。 eureka 它是一种发现服务器,允许服务注册自己并发现其他服务而不固定 url。
- 将 spring-cloud-starter-netflix-eureka-server 依赖添加到 eureka 服务器。
- user-service和order-所有application都配置在service中.eureka服务器注册yml文件:
eureka: client: service-url: defaultzone: http://localhost:8761/eureka/
现在,服务将自动注册到eureka,使它们更容易相互发现。
- api 网关与 spring cloud gateway 在微服务架构中,为所有服务提供一个入口点是非常重要的。 api 网关作为客户端与微服务之间的中介,有效地要求路由。
添加 spring-cloud-starter-gateway 依靠创建一个简单的网关:
spring: cloud: gateway: routes: - id: user-service uri: lb://user-service predicates: - path=/users/** - id: order-service uri: lb://order-service predicates: - path=/orders/**
这样,任何对的 /users/** 所有要求都将由路由提供给用户服务,这也适用于 /orders/**。
3.** 断路器的弹性 (hystrix)**
失败在微服务环境中是不可避免的。 hystrix 它是一种通过隔离故障保护服务免受过载的断路器。以下是如何将其应用于其他服务的例子:
@HystrixCommand(fallbackMethod = "fallbackGetUser") public User getUser(Long id) { return restTemplate.getForObject("http://user-service/users/" + id, User.class); } public User fallbackGetUser(Long id) { return new User(id, "Default User"); }
如果用户服务失败,将调用fallbackgetuser方法,以确保系统正常运行。
spring boot 与 spring cloud 结合起来,为开发可扩展、灵活的微服务提供了优秀的基础设施。您的应用程序将充分准备在分布式动态环境中运行,具有服务发现、路由和故障管理功能。
无论您是从单个应用程序转移到微服务还是从头开始,spring boot 和 spring cloud 所有这些都可以加速您的过程,并确保坚实的结构。
你喜欢这篇文章吗?如果您有任何问题或建议,请在评论中留下!别忘了与其他能从这些技能中受益的开发人员分享。
以上就是使用 Spring Boot 和 Spring Cloud 开发微服务的详细内容,请关注图灵教育的其他相关文章!