随着开发人员致力于创建更大、更复杂的应用程序,微服务在开发领域得到了越来越多的使用,这些应用程序作为小型服务的组合得到了更好的开发和管理,这些服务协同工作,实现了更广泛、更广泛的应用程序功能。
诸如Service Fabric之类的工具正在兴起,以满足使用逐件方法来思考和构建应用程序的需要。坦率地说,与同时考虑整个应用程序相比,这种方法不那么令人费解。
今天,我们将了解微服务、使用此功能的好处以及一些代码示例。
什么是微服务?
微服务是一种体系结构风格,它将单个应用程序开发为一组小型服务。每个服务都在自己的进程中运行。这些服务使用轻量级协议(通常通过消息传递或HTTP)与客户机通信,并且通常彼此通信。
微服务可以被认为是一种面向服务的体系结构(Java开发人员最关键的技能之一),其中应用程序构建为不同的小型服务的集合,而不是一个完整的应用程序。
你有几个独立的应用程序可以独立运行,而不是一个单一的应用程序。您可以使用不同的编程语言甚至不同的平台创建它们。您可以使用自己执行的更简单、独立的程序来构造大型复杂的应用程序。这些较小的程序被分组以提供大型单片应用程序的所有功能。
Microservices捕捉到您的业务场景,回答了“您想解决什么问题?”
与大型团队处理大型、单一项目不同,更小、更敏捷的团队使用他们最熟悉的工具和框架开发服务。每个涉及的程序都有独立的版本、执行和扩展。这些微服务可以与其他微服务交互,并且可以具有唯一的URL或名称,同时即使遇到故障也始终可用并保持一致。
微服务的好处是什么?
使用微服务有很多好处。其中一些与它们如何允许开发人员编写代码有关。其他因素会影响您的架构。
微服务是开发团队独立创建的小型应用程序。由于它们通过消息传递进行通信(如果有的话),因此它们不依赖于相同的编码语言。开发人员可以使用他们最熟悉的编程语言。这有助于他们更快地工作,降低成本,减少bug
由于您的团队正在处理更小的应用程序和更专注的问题领域,因此他们的项目也趋向于更敏捷。他们可以更快地迭代,在更短的时间内处理新特性,并且几乎可以立即修复bug。他们也经常发现更多的重用代码的机会。
微服务也提高了体系结构的可伸缩性。
对于单片系统,您通常会以“投入更多硬件”来解决问题,或以购买成本和难以维护企业软件为代价。使用微服务,您可以使用负载平衡器和消息传递等标准解决方案进行水平扩展。
此外,随着越来越多的企业拥抱云,您可能也在这样看。微服务是实现这一目标的好方法。
云平台有助于采用集装箱化等新技术。微服务也适合于容器化,因为它们已经是具有有限依赖集的小型应用程序。这意味着您可以使用Docker和Kubernetes等技术水平扩展服务,而无需编写任何定制代码。
Java微服务框架示例
有几种微服务框架可用于Java开发。其中一些是:
- Spring Boot 这可能是在控制反转、面向方面编程等语言之上工作的最好的Java微服务框架。
- Jersey 这个开源框架支持Java中的JAX-RSAPI,非常易于使用。
- Swagger 帮助您记录API,并为您提供一个开发门户,允许用户测试您的API。
您可以考虑的其他内容包括:DooWrar、Nuja Web框架、Play框架、REST Exchange、RestRead、RESX和SCAP框架。
如何使用Dropwizard创建
DropWizard将成熟和稳定的Java库整合在轻量级软件包中,您可以将其用于应用程序。它使用Jetty表示HTTP,Jersey表示REST,Jackson表示JSON,以及Metrics、Guava、Logback、Hibernate Validator、ApacheHttpClient、Liquibase、Mustache、Joda Time和Freemarker。
您可以使用Maven设置Dropwizard应用程序。怎样
在POM中,使用最新版本的dropwizard添加dropwizard.version
属性。
<properties>
<dropwizard.version>LATEST VERSION</dropwizard.version>
</properties>
Then list the dropwizard-core library:
<dependencies>
<dependency>
<groupId>io.dropwizard</groupId>
<artifactId>dropwizard-core</artifactId>
<version>${version}</version>
</dependency>
</dependencies>
这将为您设置一个Maven项目。从这里,您可以创建配置类、应用程序类、表示类、资源类或运行状况检查,还可以构建胖jar,然后运行应用程序。
请在此链接查看Dropwizard用户手册(https://www.dropwizard.io/1.1.0/docs/manual/index.html)。Github库就在这里(https://github.com/dropwizard/dropwizard)。
示例代码:
package com.example.helloworld;
import com.yammer.dropwizard.config.Configuration;
import com.fasterxml.jackson.annotation.JsonProperty;
import org.hibernate.validator.constraints.NotEmpty;
public class HelloWorldConfiguration extends Configuration {
@NotEmpty
@JsonProperty
private String template;
@NotEmpty
@JsonProperty
private String defaultName = "Stranger";
public String getTemplate() {
return template;
}
public String getDefaultName() {
return defaultName;
}
}
Spring Boot创建的微服务
SpringBoot为您提供了Java应用程序,可通过嵌入式服务器与您自己的应用程序一起使用。它使用Tomcat,因此您不必使用JavaEE容器。此链接提供了一个示例Spring Boot教程。
您可以在这里找到所有springboot项目,您将认识到springboot拥有应用程序所需的所有基础设施。
不管你是为安全、配置还是大数据编写应用程序;它有一个Spring Boot项目。
Spring Boot项目包括:
- IO平台:版本化应用程序的企业级分发。
- 框架:用于事务管理、依赖项注入、数据访问、消息传递和web应用程序。
- 云:用于分布式系统,用于构建或部署微服务。
- 数据:对于与数据访问相关的微服务,可以是map reduce、关系型或非关系型。
- 批处理:用于高级别的批处理操作。
- 安全性:用于授权和身份验证支持。
- 对于RESTful服务:文档。
- 社交:用于连接社交媒体API。
- 移动:用于移动Web应用程序。
示例代码:
import org.springframework.boot.*;
import org.springframework.boot.autoconfigure.*;
import org.springframework.stereotype.*;
import org.springframework.web.bind.annotation.*;
@RestController
@EnableAutoConfiguration
public class Example {
@RequestMapping("/")
String home() {
return "Hello World!";
}
public static void main(String[] args) throws Exception {
SpringApplication.run(Example.class, args);
}
}
Jersey
Jersey RESTful框架是开源的,它基于JAX-RS规范。Jersey的应用程序可以扩展现有的JAX-RS实现,并添加使RESTful服务更简单的特性和实用程序,以及使客户机开发更容易。
Jersey最好的地方是它的特殊文档。里面有很多很好的例子。Jersey也很快,路线也非常简单。
关于如何开始使用Jersey的文档位于此链接(https://eclipse-ee4j.github.io/jersey/),而更多文档可在此处找到(https://eclipse-ee4j.github.io/jersey/)。
您可以尝试的示例代码:
package org.glassfish.jersey.examples.helloworld;
import javax.ws.rs.GET;
import javax.ws.rs.Path;
import javax.ws.rs.Produces;
@Path("helloworld")
public class HelloWorldResource {
public static final String CLICHED_MESSAGE = "Hello World!";
@GET
@Produces("text/plain")
public String getHello() {
return CLICHED_MESSAGE;
}
}
Jersey非常容易与其他库(如Netty或Grizzly)一起使用,并且它支持异步连接。它不需要servlet容器。但是,它确实有一个未完成的依赖注入实现。
Play Framework
Play Framework为您提供了使用Scala和Java构建、创建和部署Web应用程序的更简单方法。此框架非常适合需要并行处理远程调用的RESTful应用程序。它也是非常模块化的,支持异步。Play框架也是所有微服务框架中最大的社区之一。
您可以尝试的示例代码:
package controllers;
import play.mvc.*;
public class Application extends Controller {
public static void index() {
render();
}
public static void sayHello(String myName) {
render(myName);
}
}
Restlet
Restlet帮助开发人员创建符合RESTful架构模式的快速、可伸缩的Web api。该框架具有良好的路由和过滤功能。它可用于JavaSE/EE、OSGi、Google的AppEngine(它是Google Compute的一部分)、Android和许多其他Java平台。它是一个自给自足的框架,甚至附带有自己的Web服务器。
Restlet有一个陡峭的学习曲线,封闭的社区会使学习曲线变得更糟,但您可能会从StackOverflow的人员那里得到帮助。
示例代码:
package firstSteps;
import org.restlet.resource.Get;
import org.restlet.resource.ServerResource;
/**
* Resource which has only one representation.
*/
public class HelloWorldResource extends ServerResource {
@Get
public String represent() {
return "hello, world";
}
}
微服务的最佳实践
到现在为止,您应该已经知道,向微服务的转变为开发、运营和业务带来了很多好处。它们为提高可扩展性、更高的可靠性和成本节约创造了机会。但是,没有免费的午餐。微服务本身也有缺陷。
以下是一些有助于迁移的最佳实践。
您的每个微服务都应该使用自己的数据存储。您希望开发(和开发操作)团队为他们的每个服务选择数据库。他们应该有机会选择最适合其项目的数据存储。同时,如果团队共享一个数据库,那么他们很容易共享一个模式,用不同的名称创建一个单一的服务。
在容器中部署微服务不仅仅是一个好主意。这也是一种最佳实践。我已经多次提到,微服务团队应该选择自己的工具。运营部和开发部如何管理由此造成的混乱?通过使用容器,您可以使用一组工具部署和编排系统。
RESTful服务和微服务经常相互关联是有原因的。这是因为最好的微服务体系结构将其服务视为无状态的。REST的状态转移将状态下推到客户端,这意味着您可以将服务器视为无状态,并将代码作为整体的可互换部分运行。您只需担心是否有足够的可用服务来处理负载。而且,如果一个失败了,另一个可以弥补不足。
在本文中,我们讨论了什么是微服务,以及它们如何帮助您改进企业体系结构。在定义了这些服务之后,我们介绍了它们的主要优点。然后我们看了一些最流行的Java微服务API。
原文地址:https://stackify.com/what-are-microservices/
除特别注明外,本站所有文章均为老K的Java博客原创,转载请注明出处来自https://javakk.com/2432.html
暂无评论