推荐Java五大微服务器及其代码示例教程

微服务越来越多地用于开发领域,因为开发人员致力于创建更大,更复杂的应用程序,这些应用程序作为较小的服务组合而更好地开发和管理,可将工作在一起,实现更大的应用程序范围的功能。工具正在上升,以满足使用逐块方法思考和构建应用程序的需求,与同时考虑整个应用程序相比。下面为大家讲述一下Java五大微服务器,使用这些功能的好处以及相关的代码示例。

什么是微服务

微服务是一种面向服务的架构风格(Java开发人员最重要的技能之一),其中应用程序被构建为不同的小型服务而不是整个应用程序的集合。您可以使用多个独立的应用程序来独立运行,并且可以使用不同的编码或编程语言来创建。大而复杂的应用程序可以由可自行执行的更简单和独立的程序组成。这些较小的程序组合在一起,以提供大型单片应用程序的所有功能。

微服务捕获用户的业务场景,它通常由只有少数成员的工程团队开发,可以用任何编程语言编写并且可以使用任何框架。每个涉及的程序都是独立版本化,执行和缩放。这些微服务器可以与其他微服务器交互,并且可以具有唯一的URL或名称,同时即使遇到故障时始终可用和一致。

微服务的好处是什么?

使用微服务使得较小的应用程序不依赖于相同的编码语言,开发人员可以使用他们最熟悉的编程语言。这有助于开发人员以更低的成本和更少的错误更快地提出一个程序。灵活性和低成本也可以来自于将这些较小的程序重用于其他项目,从而使其更有效率。

Java的微服务框架示例

可用于开发Java的微服务框架,其中包括如下:

Spring Boot:这可能是最好的Java微服务框架,它可以用于反转控制,面向对象编程等语言。

Jersey :开源框架支持Java中的JAX-RS API非常容易使用。

Swagger:帮助用户记录API,并为用户提供开发门户,允许用户测试API。

用户还可以考虑的其他内容包括:Dropwizard,Ninja Web Framework,Play Framework,RestExpress,Restlet,Restx和Spark Framework。

如何使用Microservices With Spring Boot创建

Spring Boot使用户可以通过嵌入式服务器将Java应用程序与自己的应用程序一起使用。不必再使用其他Java EE容器。

Spring Boot项目包括:

1) Spring IO平台:版本化应用程序的企业级分发

2) Spring框架:用于事务管理,依赖注入,数据访问,消息传递和Web应用程序

3) Spring Cloud:用于分布式系统,用于构建或部署您的微服务器

4) Spring数据:对于与数据访问相关的微服务,无论是映射减少,关系还是非关系

5) Spring Batch:用于批处理作业等操作

6) Spring Security:用于授权和身份验证支持

7) Spring REST文档:用于记录RESTful服务

8) Spring Social:用于连接社交媒体API

9) Spring Mobile:适用于移动网络应用

快速搭建Spring Boot框架,参考示例代码:


  1. import org.springframework.boot.*; 
  2. import org.springframework.boot.autoconfigure.*; 
  3. import org.springframework.stereotype.*; 
  4. import org.springframework.web.bind.annotation.*; 
  5. @RestController 
  6. @EnableAutoConfiguration 
  7. public class Example { 
  8.     @RequestMapping("/") 
  9.     String home() { 
  10.         return "Hello World!"; 
  11.     } 
  12.     public static void main(String[] args) throws Exception { 
  13.         SpringApplication.run(Example.class, args); 
  14.     } 

Jersey

Jersey RESTful框架是开源的,它基于JAX-RS规范。Jersey应用程序可以扩展现有的JAX-RS实现并添加功能和实用程序,使RESTful服务更简单,并使客户端开发变得更加轻松。

Jersey最好的一点是它有很好的文档,完善的案例。性能方面快捷并且路由简单,参考示例代码:


  1. package org.glassfish.jersey.examples.helloworld; 
  2. import javax.ws.rs.GET; 
  3. import javax.ws.rs.Path; 
  4. import javax.ws.rs.Produces; 
  5. @Path("helloworld") 
  6. public class HelloWorldResource { 
  7.     public static final String CLICHED_MESSAGE = "Hello World!"; 
  8.     @GET 
  9.     @Produces("text/plain") 
  10.     public String getHello() { 
  11.         return CLICHED_MESSAGE; 
  12.     } 

Jersey 非常容易与其他libraries一起使用,如Netty或Grizzly,支持异步连接不需要servlet容器,然而它有一个不依赖注入的实现。

Play Framework

Play Framework为用户提供了使用Scala和Java构建,创建和部署Web应用程序的更加简单的方法。Play Framework是RESTful应用程序的理想选择,需要您并行处理远程调用。它也非常模块化,支持异步。Play Framework也是所有微服务框架中最大的社区之一。

参考示例代码:


  1. package controllers; 
  2. import play.mvc.*; 
  3. public class Application extends Controller { 
  4.     public static void index() { 
  5.         render(); 
  6.     } 
  7.     public static void sayHello(String myName) { 
  8.         render(myName); 
  9.     } 

Restlet

Restlet帮助开发人员创建遵循RESTful架构模式的快速和可扩展的Web API。它具有良好的路由和过滤功能,可用于Java SE/EE,OSGi,Google AppEngine(Google Compute部分),Android和其他主要平台。

参考示例代码:


  1. package firstSteps; 
  2. import org.restlet.resource.Get; 
  3. import org.restlet.resource.ServerResource; 
  4. /**  
  5.  * Resource which has only one representation.  
  6.  */ 
  7. public class HelloWorldResource extends ServerResource { 
  8.     @Get 
  9.     public String represent() { 
  10.         return "hello, world"; 
  11.     } 

DropWizard

DropWizard将成熟稳定的Java库集成在轻量级包中,可用于自己的应用程序。它使用Jetty for HTTP,Jersey for REST和Jackson for JSON,以及Metrics,Guava,Logback,Hibernate Validator,Apache HttpClient,Liquibase,Mustache,Joda Time和Freemarker。

您可以使用Maven设置Dropwizard应用程序在pom.xml文件中,使用最新版本的DropWizard添加一个dropwizard.version属性


  1. <properties> 
  2.     <dropwizard.version>LATEST VERSION</dropwizard.version> 
  3. </properties> 
  4. <!--Then list the dropwizard-core library:--> 
  5. <dependencies> 
  6.     <dependency> 
  7.         <groupId>io.dropwizard</groupId> 
  8.         <artifactId>dropwizard-core</artifactId> 
  9.         <version>${version}</version> 
  10.     </dependency> 
  11. </dependencies> 

Maven项目设置完成后,可以创建配置类,应用程序类,表示类,资源类或运行状况检查,还可以构建Fat JARS,然后运行应用程序。

在此链接中查看Dropwizard用户手册,GitHub地址:https://github.com/dropwizard/dropwizard,参考示例代码:


  1. package com.example.helloworld; 
  2. import com.yammer.dropwizard.config.Configuration; 
  3. import com.fasterxml.jackson.annotation.JsonProperty; 
  4. import org.hibernate.validator.constraints.NotEmpty; 
  5. public class HelloWorldConfiguration extends Configuration { 
  6.     @NotEmpty 
  7.     @JsonProperty 
  8.     private String template; 
  9.     @NotEmpty 
  10.     @JsonProperty 
  11.     private String defaultName = "Stranger"; 
  12.     public String getTemplate() { 
  13.         return template; 
  14.     } 
  15.     public String getDefaultName() { 
  16.         return defaultName; 
  17.     } 

原文发布时间为:2017-10-24
本文作者:佚名
本文来自合作伙伴“51CTO”,了解相关信息可以关注。

时间: 2024-11-02 16:23:33

推荐Java五大微服务器及其代码示例教程的相关文章

Java连接ftp服务器实例代码_java

废话不多说了,直接给大家贴java代码了. import java.io.IOException; import sun.net.TelnetInputStream; import sun.net.ftp.FtpClient; public class MyFtp { static FtpClient myFtp; static String hostname; static String username; static String password; /** * @author cutel

Solr JAVA客户端SolrJ 4.9使用示例教程

简介         SolrJ是操作Solr的JAVA客户端,它提供了增加.修改.删除.查询Solr索引的JAVA接口.SolrJ针对Solr提供了Rest 的HTTP接口进行了封装,SolrJ底层是通过使用httpClient中的方法来完成Solr的操作. SolrJ/Solr 跨版本兼容性     SolrJ通常向后保持兼容性,可以使用新版本的SolrJ访问较旧的Solr,反之亦然.建议使用同Solr server同版本的SolrJ,      详见http://wiki.apache.o

java简单留言板实现代码

java简单留言板实现代码 数据库教程对应的表: guestbook:id ,name,phone,email,title,content,time;                   <pk>id 新建web project:guestbook build Path:引入连接数据库的驱动的类库 在webRoot目录中加入: +faceditor +js web.xml 代码: <?xml version="1.0" encoding="UTF-8&quo

Kafka JAVA客户端代码示例--高级应用

什么时间使用高级应用? 针对一个消息读取多次 在一个process中,仅仅处理一个topic中的一组partitions 使用事务,确保每个消息只被处理一次 使用高级应用(调用较底层函数)的缺点?     SimpleConsumer需要做很多额外的工作(在以groups方式进行消息处理时不需要) 在应用程序中跟踪上次消息处理的offset 确定一个topic partition的lead broker 手工处理broker leander的改变 使用底层函数(SimpleConsumer)开发

Kafka JAVA客户端代码示例

介绍      http://kafka.apache.org     kafka是一种高吞吐量的分布式发布订阅消息系统     kafka是linkedin用于日志处理的分布式消息队列,linkedin的日志数据容量大,但对可靠性要求不高,其日志数据主要包括用户行为(登录.浏览.点击.分享.喜欢)以及系统运行日志(CPU.内存.磁盘.网络.系统及进程状态)      当前很多的消息队列服务提供可靠交付保证,并默认是即时消费(不适合离线).  高可靠交付对linkedin的日志不是必须的,故可通

java生成csv文件 自己定义表头、用sql查询内容,把内容和表头放到表里 , 最好有代码示例

问题描述 java生成csv文件 自己定义表头.用sql查询内容,把内容和表头放到表里 , 最好有代码示例 30C java生成csv文件 ,自己定义表头.用sql查询内容,把内容和表头放到表里 , 最好有代码示例 解决方案 csv文件最简单了,就是文本格式,逗号分割字段,换行分割记录.你自己sql循环,然后写文件,要表头的话,先输出一行作为表头就可以了. 解决方案二: 我要测试导出csv文件,response.getOutputStream()报空指针异常 解决方案三: 哪位大神有关于导出cs

think in java interview-高级开发人员面试宝典代码示例

下载资源地址为: http://download.csdn.net/detail/lifetragedy/6379755 这是think in java interview中的代码示例,包括JAVA基础的数据结构,IO, 核心基础以及设计模式等. 因此我把它称为wallet工程(钱包工程),可以直接导入eclipse工程中去.

java selenium 操作弹出窗口示例代码_java

selenium 中如何处理弹出窗口 阅读目录 原理 测试页面的HTML Java 代码 原理 在代码里, 通过         Set<String> allWindowsId = driver.getWindowHandles(); 来获取到所有弹出浏览器的句柄,   然后遍历,  使用swithcto.window(newwindow_handle)方法. 就可以定位到新的窗口 测试页面的HTML <html> <head> <title>常见web

Java发送ios推送消息(APN)的代码示例

Java发送ios推送消息(APN)的代码示例 实际项目应用中,应该考虑使用开源项目java-apns:https://github.com/notnoop/java-apns 千万不要用一个叫JAVAPNS的项目.这个开源项目的代码非常烂,每次发送消息都重新建立socket连接. 在apple的文档中,都明确的说了会把这种行为当作dos攻击行为.性能差就更不用说了. ios手机上要安装对应的应用.该应用与.p12证书文件应该匹配. apple官方的,关于APN服务,和apn的feedback的