随着开发人员致力于创建更大、更复杂的应用程序,微服务在开发领域得到了越来越多的使用,这些应用程序作为小型服务的组合得到了更好的开发和管理,这些服务协同工作以实现更大、应用程序范围的功能。工具正在兴起,以满足使用逐件方法来思考和构建应用程序的需要。坦白说,与同时考虑整个应用程序相比,这种方法更令人难以置信。今天,我们将了解微服务、使用此功能的好处以及一些代码示例。
什么是微服务?
微服务是一种面向服务的体系结构风格(Java开发人员最重要的技能之一),其中应用程序构建为不同小型服务的集合,而不是一个完整的应用程序。你有几个独立的应用程序,它们可以独立运行,可以使用不同的编码或编程语言创建,而不是单一的应用程序。大型和复杂的应用程序可以由简单和独立的程序组成,这些程序可以自己执行。这些较小的程序组合在一起,提供大型单片应用程序的所有功能。
Microservices捕获您的业务场景,回答“您试图解决什么问题?”的问题。它通常由只有少数成员的工程团队开发,可以用任何编程语言编写,也可以使用任何框架。每个涉及的程序都有独立的版本、执行和扩展。这些微服务可以与其他微服务交互,并且可以具有唯一的URL或名称,同时即使遇到故障也始终可用并保持一致。
微服务的好处是什么?
使用微服务有几个好处。首先,因为这些较小的应用程序不依赖于相同的编码语言,所以开发人员可以使用他们最熟悉的编程语言。这有助于开发人员以更低的成本和更少的bug更快地开发出一个程序。敏捷性和低成本还可以来自于能够在其他项目上重用这些较小的程序,从而提高效率。
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用户手册( http://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容器。
您可以在这里找到所有springboot项目,您将认识到springboot拥有应用程序所需的所有基础设施。不管你是为安全、配置还是大数据编写应用程序;它有一个Spring Boot项目。
Spring Boot项目包括:
- Spring IO平台:版本化应用程序的企业级分发。
- Spring框架:用于事务管理、依赖项注入、数据访问、消息传递和web应用程序。
- SpringCloud:用于分布式系统,用于构建或部署微服务。
- Spring数据:对于与数据访问相关的微服务,可以是map reduce、关系型或非关系型。
- Spring批处理:用于高级别的批处理操作。
- Spring安全性:用于授权和身份验证支持。
- SpringREST文档:用于记录RESTful服务。
- SpringSocial:用于连接社交媒体API。
- Spring Mobile:用于移动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的文档位于此链接: 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;
- }
- }
- 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框架
Play Framework为您提供了使用Scala和Java构建、创建和部署Web应用程序的更简单方法。Play框架非常适合需要并行处理远程调用的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和其他主要平台。
Restlet有一个陡峭的学习曲线,封闭的社区会使学习曲线变得更糟。
示例代码:
- 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";
- }
- }