原文地址:https://dzone.com/articles/auto-publishing-amp-monitoring-apis-with-spring-bo

If you are heading down the path of a microservices style of architecture, one tenant that you will need to embrace is automation. Many moving parts are introduced with this style of architecture. If successful, your environment will have a plethora of service APIs available that the enterprise can consume for application development and integration.

This means that there must be a way that available API documentation can be discovered. API information needs to be effectively communicated throughout the enterprise that shows where APIs are used, how often APIs are used, and when APIs change. Not having this type of monitoring in place will hinder and possibly cripple the agility benefits that a microservice style of architecture can bring to the enterprise.

Spring Boot by Pivotal has led the way in providing a path to develop Microservices-based, cloud-ready applications in an Agile and minimal coding manner. If you want to find out more about Spring Boot, check out this blog by Matt McCandless. It doesn’t take much effort to implement a RESTful API for a service with Spring Boot. And, putting that service in a Microservices infrastructure does not take much effort either. (See our newest white paper for more.)

This blog will describe how Swagger/OpenAPI documentation can be applied to a Spring Boot implementation. We will show how API documentation and monitoring can be automatically published to an API documentation portal.

As an example, we introduce a reference Spring Boot API CRUD application (using Spring MVC/Data with Spring Fox) and set up the automatic publishing of API documentation and statistics to documentation portal GrokOla. In the example, we introduce two open-source utilities to help and allow published APIs the ability to be searched and notify users when changed.

Configuring Swagger in Spring Boot With Spring Fox

OpenAPI (fka Swagger) is an API documentation specification that allows RESTful APIs to be gleaned from code implementations. This is arguably more efficient than having to document APIs in a separate step.

Spring Fox is a framework that automates the generation of Swagger JSON documentation from Spring Boot applications. To see how easy it is to produce Swagger JSON documentation from a Spring Boot application, consider this simple Employee API Service application that implements a CRUD API for employees.

The employee CRUD API implementation can be found at this public GitHub repository.

The example application implements the following APIs using Spring MVC, Spring Data mapping to an Employee object model using Hibernate that is configured for an in-memory database.

When started, Employee objects can be created, read, updated, and deleted with the following APIs defined in the partial khs.exmaple.api.Api Spring REST controller implementation shown below.

 
@RestController
 
@RequestMapping("/api")
 
public class Api {
 
 
    @Autowired
 
    EmployeeService service;
 
 
    @RequestMapping(method = RequestMethod.GET, value = "/employees/{id}", produces = MediaType.APPLICATION_JSON_VALUE)
 
    ResponseEntity<Employee> employee(@PathVariable("id") Long id) {
 
        Employee employee = service.findEmployee(id);
 
        return new ResponseEntity<Employee>(employee, HttpStatus.OK);
 
    }
 
 
    @ApiOperation("value")
 
    @RequestMapping(method = RequestMethod.GET, value = "/employees", produces = MediaType.APPLICATION_JSON_VALUE)
 
    ResponseEntity<Iterable<Employee>> employees() {
 
        Iterable<Employee> employees = service.all();
 
        return new ResponseEntity<Iterable<Employee>>(employees, HttpStatus.OK);
 
    }
 
 
……..
 

Swagger documentation can be produced using the Spring Fox framework. Here is how it is applied to the example application.

Add the Spring Fox/Swagger Maven dependency to your project:

 
<dependency>
 
    <groupId>io.springfox</groupId>
 
    <artifactId>springfox-swagger2</artifactId>
 
    <version>2.6.1</version>
 
</dependency>
 

Then, a Spring Fox config is defined in a SwaggerConfig.java class along with the @EnableSwagger2 annotation:

 
@Configuration
 
@EnableSwagger2
 
public class SwaggerConfig {
 
 
    @Bean
 
    public Docket apiDocket() {
 
        return new Docket(DocumentationType.SWAGGER_2)
 
                .apiInfo(apiInfo())
 
                .select()
 
                .paths(regex("/api.*"))
 
                .build();
 
    }
 
 
    private ApiInfo apiInfo() {
 
        return new ApiInfoBuilder()
 
                .title("Employee API Example")
 
                .description("A implementation of an API Gateway for Keyhole Labs Microservice Reference.")
 
                .contact(new Contact("Keyhole Software", "keyholesoftware.com", "asktheteam@keyholesoftware.com"))
 
                .version("2.0")
 
                .build();
 
    }
 
}
 

Once configured and once the application has started, Swagger JSON documentation can be obtained with http://127.0.0.1:8080/v2/api-docs.

Automated API Publishing

Making Swagger API JSON available for teams to consume essential for success, especially if you are trying to eliminate agility-hindering silos and creating an organization with cross-functional teams (i.e., “inverting” Conway’s Law).

The Swagger framework can produce human-readable HTML Swagger documentation. However, it is not indexable/searchable, aggregated with other APIs, and does not allow additional documentation to be added. A better mechanism is required.

Ideally, this will be a developer API portal that will aggregate available APIs for an organization, index APIs for searchability, allow developers to easily add additional documentation, and provide usage metrics and notifications when APIs change.

Automating this step is essential for acceptance and providing value. Our developers at Keyhole Software have created an open source Spring Boot starter framework that will publish Swagger to a portal every time the application is started.

@PublishSwagger

Once you have Spring Fox and Swagger enabled, you can apply this starter framework with the following steps.

Add the following dependency to your pom.xml:

 
<dependency>
 
  <groupId>com.keyholesoftware</groupId>                     
 
       <artifactId>khs-spring-boot-publish-swagger-starter</artifactId> 
 
  <version>1.0.0</version>
 
</dependency>
 

Add the following properties your application.yml file:

 
swagger:
 
  publish:
 
    publish-url: https://demo.grokola.com/swagger/publish/14
 
    security-token: 6e8f1cc6-3c53-4ebe-b496-53f19fb7e10e
 
    swagger-url: http://127.0.0.1:${server.port}/v2/api-docs
 

Note: This config is pointing to the GrokOla Demo API Wiki Portal.

Add the @PublishSwagger annotation to your Spring Boot startup class.

 
@SpringBootApplication
 
@PublishSwagger
 
public class EmployeesApp {
 
    public static void main(String[] args) {
 
        SpringApplication.run(EmployeesApp.class, args);
 
    }
 
}
 

When the application is started, Swagger JSON will be published to the specified publish-url. In this case, it is Keyhole’s GrokOla API wiki portal software demo site.

Here is the imported API in GrokOla:

GrokOla is a wiki that allows APIs to be imported manually and in a headless, automated manner. This blog shows how you can easily publish your APIs using Spring Boot. However, with GrokOla, you can also manually import Swagger APIs.

You can obtain a demo user ID at this link. The example in this blog is already configured to point to this demo site. So, if you have an idea, you can play around with the API wiki portal.

@EnableApiStats

Just having readily available API documentation is not enough to govern your APIs. Seeing who, how, and when they are used is critical. There are tools and sniffers that you can use to route and filter network activity, but this is a separate piece of software deployed to a location that has to be configured, typically by operations personnel and not the developer.

A more succinct and easy-to-apply mechanism has be created for Spring Boot developers to obtain and emit individual application API usage statistics to a portal for analysis. This has been implemented as another Spring Boot starter (public, open source) framework available on GitHub.

This solution applied in the following three easy steps.

    1. Add the following dependency to your POM.XML:

 
<dependency>
 
    <groupId>com.keyholesoftware</groupId>
 
    <artifactId>khs-spring-boot-api-statistics-starter</artifactId>
 
    <version>1.0.1</version>
 
</dependency>
 
    1. Add the configuration below to your application.yml. This will emit an API’s stats to the GrokOla demo instance.

 
api:
 
  statistics:
 
    name: employeeapi
 
    pattern-match: /api/.*
 
    publish-url: https://demo.grokola.com/sherpa/api/stats/41
 
    token: 6e8f1cc6-3c53-4ebe-b496-53f19fb7e10e
 
  1. Add the @EnableApiStatistics to your application boot main class implementation:

 
@SpringBootApplication
 
@PublishSwagger
 
@EnableApiStatistics
 
public class EmployeesApp {
 
 
    public static void main(String[] args) {
 
        SpringApplication.run(EmployeesApp.class, args);
 
    }
 
}
 

When the application starts, after every ten requests against the API, collected usage stats will be emitted to the publish-url. The number of requests before emission to the URL is configurable. This is done on a separate thread as not to inhibit performance.

Here is the console of the example application after ten API requests:

Notice, the API JSON being sent to the published URL.

GrokOla has been outfitted to accept the emitted API JSON stream and provide usage statistics to the user by associating API usage with published. This is accessible from the API documentation section of GrokOla. A screenshot for this API stats view is shown below.

The Usage view shows API routes type counts total duration and average duration. This allows developers to determine what and how long their APIs are being used. You can also view popularity and where and when APIs are being used.

Final Thoughts

Automatically publishing your API documentation in a seamless manner and providing a way to monitor their usage behavior is critical to the success of your services-based platform.

Having automated API publishing and monitoring will strengthen a microservices style of architecture and bring agility to the enterprise. Available API documentation should be easily discoverable, with information effectively communicated throughout the enterprise dictating where APIs are used, how often APIs are used, and when APIs change.

We have released two open-source utilities that should help in this goal:

  1. Spring Boot Starter for publishing Swagger/OpenAPI to a portal every time the application is started.

    • This Spring Boot starter can be used to POST Swagger JSON to a publishing target (URL) upon startup of the Spring Boot application. The body of the request will be the raw Swagger JSON, and a security token can be applied to ensure that only authorized clients have access.
  2. Spring Boot Starter for publishing individual application API usage statistics to a portal for analysis.
    • This Spring Boot starter can be used to POST API usage statistics to a publishing target (URL) on a configurable interval. The body of the request will be a JSON array of statistics, and a security token can be applied to ensure that only authorized clients have access.

We hope that you find this helpful!

Auto-Publishing and Monitoring APIs With Spring Boot--转的更多相关文章

  1. Java | Spring Boot Swagger2 集成REST ful API 生成接口文档

      Spring Boot Swagger2 集成REST ful API 生成接口文档 原文 简介 由于Spring Boot 的特性,用来开发 REST ful 变得非常容易,并且结合 Swagg ...

  2. 使用Spring Boot Actuator、Jolokia和Grafana实现准实时监控

    由于最近在做监控方面的工作,因此也读了不少相关的经验分享.其中有这样一篇文章总结了一些基于Spring Boot的监控方案,因此翻译了一下,希望可以对大家有所帮助. 原文:Near real-time ...

  3. spring boot整合Swagger2

    Swagger 是一个规范和完整的框架,用于生成.描述.调用和可视化RESTful风格的 Web 服务.总体目标是使客户端和文件系统作为服务器以同样的速度来更新.文件的方法,参数和模型紧密集成到服务器 ...

  4. 使用Spring Boot Actuator、Jolokia和Grafana实现准实时监控--转

    原文地址:http://mp.weixin.qq.com/s?__biz=MzAxODcyNjEzNQ==&mid=2247483789&idx=1&sn=ae11f04780 ...

  5. Spring Boot 入门系列(二十二)使用Swagger2构建 RESTful API文档

    前面介绍了如何Spring Boot 快速打造Restful API 接口,也介绍了如何优雅的实现 Api 版本控制,不清楚的可以看我之前的文章:https://www.cnblogs.com/zha ...

  6. Spring Boot中使用Swagger2构建RESTful APIs

    关于 Swagger Swagger能成为最受欢迎的REST APIs文档生成工具之一,有以下几个原因: Swagger 可以生成一个具有互动性的API控制台,开发者可以用来快速学习和尝试API. S ...

  7. Spring Boot中使用Swagger2构建RESTful APIs介绍

    1.添加相关依赖 <!-- https://mvnrepository.com/artifact/io.springfox/springfox-swagger2 --> <depen ...

  8. spring boot 四大组件之Auto Configuration

    SpringBoot 自动配置主要通过 @EnableAutoConfiguration, @Conditional, @EnableConfigurationProperties 或者 @Confi ...

  9. Spring Boot Reference Guide

    Spring Boot Reference Guide Authors Phillip Webb, Dave Syer, Josh Long, Stéphane Nicoll, Rob Winch,  ...

随机推荐

  1. 2014年辛星解读css第三节

    第二节我们讲述的差点儿全是CSS的选择器,那么以下这一节我们来讲一下CSS的颜色和文本的一些东西,尽管我对调色不大敏感.可是对于颜色还是比較感兴趣的. *********CSS中的颜色******** ...

  2. 安卓APP载入HTML5页面解决方式总结

    因为H5页面在移动端的兼容性及扩展性方面体现出来的优势,又兼得APP中植入H5页面相应用的灵活性有大大的提升(如活动.游戏的更新等).APP开发不可避免的须要载入一些H5页面.但安卓client对网页 ...

  3. CentOS6.3升级GCC到GCC4.8.2

    server上安装的GCC版本号过旧.已经不满足个人使用的版本号需求,故决定对其进行升级操作.由当前版本号3.4.6升级到4.8.2.然受权限制约.仅仅能安装到个人文件夹.因此假设您的server能够 ...

  4. nyoj--18--The Triangle(dp水题)

    The Triangle 时间限制:1000 ms  |  内存限制:65535 KB 难度:4 描述 7 3 8 8 1 0 2 7 4 4 4 5 2 6 5 (Figure 1) Figure ...

  5. javaBean 练习—封装学生信息

    编写一个封装学生信息的JavaBean对象,在页面中调用该对象,并将学生信息输出在页面中. package com.sp.test; public class Student { private St ...

  6. Edge浏览器的几个创意应用

    如果你跟我一样也喜欢书法,并且也有surface.那你可以进入我的网页.我给您准备了中国书法纸.信纸.方格子.对联等模板.满足您打发时间,精心抄佛经.诗歌,练书法等.开启Edge浏览器,开启涂鸦模式, ...

  7. C#调用webservice(一)

    最近一直在搞网络编程,这篇是关于webservice的,准备写两篇例子这篇是实现手机号码归宿地查询,下篇准备写实现机票查询. 这个网站(http://www.webxml.com.cn/zh_cn/i ...

  8. 《汇编语言(第三版)》pushf 和 popf 指令,以及标志寄存器在 Debug 中的表示

    pushf 和 popf pushf 的功能是将标志寄存器的值压栈,而 popf 是从栈中弹出数据,输入标志寄存器. pushf 和 popf,为直接访问寄存器提供了方法. 格式 pushf popf ...

  9. sqlserver 恢复模式及避免日志爆满的方法

    recovery simple 循环日志,空间自动回收,不可备份日志,恢复时仅能恢复到数据库备份时间点: 用于落地数据或测试环境或OLAP,不推荐用于生产OLTP 有时候distribution过大也 ...

  10. PHP mysql_fetch_array得不到数据

    好久没写PHP了...为了数据库课设开始了PHP速成之旅... 光是简单的注册功能就坑了我好几个小时,不过万事开头难嘛...之后应该会快起来的. 先说一下昨天遇到的小坑, 我的表单是这么写的 < ...