CN114374620A - 一种基于非阻塞可动态配置的应用中间层网关装置 - Google Patents
一种基于非阻塞可动态配置的应用中间层网关装置 Download PDFInfo
- Publication number
- CN114374620A CN114374620A CN202210151060.8A CN202210151060A CN114374620A CN 114374620 A CN114374620 A CN 114374620A CN 202210151060 A CN202210151060 A CN 202210151060A CN 114374620 A CN114374620 A CN 114374620A
- Authority
- CN
- China
- Prior art keywords
- interface
- routing
- http request
- routing table
- module
- Prior art date
- Legal status (The legal status is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the status listed.)
- Pending
Links
Images
Classifications
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04L—TRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
- H04L41/00—Arrangements for maintenance, administration or management of data switching networks, e.g. of packet switching networks
- H04L41/22—Arrangements for maintenance, administration or management of data switching networks, e.g. of packet switching networks comprising specially adapted graphical user interfaces [GUI]
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04L—TRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
- H04L12/00—Data switching networks
- H04L12/66—Arrangements for connecting between networks having differing types of switching systems, e.g. gateways
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04L—TRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
- H04L41/00—Arrangements for maintenance, administration or management of data switching networks, e.g. of packet switching networks
- H04L41/08—Configuration management of networks or network elements
- H04L41/0876—Aspects of the degree of configuration automation
- H04L41/0879—Manual configuration through operator
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04L—TRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
- H04L45/00—Routing or path finding of packets in data switching networks
- H04L45/02—Topology update or discovery
Landscapes
- Engineering & Computer Science (AREA)
- Computer Networks & Wireless Communication (AREA)
- Signal Processing (AREA)
- Human Computer Interaction (AREA)
- Automation & Control Theory (AREA)
- Data Exchanges In Wide-Area Networks (AREA)
- Computer And Data Communications (AREA)
Abstract
本发明公开—种基于非阻塞可动态配置的应用中间层网关装置,涉及政府服务技术领域,包括网关管理模块、本地缓存模块和网关服务模块;网关管理模块提供可视化的用户界面,供用户手动新增或更改路由配置信息,路由配置信息包含路由表信息,新增或更改的路由配置信息推送到本地缓存模块;网关服务模块根据服务接入和接口接入的注册信息自动生成路由表规则,路由表规则推送至本地缓存模块;在网关服务模块拦截到HTTP请求时,根据路由表规则读取并匹配本地缓存模块的路由表信息,匹配成功后处理拦截到的HTTP请求。本发明操作简单,提供可视化界面,用户可以简单快捷的完成接口注册、变更,无需接口提供方的改造、对接,具有高可用和高性能的特点。
Description
技术领域
本发明涉及政府服务技术领域,具体的说是—种基于非阻塞可动态配置的应用中间层网关装置。
背景技术
随着政务服务信息化建设程度的加深,产生了越来越多的政务服务应用,这些应用之间技术架构各异,存在着相互对接复杂度高,对接需求变化快,接口开放维护过度依赖于开发人员等问题。传统网关解决以上问题时,又存在或需要政务服务应用和网关进行对接开发、或无法实时同步网关的配置、或需要专业的技术知识才能完成网关路由配置等问题。
发明内容
本发明针对目前技术发展的需求和不足之处,提供—种基于非阻塞可动态配置的应用中间层网关装置,通过提供可视化界面,用户可以简单快捷的完成接口注册、变更,无需接口提供方的改造、对接。
本发明的—种基于非阻塞可动态配置的应用中间层网关装置,解决上述技术问题采用的技术方案如下:
—种基于非阻塞可动态配置的应用中间层网关装置,其包括网关管理模块、本地缓存模块和网关服务模块;
网关管理模块提供可视化的用户界面,供用户手动新增或更改路由配置信息,新增或更改的路由配置信息推送到本地缓存模块,路由配置信息包含路由表信息;
网关服务模块根据服务接入和接口接入的注册信息自动生成路由表规则;
在网关服务模块拦截到HTTP请求时,根据路由表规则读取并匹配本地缓存模块的路由表信息,匹配成功后处理拦截到的HTTP请求。
可选的,新增或更改的路由配置信息一方面写入MySql数据库实现持久化存储,另一方面同步推送到本地缓存模块。
可选的,服务接入的注册信息包括提供接口的第三方服务名称、IP端口、服务所属区域;
接口接入对服务需要开放的API进行注册,包含接口名称、方法名称、接口路径、接口参数、所属系统和功能描述。
可选的,网关服务模块生成的路由表规则一方面持久化到MySql数据库,另一方面同步推送到本地缓存模块。
可选的,网关服务模块包括路由组件和插件组件;
路由组件用于拦截HTTP请求,并在拦截到HTTP请求时读取本地缓存模块的路由表信息,同时,将拦截到的HTTP请求交给插件组件,插件组件对HTTP请求进行权限校验,校验成功后转发到接口服务。
进一步可选的,路由组件利用异步非阻塞WebFlux框架提供的WebFilter过滤器拦截HTTP请求。
进一步可选的,路由组件将拦截到的HTTP请求交给插件组件,具体操作包括:
创建一个PluginFilter实现WebFilter接口,重写filter方法;
在filter方法中,解析URL携带的参数,获取HTTP请求要调用的目标接口信息;
读取本地缓存模块的路由表信息,检查目标接口信息是否能够匹配到读取的路由表信息,匹配成功则将HTTP请求交给插件组件组装插件链,以链式处理拦截到的HTTP 请求。
优选的,本地缓存模块采用Redis存储路由配置信息和路由表规则。
本发明的—种基于非阻塞可动态配置的应用中间层网关装置,与现有技术相比具有的有益效果是:
(1)本发明操作简单,提供可视化界面,用户可以简单快捷的完成接口注册、变更,无需接口提供方的改造、对接,具有高可用和高性能的特点;
(2)本发明通过在用户在可视化界面人工配置开放接口信息、网关热重载配置信息,实现路由信息的动态加载,解耦接口提供者和使用者,最终达到提高接口开放的易用性和可操作性,便于系统直接通过HTTP接口实现对接。
附图说明
附图1是本发明实施例一的连接框图。
具体实施方式
为使本发明的技术方案、解决的技术问题和技术效果更加清楚明白,以下结合具体实施例,对本发明的技术方案进行清楚、完整的描述。
实施例一:
结合附图1,本实施例提出—种基于非阻塞可动态配置的应用中间层网关装置,其包括网关管理模块、本地缓存模块和网关服务模块。
网关管理模块提供可视化的用户界面,供用户手动新增或更改路由配置信息,路由配置信息包含路由表信息。
新增或更改的路由配置信息一方面写入MySql数据库实现持久化存储,另一方面同步推送到本地缓存模块。
网关服务模块根据服务接入和接口接入的注册信息自动生成路由表规则,路由表规则一方面持久化到MySql数据库,另一方面同步推送到本地缓存模块。
在网关服务模块拦截到HTTP请求时,根据路由表规则读取并匹配本地缓存模块的路由表信息,匹配成功后处理拦截到的HTTP请求。
本实施例中:服务接入的注册信息包括提供接口的第三方服务名称、IP端口、服务所属区域;
接口接入对服务需要开放的API进行注册,包含接口名称、方法名称、接口路径、接口参数、所属系统和功能描述。
实施例二:
本实施例提出—种基于非阻塞可动态配置的应用中间层网关装置,其包括网关管理模块、本地缓存模块和网关服务模块。
网关管理模块提供可视化的用户界面,供用户手动新增或更改路由配置信息,路由配置信息包含路由表信息。
新增或更改的路由配置信息一方面写入MySql数据库实现持久化存储,另一方面同步推送到本地缓存模块。
网关服务模块根据服务接入和接口接入的注册信息自动生成路由表规则,路由表规则一方面持久化到MySql数据库,另一方面同步推送到本地缓存模块。
本实施例中,网关服务模块包括路由组件和插件组件;路由组件利用异步非阻塞WebFlux框架提供的WebFilter过滤器拦截HTTP请求,并在拦截到HTTP请求时根据路由表规则读取本地缓存模块的路由表信息,同时,将拦截到的HTTP请求交给插件组件,插件组件对HTTP请求进行权限校验,校验成功后转发到接口服务。
上述过程中,路由组件将拦截到的HTTP请求交给插件组件,具体操作包括:
创建一个PluginFilter实现WebFilter接口,重写filter方法;
在filter方法中,解析URL携带的参数,获取HTTP请求要调用的目标接口信息;
根据路由表规则读取本地缓存模块的路由表信息,检查目标接口信息是否能够匹配到读取的路由表信息,匹配成功则将HTTP请求交给插件组件组装插件链,以链式处理拦截到的HTTP请求。
本实施例中:服务接入的注册信息包括提供接口的第三方服务名称、IP端口、服务所属区域;
接口接入对服务需要开放的API进行注册,包含接口名称、方法名称、接口路径、接口参数、所属系统和功能描述。
综上可知,采用本发明的—种基于非阻塞可动态配置的应用中间层网关装置,操作简单,提供可视化界面,用户可以简单快捷的完成接口注册、变更,无需接口提供方的改造、对接,具有高可用和高性能的特点,便于系统直接通过HTTP接口实现对接。
以上应用具体个例对本发明的原理及实施方式进行了详细阐述,这些实施例只是用于帮助理解本发明的核心技术内容。基于本发明的上述具体实施例,本技术领域的技术人员在不脱离本发明原理的前提下,对本发明所作出的任何改进和修饰,皆应落入本发明的专利保护范围。
Claims (8)
1.一种基于非阻塞可动态配置的应用中间层网关装置,其特征在于,其包括网关管理模块、本地缓存模块和网关服务模块;
所述网关管理模块提供可视化的用户界面,供用户手动新增或更改路由配置信息,新增或更改的路由配置信息推送到本地缓存模块,所述路由配置信息包含路由表信息;
所述网关服务模块根据服务接入和接口接入的注册信息自动生成路由表规则;
在所述网关服务模块拦截到HTTP请求时,根据路由表规则读取并匹配所述本地缓存模块的路由表信息,匹配成功后处理拦截到的HTTP请求。
2.根据权利要求1所述的—种基于非阻塞可动态配置的应用中间层网关装置,其特征在于,新增或更改的路由配置信息一方面写入MySql数据库实现持久化存储,另一方面同步推送到本地缓存模块。
3.根据权利要求2所述的—种基于非阻塞可动态配置的应用中间层网关装置,其特征在于,所述服务接入的注册信息包括提供接口的第三方服务名称、IP端口、服务所属区域;
所述接口接入对服务需要开放的API进行注册,包含接口名称、方法名称、接口路径、接口参数、所属系统和功能描述。
4.根据权利要求1所述的—种基于非阻塞可动态配置的应用中间层网关装置,其特征在于,所述网关服务模块生成的路由表规则一方面持久化到MySql数据库,另一方面同步推送到本地缓存模块。
5.根据权利要求1所述的—种基于非阻塞可动态配置的应用中间层网关装置,其特征在于,所述网关服务模块包括路由组件和插件组件;
所述路由组件用于拦截HTTP请求,并在拦截到HTTP请求时读取所述本地缓存模块的路由表信息,同时,将拦截到的HTTP请求交给所述插件组件,所述插件组件对HTTP请求进行权限校验,校验成功后转发到接口服务。
6.根据权利要求5所述的—种基于非阻塞可动态配置的应用中间层网关装置,其特征在于,所述路由组件利用异步非阻塞WebFlux框架提供的WebFilter过滤器拦截HTTP请求。
7.根据权利要求6所述的—种基于非阻塞可动态配置的应用中间层网关装置,其特征在于,所述路由组件将拦截到的HTTP请求交给所述插件组件,具体操作包括:
创建一个PluginFilter实现WebFilter接口,重写filter方法;
在filter方法中,解析URL携带的参数,获取HTTP请求要调用的目标接口信息;
读取所述本地缓存模块的路由表信息,检查目标接口信息是否能够匹配到读取的路由表信息,匹配成功则将HTTP请求交给插件组件组装插件链,以链式处理拦截到的HTTP请求。
8.根据权利要求1所述的—种基于非阻塞可动态配置的应用中间层网关装置,其特征在于,所述本地缓存模块采用Redis存储路由配置信息和路由表规则。
Priority Applications (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN202210151060.8A CN114374620A (zh) | 2022-02-14 | 2022-02-14 | 一种基于非阻塞可动态配置的应用中间层网关装置 |
Applications Claiming Priority (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN202210151060.8A CN114374620A (zh) | 2022-02-14 | 2022-02-14 | 一种基于非阻塞可动态配置的应用中间层网关装置 |
Publications (1)
Publication Number | Publication Date |
---|---|
CN114374620A true CN114374620A (zh) | 2022-04-19 |
Family
ID=81146625
Family Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
CN202210151060.8A Pending CN114374620A (zh) | 2022-02-14 | 2022-02-14 | 一种基于非阻塞可动态配置的应用中间层网关装置 |
Country Status (1)
Country | Link |
---|---|
CN (1) | CN114374620A (zh) |
Cited By (1)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN115665246A (zh) * | 2022-09-01 | 2023-01-31 | 浪潮通信信息系统有限公司 | 注册请求处理方法、装置、设备及存储介质 |
Citations (4)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN109446769A (zh) * | 2018-10-18 | 2019-03-08 | 北京计算机技术及应用研究所 | 统计身份认证及日志处理微服务系统及其实现方法 |
CN110391942A (zh) * | 2019-07-30 | 2019-10-29 | 中国联合网络通信集团有限公司 | 服务管理平台及服务管理方法 |
WO2021169254A1 (zh) * | 2020-02-28 | 2021-09-02 | 华为技术有限公司 | 一种路由匹配方法、信息发送方法及装置 |
CN113595991A (zh) * | 2021-07-07 | 2021-11-02 | 河北远东通信系统工程有限公司 | 一种http接口网关、通信系统及通信方法 |
-
2022
- 2022-02-14 CN CN202210151060.8A patent/CN114374620A/zh active Pending
Patent Citations (4)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN109446769A (zh) * | 2018-10-18 | 2019-03-08 | 北京计算机技术及应用研究所 | 统计身份认证及日志处理微服务系统及其实现方法 |
CN110391942A (zh) * | 2019-07-30 | 2019-10-29 | 中国联合网络通信集团有限公司 | 服务管理平台及服务管理方法 |
WO2021169254A1 (zh) * | 2020-02-28 | 2021-09-02 | 华为技术有限公司 | 一种路由匹配方法、信息发送方法及装置 |
CN113595991A (zh) * | 2021-07-07 | 2021-11-02 | 河北远东通信系统工程有限公司 | 一种http接口网关、通信系统及通信方法 |
Cited By (2)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN115665246A (zh) * | 2022-09-01 | 2023-01-31 | 浪潮通信信息系统有限公司 | 注册请求处理方法、装置、设备及存储介质 |
CN115665246B (zh) * | 2022-09-01 | 2024-03-08 | 浪潮通信信息系统有限公司 | 注册请求处理方法、装置、设备及存储介质 |
Similar Documents
Publication | Publication Date | Title |
---|---|---|
US12028210B2 (en) | Production software application performance and resiliency testing | |
CN109446063A (zh) | 接口测试方法、装置、计算机设备和存储介质 | |
US20140317336A1 (en) | Local direct storage class memory access | |
CN114374620A (zh) | 一种基于非阻塞可动态配置的应用中间层网关装置 | |
CN111262784A (zh) | 报文转发方法、报文转发装置、存储介质及电子设备 | |
US9037630B2 (en) | Systems and methods for provisioning digital forensics services remotely over public and private networks | |
US20150067759A1 (en) | System and method for implementing data migration while preserving security policies of a source filer | |
US20200344112A1 (en) | On-premise and off-premise debugging | |
CN108521444B (zh) | 一种网络调试方法、装置及计算机可读存储介质 | |
WO2021003798A1 (zh) | 一种实现域名访问加速的方法和系统 | |
CN108540674A (zh) | 自动化测试方法、装置、计算机设备以及存储介质 | |
CN104580501A (zh) | 一种基于反射机制的Http接口动态发布方法与系统 | |
CN108132815A (zh) | 一种配置文件动态加载的方法、装置和存储介质 | |
CN108255467A (zh) | 按照工作流顺序执行服务的方法、装置及系统 | |
CN112948409A (zh) | 一种数据处理方法、装置、电子设备及存储介质 | |
CN103139311A (zh) | 一种文件共享系统、装置及方法 | |
AU2022279438A1 (en) | Networks for packet monitoring and replay | |
US20150066846A1 (en) | System and method for asynchronous replication of a network-based file system | |
CN108595280A (zh) | 接口适配方法、装置、计算机设备和存储介质 | |
CN103248709A (zh) | 无线信号自动化仿真方法及系统 | |
CN107741891A (zh) | 对象的析构方法、介质、装置和计算设备 | |
CN109753229A (zh) | 数据迁移方法、装置、网络附属存储设备和存储介质 | |
CN109429266A (zh) | 网络通信系统的控制方法与边缘运算装置 | |
US8650151B2 (en) | Transactional service pipeline | |
CN104881826A (zh) | 一种基于地理位置信息处理的法律服务系统及方法 |
Legal Events
Date | Code | Title | Description |
---|---|---|---|
PB01 | Publication | ||
PB01 | Publication | ||
SE01 | Entry into force of request for substantive examination | ||
SE01 | Entry into force of request for substantive examination |