本文主要是介绍使用Knative部署基于Spring Native的微服务,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!
在本文中,您将学习如何运行Spring Boot微服务,这些服务在Knative上相互通信。我还向您展示了如何使用GraalVM准备Spring Boot应用程序的本机映像。然后我们将使用Skaffold和jibmaven插件在Kubernetes上运行它。
本文是我关于Knative系列文章的第二篇。在Knative上发布了第一个SpringBoot之后,您问我在扩展到零后有很长的应用程序启动时间。这就是为什么我通过使用GraalVM将其编译为本机映像来解决这个Spring Boot问题。在无服务器serverless方法中,启动时间问题似乎是一个重要的问题。
在Knative上,您可以运行任何类型的应用程序,而不仅仅是函数。在本文中,当我编写“微服务”时,实际上,我考虑的是服务对服务的通信。
源代码
如果你想自己试试,你可以随时看看我的源代码: https://github.com/piomin/sample-spring-boot-graalvm.git 。为此,您需要克隆我的GitHub存储库。那你应该听从我的指示。
作为本文中的微服务示例,我使用了两个应用程序callme service和caller service。它们都公开了一个端点,该端点打印应用程序pod的名称。调用方服务应用程序还调用callme服务应用程序公开的端点。
在Kubernetes上,这两个应用程序都将作为Knative服务部署在多个版本中。我们还将使用Knative路由在这些修订版中分配流量。下图说明了我们的示例系统的体系结构。
准备Spring Boot微服务
我们有两个简单的Spring Boot应用程序,它们公开一个REST端点、运行状况检查,并运行内存中的H2数据库。我们使用Hibernate和Lombok。因此,我们需要在Maven pom.xml
中包含以下依赖项列表。
<dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-web</artifactId>
</dependency>
<dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-actuator</artifactId>
</dependency>
<dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-data-jpa</artifactId>
</dependency>
<dependency><groupId>com.h2database</groupId><artifactId>h2</artifactId><scope>runtime</scope>
</dependency>
<dependency><groupId>org.projectlombok</groupId><artifactId>lombok</artifactId><version>1.18.16</version>
</dependency>
每次调用ping端点时,它都会创建一个事件并将其存储在H2数据库中。REST端点返回Kubernetes中pod和命名空间的名称以及事件的id。该方法在我们对集群的手动测试中很有用。
@RestController
@RequestMapping("/callme")
public class CallmeController {@Value("${spring.application.name}")private String appName;@Value("${POD_NAME}")private String podName;@Value("${POD_NAMESPACE}")private String podNamespace;@Autowiredprivate CallmeRepository repository;@GetMapping("/ping")public String ping() {Callme c = repository.save(new Callme(new Date(), podName));return appName + "(id=" + c.getId() + "): " + podName + " in " + podNamespace;}}
这是我们的模型课—— Callme
。调用者服务应用程序中的模型类非常类似。
@Entity
@Getter
@Setter
@NoArgsConstructor
@RequiredArgsConstructor
public class Callme {@Id@GeneratedValueprivate Integer id;@Temporal(TemporalType.TIMESTAMP)@N
这篇关于使用Knative部署基于Spring Native的微服务的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!