CN115580666B - 面向内容访问的ip-ndn互通方法、系统、设备及存储介质 - Google Patents
面向内容访问的ip-ndn互通方法、系统、设备及存储介质 Download PDFInfo
- Publication number
- CN115580666B CN115580666B CN202211588540.7A CN202211588540A CN115580666B CN 115580666 B CN115580666 B CN 115580666B CN 202211588540 A CN202211588540 A CN 202211588540A CN 115580666 B CN115580666 B CN 115580666B
- Authority
- CN
- China
- Prior art keywords
- ndn
- request
- data
- protocol
- response message
- 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.)
- Active
Links
- 238000000034 method Methods 0.000 title claims abstract description 37
- 238000003860 storage Methods 0.000 title claims abstract description 12
- 230000005540 biological transmission Effects 0.000 claims abstract description 10
- 230000004044 response Effects 0.000 claims description 90
- 239000012634 fragment Substances 0.000 claims description 72
- 238000004458 analytical method Methods 0.000 claims description 24
- 238000004806 packaging method and process Methods 0.000 claims description 18
- 238000012545 processing Methods 0.000 claims description 16
- 230000002776 aggregation Effects 0.000 claims description 9
- 238000004220 aggregation Methods 0.000 claims description 9
- 238000009826 distribution Methods 0.000 claims description 5
- 238000004590 computer program Methods 0.000 claims description 4
- 238000012546 transfer Methods 0.000 claims description 3
- 230000003993 interaction Effects 0.000 claims description 2
- 230000006872 improvement Effects 0.000 abstract description 7
- 230000004888 barrier function Effects 0.000 abstract description 3
- 230000008569 process Effects 0.000 description 7
- 238000010586 diagram Methods 0.000 description 4
- 230000006870 function Effects 0.000 description 4
- 238000013507 mapping Methods 0.000 description 4
- 238000013519 translation Methods 0.000 description 4
- 238000006243 chemical reaction Methods 0.000 description 2
- 238000004891 communication Methods 0.000 description 2
- 238000005516 engineering process Methods 0.000 description 2
- 239000000463 material Substances 0.000 description 2
- 230000008901 benefit Effects 0.000 description 1
- -1 carrier Substances 0.000 description 1
- 230000008859 change Effects 0.000 description 1
- 239000000306 component Substances 0.000 description 1
- 238000010276 construction Methods 0.000 description 1
- 238000011161 development Methods 0.000 description 1
- 238000004134 energy conservation Methods 0.000 description 1
- 238000009472 formulation Methods 0.000 description 1
- 230000004927 fusion Effects 0.000 description 1
- 239000004615 ingredient Substances 0.000 description 1
- 238000004519 manufacturing process Methods 0.000 description 1
- 230000007246 mechanism Effects 0.000 description 1
- 239000000203 mixture Substances 0.000 description 1
- 238000012544 monitoring process Methods 0.000 description 1
- 230000003287 optical effect Effects 0.000 description 1
- 238000005457 optimization Methods 0.000 description 1
- 238000011160 research Methods 0.000 description 1
- 238000012163 sequencing technique Methods 0.000 description 1
- 238000006467 substitution reaction Methods 0.000 description 1
- 230000004083 survival effect Effects 0.000 description 1
- 230000001360 synchronised effect Effects 0.000 description 1
Images
Classifications
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04L—TRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
- H04L69/00—Network arrangements, protocols or services independent of the application payload and not provided for in the other groups of this subclass
- H04L69/08—Protocols for interworking; Protocol conversion
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04L—TRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
- H04L69/00—Network arrangements, protocols or services independent of the application payload and not provided for in the other groups of this subclass
- H04L69/16—Implementation or adaptation of Internet protocol [IP], of transmission control protocol [TCP] or of user datagram protocol [UDP]
- H04L69/161—Implementation details of TCP/IP or UDP/IP stack architecture; Specification of modified or new header fields
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04L—TRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
- H04L69/00—Network arrangements, protocols or services independent of the application payload and not provided for in the other groups of this subclass
- H04L69/22—Parsing or analysis of headers
-
- Y—GENERAL TAGGING OF NEW TECHNOLOGICAL DEVELOPMENTS; GENERAL TAGGING OF CROSS-SECTIONAL TECHNOLOGIES SPANNING OVER SEVERAL SECTIONS OF THE IPC; TECHNICAL SUBJECTS COVERED BY FORMER USPC CROSS-REFERENCE ART COLLECTIONS [XRACs] AND DIGESTS
- Y02—TECHNOLOGIES OR APPLICATIONS FOR MITIGATION OR ADAPTATION AGAINST CLIMATE CHANGE
- Y02D—CLIMATE CHANGE MITIGATION TECHNOLOGIES IN INFORMATION AND COMMUNICATION TECHNOLOGIES [ICT], I.E. INFORMATION AND COMMUNICATION TECHNOLOGIES AIMING AT THE REDUCTION OF THEIR OWN ENERGY USE
- Y02D30/00—Reducing energy consumption in communication networks
- Y02D30/50—Reducing energy consumption in communication networks in wire-line communication networks, e.g. low power modes or reduced link rate
Landscapes
- Engineering & Computer Science (AREA)
- Computer Security & Cryptography (AREA)
- Computer Networks & Wireless Communication (AREA)
- Signal Processing (AREA)
- Data Exchanges In Wide-Area Networks (AREA)
Abstract
本发明公开了一种面向内容访问的IP‑NDN互通方法、系统、设备及存储介质,它们是一一对应的方案,其中方法方案中,通过运行TCP/IP协议框架与NDN协议框架的互通网关能够实现IP客户端与NDN服务端的互通,打通了在异构网络之间进行消息传输的壁垒,使得用户在网页浏览、观看多媒体视频等实际使用场景中能够实现NDN网络与传统IP网络的高性能互相通信,用户在搭建网络环境时可以将先进的NDN网络架构部署在传统的TCP/IP网络环境中,使用户既能够获得NDN带来的网络性能提升,又能跨网络获取内容,充分利用新的网络架构带来的性能提升,从而提高网络性能和用户的使用感受。
Description
技术领域
本发明涉及信息技术领域,尤其涉及一种面向内容访问的IP-NDN互通方法、系统、设备及存储介质。
背景技术
随着互联网行业的不断发展,传统的以TCP/IP协议(传输控制协议/网际协议)栈为主的互联网体系已经暴露出一些固有的问题和局限。为解决现有网络问题而提出的ICN网络(信息中心网络)通信模型将传统的以主机为中心的网络转变为以信息为中心的新网络。
NDN网络(命名数据网络)是基于ICN思想的一个重要网络架构,在NDN网络中,用户可以发送仅指定内容名称的请求,而无需知道内容在网络中的位置,这是对网络架构的一次根本性的改进和创新。与传统网络相比,NDN网络在可扩展性、可管可控性、安全性、移动性、节能等方面具有显著的优势。
目前TCP/IP网络已经非常成熟,网络架构的变革无法轻易实现,因此研究NDN与TCP/IP网络的融合问题是网络架构演进的重要一步。
现有互通方案及其存在主要问题如下:1)根据配置文件实现翻译的互通网关,它的问题在于:名字需要由互通网关生成、分配和同步;仅能根据已有配置文件进行处理,无法加入新的客户端和内容源;并且,仅试验了简单聊天场景,没有处理长数据及执行实际任务的能力。2)DOCTOR项目:将NDN与NFV(虚拟网络功能)结合,基于网络捕获和监控工具实现的NDN-HTTP(超文本传输协议)互通方案,它的问题在于:构建较为复杂,需要开发NDN虚拟化架构;需要在网络中部署OpenvSwitch(开放虚拟交换标准);一个大的HTTP请求对应较多NDN分片,引起较大时延。3)iGate项目(在IP网络中建立NDN的通信隧道的方式实现互通),它的问题在于:客户端和内容服务器必须部署在NDN网络。总体而言,以上现有互通方案的各项性能还有待提升。
发明内容
本发明的目的是提供一种面向内容访问的IP-NDN互通方法、系统、设备及存储介质,使得用户在网页浏览、观看多媒体视频等实际使用场景中能够实现NDN网络与传统IP网络的高性能互相通信,使愿意部署新一代网络架构的用户既能够获得NDN带来的网络性能提升,又能跨网络获取内容,是研究新一代信息中心网络的必经之路。
本发明的目的是通过以下技术方案实现的:
一种面向内容访问的IP-NDN互通方法,包括:
运行TCP/IP协议框架与NDN协议框架;其中,所述TCP/IP协议为传输控制协议/网际协议,NDN协议为信息中心网络协议;
通过所述TCP/IP协议框架,接收来自IP网络的请求报文,并进行解析;通过调度器构建并维护请求队列与发送队列,调度器利用请求报文的解析结果在内容缓存单元中查询相应的响应报文,若查询到相应的响应报文,则将相应的响应报文加入发送队列,若未查询到相应的响应报文,则结合请求报文的解析结果封装为请求实体,并将请求实体加入请求队列,以及使用调度算法决策出下一个处理的请求实体;通过翻译机将下一个处理的请求实体转换为NDN标准的名字,经请求处理程序处理后传输至NDN协议框架,再由NDN协议框架将NDN标准的名字封装为NDN兴趣包后,向NDN网络发送,以及接收所述NDN网络反馈的NDN数据包,并将NDN数据包解析后交由请求处理程序,由所述请求处理程序生成分片名字并按照分片将数据包拼接为完整的内容数据体;通过所述翻译机将所述完整的内容数据体翻译为响应报文后存入内容缓存单元中,并由调度器从内容缓存单元中提取相应的响应报文,加入发送队列;由所述TCP/IP协议框架按照发送队列的顺序将响应报文通过IP网络向外发送。
一种面向内容访问的IP-NDN互通系统,包括:TCP/IP协议框架、NDN协议框架、调度器、翻译机、以及请求处理程序;其中:
通过所述TCP/IP协议框架,接收来自IP网络的请求报文,并进行解析;通过调度器构建并维护请求队列与发送队列,调度器利用请求报文的解析结果在内容缓存单元中查询相应的响应报文,若查询到相应的响应报文,则将相应的响应报文加入发送队列,若未查询到相应的响应报文,则结合请求报文的解析结果封装为请求实体,并将请求实体加入请求队列,以及使用调度算法决策出下一个处理的请求实体;通过翻译机将下一个处理的请求实体转换为NDN标准的名字,经请求处理程序处理后传输至NDN协议框架,再由NDN协议框架将NDN标准的名字封装为NDN兴趣包后,向NDN网络发送,以及接收所述NDN网络反馈的NDN数据包,并将NDN数据包解析后交由请求处理程序,由所述请求处理程序生成分片名字并将按照分片将数据包拼接为完整的内容数据体;通过所述翻译机将所述完整的内容数据体翻译为响应报文后存入内容缓存单元中,并由调度器从内容缓存单元中提取相应的响应报文,加入发送队列;由所述TCP/IP协议框架按照发送队列的顺序将响应报文通过IP网络向外发送。
一种处理设备,包括:一个或多个处理器;存储器,用于存储一个或多个程序;
其中,当所述一个或多个程序被所述一个或多个处理器执行时,使得所述一个或多个处理器实现前述的方法。
一种可读存储介质,存储有计算机程序,当计算机程序被处理器执行时实现前述的方法。
由上述本发明提供的技术方案可以看出,打通了在异构网络之间进行消息传输的壁垒,用户在搭建网络环境时可以将先进的NDN网络架构部署在传统的TCP/IP网络环境中,充分利用新的网络架构带来的性能提升,从而提高网络性能和用户的使用感受。
附图说明
为了更清楚地说明本发明实施例的技术方案,下面将对实施例描述中所需要使用的附图作简单地介绍,显而易见地,下面描述中的附图仅仅是本发明的一些实施例,对于本领域的普通技术人员来讲,在不付出创造性劳动的前提下,还可以根据这些附图获得其他附图。
图1为本发明实施例提供的一种面向内容访问的IP-NDN互通方法的框架示意图;
图2为本发明实施例提供的调度器调度过程示意图;
图3为本发明实施例提供的请求聚合过程示意图。
具体实施方式
下面结合本发明实施例中的附图,对本发明实施例中的技术方案进行清楚、完整地描述,显然,所描述的实施例仅仅是本发明一部分实施例,而不是全部的实施例。基于本发明的实施例,本领域普通技术人员在没有做出创造性劳动前提下所获得的所有其他实施例,都属于本发明的保护范围。
首先对本文中可能使用的术语进行如下说明:
术语“包括”、“包含”、“含有”、“具有”或其它类似语义的描述,应被解释为非排它性的包括。例如:包括某技术特征要素(如原料、组分、成分、载体、剂型、材料、尺寸、零件、部件、机构、装置、步骤、工序、方法、反应条件、加工条件、参数、算法、信号、数据、产品或制品等),应被解释为不仅包括明确列出的某技术特征要素,还可以包括未明确列出的本领域公知的其它技术特征要素。
下面对本发明所提供的一种面向内容访问的IP-NDN互通方法、系统、设备及存储介质进行详细描述。本发明实施例中未作详细描述的内容属于本领域专业技术人员公知的现有技术。本发明实施例中未注明具体条件者,按照本领域常规条件或制造商建议的条件进行。
实施例一
本发明实施例提供一种面向内容访问的IP-NDN互通方法,该方法主要包括:运行TCP/IP协议框架与NDN协议框架;通过所述TCP/IP协议框架,接收来自IP网络的请求报文,并进行解析;通过调度器构建并维护请求队列与发送队列,调度器利用请求报文的解析结果在内容缓存单元中查询相应的响应报文,若查询到相应的响应报文,则将相应的响应报文加入发送队列,若未查询到相应的响应报文,则结合请求报文的解析结果封装为请求实体,并将请求实体加入请求队列,以及使用调度算法决策出下一个处理的请求实体;通过翻译机将下一个处理的请求实体转换为NDN标准的名字,经请求处理程序处理后传输至NDN协议框架,再由NDN协议框架将NDN标准的名字封装为NDN兴趣包后,通过NDN端口向NDN网络中发送NDN兴趣包,以及接收所述NDN网络反馈的NDN数据包,并将NDN数据包解析后交由请求处理程序,由所述请求处理程序生成分片名字并按照分片将数据包拼接为完整的内容数据体;通过所述翻译机将所述完整的内容数据体翻译为响应报文后存入内容缓存单元中,并由调度器从内容缓存单元中提取相应的响应报文,加入发送队列;由所述TCP/IP协议框架按照发送队列的顺序将响应报文通过IP网络向外发送。
如图1所示,展示了上述方法的整体框架,中间部分为互通网关,能够实现左侧IP客户端与右侧NDN服务端的互通,中间部分的互通网关运行了TCP/IP协议框架与NDN协议框架,还设有调度器、翻译机、请求处理程序等。示例性的,可以在Linux操作系统之上运行TCP/IP网络协议栈,安装ndn-cxx 0.7.0程序库,安装对应的NFD 0.7.0程序,在IP客户端与互通网关之间建立TCP连接,在互通网关、NDN中间节点(NDN网络中非内容服务器的其它设备)与内容服务器(DND服务端)之间搭建NDN网络环境。互通网关程序以实施环境为基础构建请求队列、调度器、翻译机等结构和单元。
下面针对实现IP-NDN互通过程中所涉及的所有部分及其工作流程做详细的介绍。
一、TCP/IP协议框架。
本发明实施例中,运行的TCP/IP协议框架,可通过网络端口在IP网络中传递报文(包含请求报文与响应报文)。在所述互通网关运行TCP/IP协议框架后,当IP客户端发起连接请求时与IP客户端建立连接,将响应报文发往IP客户端主机,接收IP客户端主机发送的请求报文(HTTP报文),完成全部传输过程后切段连接。
示例性的,可以将互通网关地址设置为192.168.1.1,IP客户端地址设置为192.168.1.2、192.168.1.3、192.168.1.4等。将网页浏览作为实施场景,所浏览的网页包含文字内容、图片内容、视频内容,IP客户端使用网页浏览器,浏览器访问192.168.1.1/index.html,将浏览请求发送至互通网关,互通网关在获取内容后将响应报文发回至IP客户端。
如图1所示,所述TCP/IP协议框架包括:端口(网络端口)以及HTTP解析器。
所述端口主要负责实现TCP/IP协议框架与IP客户端的数据交互。HTTP(超文本传输协议)解析器主要负责请求报文的解析工作,具体的,可以对请求报文的首部字段进行解析,获得统一资源定位符(URL)与报文首部的字段值。
示例性的, HTTP 解析器可以调用http_parser工具(一种HTTP 解析工具),将从传输层获取的原始HTTP报文进行解析完毕后获得URL及多个首部字段信息。
二、调度器。
本发明实施例中,所述调度器主要负责构建请求队列与发送队列,以及实现请求聚合、请求调度、请求分发等工作。
1、构建与维护请求队列。
本发明实施例中,调度器构建请求队列,如果利用请求报文的解析结果在内容缓存单元中未查询到相应的响应报文,则将请求报文的解析结果封装为请求实体,具体的:则按照系统时间、报文首部的字段值中的优先级字段以及网络信息封装为请求实体,并将请求实体加入请求队列。
本发明实施例中,在初始化时初始化了空的请求队列,开始工作后,收到IP客户端发来的请求报文,通过HTTP解析器解析得到URL(例如:192.168.1.1/index.html),在与时间、优先级、对端网络信息共同封装为请求实体,放入请求队列,在收到多个IP客户端的多个请求报文后按照相同的处理方式放入请求队列。
2、请求调度与请求分发。
本发明实施例中,所述调度器,用于使用调度算法决策出下一个处理的请求实体。
本发明实施例中,调度器选择优先级与先来先服务结合的调度算法进行调度,从请求队列中拉取到了相应的请求实体,并通过翻译机翻译后发送给请求处理成程序。
本发明实施例中,调度算法的输入包括:请求队列中请求实体、用户对之前传输过程的反馈信息、网关自身的系统参数等,由调度算法进行决策,最终实现效率优化和用户使用感受的提升。
具体的,调度算法以请求报文的接收时间作为初始判断依据,结合系统参数(例如系统时间、操作系统类型、NDN版本号等等)、请求报文中的网络信息(速率、带宽、吞吐量、时延等)计算出各请求报文的优先级,结合请求报文的优先级与最短任务优先(SJF)算法,计算出各个请求报文的调度参数值(Rank值),按照调度参数值由高到低的顺序决策出下一个处理的请求实体。如图2所示,展示了调度器的请求调度过程示意图,决策出下一个处理的请求实体后通过翻译机处理为NDN标准的名字再发送至请求处理程序,图2省略了翻译机。
3、请求聚合。
如之前所述,调度器利用请求报文的解析结果在内容缓存单元中查询相应的响应报文,若查询到相应的响应报文,则将相应的响应报文加入发送队列,从而实现请求聚合;具体的:可以使用基于URL的匹配查找,将URL字符串作为键值,收到请求报文并完成解析获取到URL后在内容缓存中进行查找,当缓存命中后跳过之后的报文转换等操作并直接将响应报文发送回IP客户端,缓存没有命中则将解析结果封装为请求实体并加入请求队列等待调度器对其进行调度,图3展示了请求聚合的主要过程。
示例性的:将URL字符串作为键,以192.168.1.1/index.html为例,请求处理程序得到完整的响应报文后放入该键对应的缓存中,当再次收到URL为 192.168.1.1/index.html的请求报文时,请求聚合模块先在缓存中进行查找,缓存命中后将响应报文直接发送回IP客户端。
4、构建与维护发送队列。
本发明实施例中,调度器还需要构建与维护发送队列,发送队列中的信息为来自内容缓存的响应报文,将发送队列中的响应报文按照顺序传输至TCP/IP协议框架。
三、翻译机。
本发明实施例中,所述翻译机主要负责两部分翻译工作:1、用于将下一个处理的请求实体转换为NDN标准的名字。2、将完整的内容数据体(具体在后文介绍)翻译为响应报文后存入内容缓存单元。
1、将请求实体转换为NDN标准的名字。
本发明实施例中,结合请求实体中包含的统一资源定位符、从所述NDN协议框架获取的需要拼接至名字中的信息(由不同的应用程序来决定,本发明不做限定),以及从本地(互通网关)操作系统中获取的信息,将请求实体转换为NDN标准的名字,NDN标准的名字是指符合NDN协议标准的名字格式。
本发明实施例中,操作系统是指互通网关上运行的操作系统,例如,可以为Linux操作系统,当然也可以其他类型的操作系统。
示例性的,如果URL为192.168.1.1/video.mp4,则映射为名字/example/home/web_file/video.mp4,获取映射关系后建立映射表,在表内动态地填充不同网络协议的报文格式中所需的必要字段,构成NDN标准的名字。
2、将完整的内容数据体翻译为响应报文后存入内容缓存单元。
所述完整的内容数据体是请求处理程序拼接获得的数据,具体将在后文进行介绍,此部分翻译主要是将完整的内容数据体翻译为IP客户端可以识别的信息,也就是前文所述的响应报文。
四、请求处理程序。
本发明实施例中,请求处理程序,用于将NDN标准的名字封装为元数据兴趣包,通过NDN协议框架获取元数据数据包,并从中读取元数据数据体;计算元数据数据体中内容数据的总分片数n,利用所述NDN标准的名字制作n个分片名字,封装成n个分片数据的兴趣包,再通过NDN协议框架获取分片数据的数据包,从中读取对应分片数据的数据体,按照分片顺序将分片数据的数据体拼接成完整的内容数据体,再调用翻译机将所述完整的数据体转换为响应报文。此处的元数据兴趣包与分片数据的兴趣包均属于NDN兴趣包,元数据数据包与分片数据的数据包均属于NDN数据包。
本发明实施例中,加密与解密是NDN协议框架提供的功能,主要用于请求处理程序与NDN协议框架之间数据信息的加密与解密。可以根据实际情况选择相应的内容加密算法,例如,可使用3DES加密算法进行加密和解密。
此次部分的主要工作流程如下:
1)请求处理程序从NDN协议框架中获取NDN报文相关信息(例如,NDN报文的存活时间、跳数限制、复用次数等),将NDN标准的名字与获得的NDN报文相关信息一起,按照NDN协议规定的格式(TLV格式)封装成元数据兴趣包,加密后发送至NDN协议框架。
2)NDN协议框架通过NDN网络向NDN服务端发送加密的元数据兴趣包,获得元数据数据包,由NDN解析器解析后写入数据队列,并依次反馈给请求处理程序。
3)请求处理程序接收NDN协议框架反馈的元数据数据包解析结果后进行解密,获得元数据数据体,在元数据数据体中读取内容数据的数据大小、格式、版本号、优先级等信息。
4)请求处理程序计算内容数据的总分片数目n,利用NDN标准的名字制作n个分片名字,将每个分片名字分别与NDN报文相关信息一起,按照NDN协议规定的格式封装成分片数据的兴趣包(数目为n),加密后发送至NDN协议框架。此处所有分片名字的前缀相同,为NDN标准的名字拼接格式、版本号、优先级号,分片名字的后缀为分片序号,分片序号为数字1到n。
5)NDN协议框架通过NDN网络向NDN服务端发送所有加密的分片数据的兴趣包,获得分片数据的数据包,由NDN解析器解析后写入数据队列,并依次反馈给请求处理程序。
6)请求处理程序接收NDN协议框架反馈的分片数据的数据包的解析结果后进行解密,读取出分片数据的数据体,按照分片顺序将分片数据的数据体拼接成完整的内容数据体,如果缺少某个分片数据的数据体,则请求处理程序向NDN协议框架重新发送相应的加密的分片数据的兴趣包。
7)请求处理程度调用翻译机将完整的内容数据体翻译为响应报文。
示例性的:若计算的分片数量为5,则根据分片总数依次生成名字/example/home/web_file/video.mp4/segno.x,此处的segno.x表示分片序号,x取1至5这五个数,分别组装为分片兴趣包向NDN网络请求数据,接收到同一内容的不同分片的数据包后,发现某个序号(例如,序号3)的数据包丢包,对其进行丢包重传,待全部分片都收到后对分片进行排序,将排好序的分片去除非必要字段后将内容拼接成完整的内容数据体。
本发明实施例中,需要将所述完整的内容数据体转换为响应报文,具体的,在所述完整的数据体添加首部字段(按照HTTP协议的要求添加),获得响应报文。示例性的,根据映射表找到目的请求URL或名字,抽取必要的信息,根据HTTP或NDN报文格式进行填充和组装。
五、内容缓存单元。
本发明实施例中,所述内容缓存单元,用于存储响应报文,以及根据调度器的指令将相应的响应报文加入发送队列。
六、NDN协议框架。
本发明实施例中,NDN协议框架可通过常规技术实现,在互通网关上运行NDN协议及其下层协议,不同的NDN实现方式其下层协议是不同的,因此,可以根据实际情况选择相应的下层协议,本发明不做限定;运行NDN协议所需的PIT(pending interest table,未决请求表)、FIB(forwarding information base,转发信息库)、CS(content store,内容存储库)三个结构,将名字封装为NDN兴趣包向NDN网络中发送。
上述PIT、FIB、CS均为NDN协议中已有的结构,本发明不赘述。
本发明实施例中,可以在互通网关的终端界面输入NFD启动命令,在需要建立NDN连接的主机(内容服务器)之间输入与对方建立连接的命令,并输入nfdc register /example udp://192.168.1.1命令来注册名字前缀。在内容服务器(NDN服务端)之上运行专门编写的服务程序响应特定内容的名字并返回封装和加密好的数据包。
本发明实施例提供的一种面向内容访问的IP-NDN互通方法,打通了在异构网络之间进行消息传输的壁垒,用户在搭建网络环境时可以将先进的NDN网络架构部署在传统的TCP/IP网络环境中,充分利用新的网络架构带来的性能提升,从而提高网络性能和用户的使用感受。
实施例二
本发明还提供一种面向内容访问的IP-NDN互通系统,其主要基于前述实施例提供的方法实现,还可参见前述图1,该系统即为中间部分的互通网关,主要包括:TCP/IP协议框架、NDN协议框架、调度器、翻译机、以及请求处理程序;其中:
通过所述TCP/IP协议框架,接收来自IP网络的请求报文,并进行解析;通过调度器构建并维护请求队列与发送队列,调度器利用请求报文的解析结果在内容缓存单元中查询相应的响应报文,若查询到相应的响应报文,则将相应的响应报文加入发送队列,若未查询到相应的响应报文,则结合请求报文的解析结果封装为请求实体,并将请求实体加入请求队列,以及使用调度算法决策出下一个处理的请求实体;通过翻译机将下一个处理的请求实体转换为NDN标准的名字,经请求处理程序处理后传输至NDN协议框架,再由NDN协议框架将NDN标准的名字封装为NDN兴趣包后,向NDN网络发送,以及接收所述NDN网络反馈的NDN数据包,并将NDN数据包解析后交由请求处理程序,由所述请求处理程序生成分片名字并将按照分片将数据包拼接为完整的内容数据体;通过所述翻译机将所述完整的内容数据体翻译为响应报文后存入内容缓存单元中,并由调度器从内容缓存单元中提取相应的响应报文,加入发送队列;由所述TCP/IP协议框架按照发送队列的顺序将响应报文通过IP网络向外发送。
所属领域的技术人员可以清楚地了解到,为描述的方便和简洁,仅以上述各功能模块的划分进行举例说明,实际应用中,可以根据需要而将上述功能分配由不同的功能模块完成,即将系统的内部结构划分成不同的功能模块,以完成以上描述的全部或者部分功能。
实施例三
本发明还提供一种处理设备,其主要包括:一个或多个处理器;存储器,用于存储一个或多个程序;其中,当所述一个或多个程序被所述一个或多个处理器执行时,使得所述一个或多个处理器实现前述实施例提供的方法。
进一步的,所述处理设备还包括至少一个输入设备与至少一个输出设备;在所述处理设备中,处理器、存储器、输入设备、输出设备之间通过总线连接。
本发明实施例中,所述存储器、输入设备与输出设备的具体类型不做限定;例如:
输入设备可以为触摸屏、图像采集设备、物理按键或者鼠标等;
输出设备可以为显示终端;
存储器可以为随机存取存储器(Random Access Memory,RAM),也可为非不稳定的存储器(non-volatile memory),例如磁盘存储器。
实施例四
本发明还提供一种可读存储介质,存储有计算机程序,当计算机程序被处理器执行时实现前述实施例提供的方法。
本发明实施例中可读存储介质作为计算机可读存储介质,可以设置于前述处理设备中,例如,作为处理设备中的存储器。此外,所述可读存储介质也可以是U盘、移动硬盘、只读存储器(Read-Only Memory,ROM)、磁碟或者光盘等各种可以存储程序代码的介质。
以上所述,仅为本发明较佳的具体实施方式,但本发明的保护范围并不局限于此,任何熟悉本技术领域的技术人员在本发明披露的技术范围内,可轻易想到的变化或替换,都应涵盖在本发明的保护范围之内。因此,本发明的保护范围应该以权利要求书的保护范围为准。
Claims (9)
1.一种面向内容访问的IP-NDN互通方法,其特征在于,包括:
运行TCP/IP协议框架与NDN协议框架;其中,所述TCP/IP协议为传输控制协议/网际协议,NDN协议为信息中心网络协议;
通过所述TCP/IP协议框架,接收来自IP网络的请求报文,并进行解析;通过调度器构建并维护请求队列与发送队列,调度器利用请求报文的解析结果在内容缓存单元中查询相应的响应报文,若查询到相应的响应报文,则将相应的响应报文加入发送队列,若未查询到相应的响应报文,则结合请求报文的解析结果封装为请求实体,并将请求实体加入请求队列,以及使用调度算法决策出下一个处理的请求实体;通过翻译机将下一个处理的请求实体转换为NDN标准的名字,经请求处理程序处理后传输至NDN协议框架,再由NDN协议框架将NDN标准的名字封装为NDN兴趣包后,向NDN网络发送,以及接收所述NDN网络反馈的NDN数据包,并将NDN数据包解析后交由请求处理程序,由所述请求处理程序生成分片名字并按照分片将数据包拼接为完整的内容数据体;通过所述翻译机将所述完整的内容数据体翻译为响应报文后存入内容缓存单元中,并由调度器从内容缓存单元中提取相应的响应报文,加入发送队列;由所述TCP/IP协议框架按照发送队列的顺序将响应报文通过IP网络向外发送;
请求处理程序的工作流程包括:将NDN标准的名字封装为元数据兴趣包,通过NDN协议框架获取元数据数据包,并从中读取元数据数据体;计算元数据数据体中内容数据的总分片数n,利用所述NDN标准的名字制作n个分片名字,封装成n个分片数据的兴趣包,再通过NDN协议框架获取分片数据的数据包,从中读取对应分片数据的数据体,按照分片顺序将分片数据的数据体拼接成完整的内容数据体,再调用翻译机将所述完整的数据体转换为响应报文;此处的元数据兴趣包与分片数据的兴趣包均属于NDN兴趣包,元数据数据包与分片数据的数据包均属于NDN数据包。
2.根据权利要求1所述的一种面向内容访问的IP-NDN互通方法,其特征在于,所述TCP/IP协议框架包括:端口以及HTTP解析器;其中,所述端口负责实现TCP/IP协议框架与IP客户端的数据交互;HTTP解析器为超文本传输协议解析器,负责解析请求报文。
3.根据权利要求1所述的一种面向内容访问的IP-NDN互通方法,其特征在于,所述调度器负责构建请求队列与发送队列,以及实现请求聚合、请求调度与请求分发;其中,
构建与维护请求队列:调度器构建请求队列,若利用请求报文的解析结果在内容缓存单元中未查询到相应的响应报文,则将请求报文的解析结果封装为请求实体,并将请求实体加入请求队列;
请求调度与请求分发:调度器使用调度算法决策出下一个处理的请求实体,并发送给翻译机;
请求聚合:调度器利用请求报文的解析结果在内容缓存单元中查询相应的响应报文,若查询到相应的响应报文,则将相应的响应报文加入发送队列,实现请求聚合;
构建与维护发送队列:调度器构建发送队列,发送队列中的信息为来自内容缓存的响应报文,将发送队列中的响应报文按照顺序传输至TCP/IP协议框架。
4.根据权利要求3所述的一种面向内容访问的IP-NDN互通方法,其特征在于,所述使用调度算法决策出下一个处理的请求实体包括:
调度算法以请求报文的接收时间作为初始判断依据,结合系统参数、请求报文中的网络信息计算出请求报文的优先级,结合请求报文的优先级与最短任务优先算法,计算出各个请求报文的调度参数值,按照调度参数值由高到低的顺序决策出下一个处理的请求实体。
5.根据权利要求1所述的一种面向内容访问的IP-NDN互通方法,其特征在于,翻译机将下一个处理的请求实体转换为NDN标准的名字包括:结合请求实体中包含的统一资源定位符、从所述NDN协议框架获取的需要拼接至名字中的信息,以及从本地操作系统中获取的信息,将请求实体转换为NDN标准的名字,NDN标准的名字是指符合NDN协议标准的名字格式。
6.根据权利要求1所述的一种面向内容访问的IP-NDN互通方法,其特征在于,
所述将NDN标准的名字封装为元数据兴趣包,通过NDN协议框架获取元数据数据包,并从中读取元数据数据体包括:从NDN协议框架中获取NDN报文相关信息,将NDN标准的名字与获得的NDN报文相关信息一起,按照NDN协议规定的格式封装成元数据兴趣包,加密后发送至NDN协议框架;接收NDN协议框架反馈的元数据数据包解析结果后进行解密,获得元数据数据体;
所述利用所述NDN标准的名字制作n个分片名字,封装成n个分片数据的兴趣包,再通过NDN协议框架获取分片数据的数据包,从中读取对应分片数据的数据体,按照分片顺序将分片数据的数据体拼接成完整的内容数据体包括:利用NDN标准的名字制作n个分片名字,将每个分片名字分别与NDN报文相关信息一起,按照NDN协议规定的格式封装成分片数据的兴趣包,加密后发送至NDN协议框架;接收NDN协议框架反馈的分片数据的数据包的解析结果,读取出分片数据的数据体,按照分片顺序将分片数据的数据体拼接成完整的内容数据体,如果缺少某个分片数据的数据体,则请求处理程序向NDN协议框架重新发送相应的加密的分片数据的兴趣包。
7.一种面向内容访问的IP-NDN互通系统,其特征在于,基于权利要求1~6任一项所述的方法实现,该系统包括:TCP/IP协议框架、NDN协议框架、调度器、翻译机、以及请求处理程序;其中:
通过所述TCP/IP协议框架,接收来自IP网络的请求报文,并进行解析;通过调度器构建并维护请求队列与发送队列,调度器利用请求报文的解析结果在内容缓存单元中查询相应的响应报文,若查询到相应的响应报文,则将相应的响应报文加入发送队列,若未查询到相应的响应报文,则结合请求报文的解析结果封装为请求实体,并将请求实体加入请求队列,以及使用调度算法决策出下一个处理的请求实体;通过翻译机将下一个处理的请求实体转换为NDN标准的名字,经请求处理程序处理后传输至NDN协议框架,再由NDN协议框架将NDN标准的名字封装为NDN兴趣包后,向NDN网络发送,以及接收所述NDN网络反馈的NDN数据包,并将NDN数据包解析后交由请求处理程序,由所述请求处理程序生成分片名字并将按照分片将数据包拼接为完整的内容数据体;通过所述翻译机将所述完整的内容数据体翻译为响应报文后存入内容缓存单元中,并由调度器从内容缓存单元中提取相应的响应报文,加入发送队列;由所述TCP/IP协议框架按照发送队列的顺序将响应报文通过IP网络向外发送。
8.一种处理设备,其特征在于,包括:一个或多个处理器;存储器,用于存储一个或多个程序;
其中,当所述一个或多个程序被所述一个或多个处理器执行时,使得所述一个或多个处理器实现如权利要求1~6任一项所述的方法。
9.一种可读存储介质,存储有计算机程序,其特征在于,当计算机程序被处理器执行时实现如权利要求1~6任一项所述的方法。
Priority Applications (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN202211588540.7A CN115580666B (zh) | 2022-12-12 | 2022-12-12 | 面向内容访问的ip-ndn互通方法、系统、设备及存储介质 |
Applications Claiming Priority (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN202211588540.7A CN115580666B (zh) | 2022-12-12 | 2022-12-12 | 面向内容访问的ip-ndn互通方法、系统、设备及存储介质 |
Publications (2)
Publication Number | Publication Date |
---|---|
CN115580666A CN115580666A (zh) | 2023-01-06 |
CN115580666B true CN115580666B (zh) | 2023-03-10 |
Family
ID=84590465
Family Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
CN202211588540.7A Active CN115580666B (zh) | 2022-12-12 | 2022-12-12 | 面向内容访问的ip-ndn互通方法、系统、设备及存储介质 |
Country Status (1)
Country | Link |
---|---|
CN (1) | CN115580666B (zh) |
Families Citing this family (1)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN117499178A (zh) * | 2024-01-02 | 2024-02-02 | 中国科学技术大学 | 一种ip网络和icn网络融合方法与系统 |
Citations (6)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN103237024A (zh) * | 2013-04-19 | 2013-08-07 | 北京大学深圳研究生院 | Tcp/ip协议与ndn协议之间的数据转换传输方法 |
CN104967677A (zh) * | 2015-06-05 | 2015-10-07 | 无锡量子云数字新媒体科技有限公司 | 一种基于ndn缓存优化的文件传输方法以及装置 |
CN107634935A (zh) * | 2017-08-11 | 2018-01-26 | 北京大学深圳研究生院 | 一种ndn和ip融合网络的内容管控方法、装置及存储介质 |
CN110177098A (zh) * | 2019-05-28 | 2019-08-27 | 北京理工大学 | Ndn与ip网络边界网关转换方法和装置 |
CN110505300A (zh) * | 2019-08-23 | 2019-11-26 | 中山大学 | 一种ip网络与命名数据网络混合的新型链式代理方法 |
CN111611613A (zh) * | 2020-04-28 | 2020-09-01 | 网络通信与安全紫金山实验室 | 基于icn的工业互联网标识解析系统及数据访问方法 |
Family Cites Families (4)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN104901860B (zh) * | 2014-03-04 | 2018-03-23 | 中国科学院声学研究所 | 一种ndn与cdn互联互通的系统及方法 |
US10356209B2 (en) * | 2015-11-30 | 2019-07-16 | Futurewei Technologies, Inc. | System and method to support context-aware content requests in information centric networks |
US20190132282A1 (en) * | 2017-08-11 | 2019-05-02 | Peking University Shenzhen Graduate School | Ndn and ip fusion network content control method and apparatus, and storage medium |
CN108259337B (zh) * | 2017-12-20 | 2021-01-19 | 广东技术师范大学 | 一种基于兴趣网络分片的icn路由方法及系统 |
-
2022
- 2022-12-12 CN CN202211588540.7A patent/CN115580666B/zh active Active
Patent Citations (6)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN103237024A (zh) * | 2013-04-19 | 2013-08-07 | 北京大学深圳研究生院 | Tcp/ip协议与ndn协议之间的数据转换传输方法 |
CN104967677A (zh) * | 2015-06-05 | 2015-10-07 | 无锡量子云数字新媒体科技有限公司 | 一种基于ndn缓存优化的文件传输方法以及装置 |
CN107634935A (zh) * | 2017-08-11 | 2018-01-26 | 北京大学深圳研究生院 | 一种ndn和ip融合网络的内容管控方法、装置及存储介质 |
CN110177098A (zh) * | 2019-05-28 | 2019-08-27 | 北京理工大学 | Ndn与ip网络边界网关转换方法和装置 |
CN110505300A (zh) * | 2019-08-23 | 2019-11-26 | 中山大学 | 一种ip网络与命名数据网络混合的新型链式代理方法 |
CN111611613A (zh) * | 2020-04-28 | 2020-09-01 | 网络通信与安全紫金山实验室 | 基于icn的工业互联网标识解析系统及数据访问方法 |
Non-Patent Citations (3)
Title |
---|
NDMANET中基于内容优先级的缓存策略研究;高子轩,郑烇;《计算机工程》;全文 * |
一种命名数据网络的视频全域协作缓存算法;胡亚萍等;《计算机工程》(第05期);全文 * |
命名数据网络中VIP转发方案的性能优化;金洋,吕金阳,谭小彬;《重庆邮电大学学报(自然科学版)》;全文 * |
Also Published As
Publication number | Publication date |
---|---|
CN115580666A (zh) | 2023-01-06 |
Similar Documents
Publication | Publication Date | Title |
---|---|---|
EP1364511B1 (en) | A digital television application protocol for interactive television | |
CN111294399B (zh) | 一种数据传输方法和装置 | |
Lampesberger | Technologies for web and cloud service interaction: a survey | |
AU2002240200A1 (en) | A digital television application protocol for interactive television | |
US11196833B1 (en) | Proxy server synchronizer | |
CN104468704B (zh) | 支持内容中心网络的Web服务器系统及处理方法 | |
CN106464596A (zh) | 开放流通信方法、系统、控制器和业务网关 | |
CN115580666B (zh) | 面向内容访问的ip-ndn互通方法、系统、设备及存储介质 | |
TWI646805B (zh) | 網路通訊協定轉譯系統及方法 | |
JP2017500679A (ja) | メディアリソースフィードバック方法、装置、プログラム及び記録媒体 | |
WO2024012001A1 (zh) | 一种在多模态网络中实现开源社区访问的方法及系统 | |
JP2002141954A (ja) | 通信中継装置、および通信中継方法、並びにプログラム記憶媒体 | |
CN113726895A (zh) | 文件传输方法、装置及网络ktv系统 | |
JP2004246747A (ja) | 既存サービスのラッピング方法および装置 | |
CN117176633A (zh) | 一种总线跨设备通信方法、装置、设备及存储介质 | |
JP6521762B2 (ja) | Httpサーバとその制御方法、画像形成装置およびプログラム | |
Kissel et al. | The extensible session protocol: A protocol for future internet architectures | |
US11929933B2 (en) | Ephemeral data stream routing service | |
CN116582590A (zh) | 数据传输方法及装置 | |
WO2016058401A1 (zh) | 一种超文本传输协议数据还原方法及装置 | |
JP2006018430A (ja) | 情報処理装置、ネットワークシステム、プログラム、データ構造及び記憶媒体 | |
JP2004192358A (ja) | 端末とセンタ側の装置との間で送受信を行うための双方向通信方式および双方向通信のためのプログラム | |
US6801531B1 (en) | Distributed processing system and method | |
JPH10326232A (ja) | 分散ネットワークコンピューティングシステム、同システムに用いられる情報交換装置、情報交換方法、及び記憶媒体 | |
JP2001167059A (ja) | サービス要求装置およびデータ変換方法およびクライアントオブジェクトを有する計算機 |
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 | ||
GR01 | Patent grant | ||
GR01 | Patent grant |