需求分析
我们有一个应用平台需要和某特殊服务器对接,实现对特殊服务器的一些操作以及状态信息的读取。但是该服务器由多个厂商完成,且每个厂商的实现方式不同,因此不能通过应用平台逐一实现每个厂商的接口调用。我们考虑在特殊服务器端部署一个通用操作接口服务,应用平台仅仅与该接口通信,而具体的命令下发则由该通用操作接口服务实施。此时,仅需在接口服务项目中实现不同厂商的命令实现即可。该接口服务的需求如下:
- 接口服务与应用平台的通信标准化并实施通信加密。
- 应用无需考虑服务器硬件情况,仅需与接口服务通信即可完成所有功能对接。
- 接口服务前端接收应用平台请求数据,后端向服务器发送命令并接收结果。
- 接口服务的后端应根据功能需求指定规范,并要求厂商实现这些规范功能。
- 接口服务的后端应支持根据不同服务器类型灵活配置,实现模块化,并可以灵活配置和替换。
- 接口服务后端模块应与前端请求解耦,支持厂商自行开发后端实现模块。
- 接口服务在启动时应该实现对设备的认证,未通过认证的设备不允许对外提供服务。
程序设计
总体实际
我们计划将后端接口服务设计为REST风格的微服务,因此采用Spring boot作为框架基础。同时考虑到前后解耦的需求,我们将项目拆分为前后端两个模块。如下所示:
nmi为项目名:network management interface
--> nmi (父项目)
|-->nmi-front(前端模块)
|-->nmi-core(后端模块)
如上所示,整体项目由MAVEN管理,将项目拆分后,nmi-core以jar包形式引入nmi-front中。我们在nmi-core中制定好接口interface,不同厂商的则可以在该模块模板的基础上开发各自对应的nmi-core.jar。这样在最终部署时即可通过替换nmi-core.jar实现对不同设备的定制。
MAVEN构建
nmi父项目
<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
<modelVersion>4.0.0</modelVersion>
<groupId>org.wsy</groupId>
<artifactId>nmi</artifactId>
<version>0.0.1-SNAPSHOT</version>
<packaging>pom</packaging>
<name>nmi</name>
<description>network management interface</description>
<dependencyManagement>
<dependencies>
<dependency>
<groupId>org.wsy</groupId>
<artifactId>nmi-core</artifactId>
<type>jar</type>
<scope>compile</scope>
</dependency>
</dependencies>
</dependencyManagement>
<modules>
<module>nmi-core</module>
<module>nmi-front</module>
</modules>
</project>