本发明涉及网络安全技术领域,尤其涉及一种基于sdn的工业无线网络安全路由方法。
背景技术:
随着无线技术的发展,以及工业生产规模越来越大并且工业设备的灵活性要求越来越高,所以工业无线网络越来越受各个领域的欢迎,并同时提出了工业无线网络标准,像zigbee无线标准、wirelesshart无线标准、wia-pa无线标准和isa100.11a无线标准。无线hart标准首次提出了三种工业无线网络路由,分别是图路由、源路由以及超帧路由,基本满足了专业环境下无线网络的需求,但这三种路由技术并没有一种路由技术能够同时解决网络运行时网络内部恶意节点发动恶意攻击问题和工业无线网络高实时性的路由要求问题。由于网络的灵活性越来越重要,传统网络架构已经不能满足现今的业务变化需求。为了解决问题,软件定义网络(sdn)被应用到无线网络中。随着工业化与信息化的两化融合,工业无线网络中生产设备越来越多,网络规模越来越趋于大规模化,同时工业无线网络处于常规工业生产车间或一些高干扰高危险性地区容易被恶意攻击入侵,这些都为工业无线网络安全带来了巨大的挑战。内部恶意攻击模型包括dos攻击、自私攻击、虫洞攻击、sinkhole攻击、on-off攻击、黑洞攻击以及智能行为攻击等,面对这些内部恶意攻击时传统的网络安全技术是不适合的,首先信息加密技术不适用于具有大量能源和计算能力有限节点的网络,其次,网络物理中间件以及传统网络协议安全技术可以抵御来自网络外部攻击,但无法检测网络内部恶意攻击。
所以亟需一种方法来解决传统网络安全技术无法解决内部攻击的安全问题。同时在面对网络内部恶意攻击时设计一种网络安全路由方法,能够快速的解决传统解决方案无法解决的np难问题,计算网络安全传输路径,找到一条高效可信的路径,安全传输信息。
技术实现要素:
针对上述现有技术的不足,本发明提供一种基于sdn的工业无线网络安全路由方法。
为解决上述技术问题,本发明所采取的技术方案是:一种基于sdn的工业无线网络安全路由方法,包括如下步骤:
步骤1:sdn架构中底层网络设备周期性上传节点自身运行参数至sdn架构中的网络控制器中;
步骤2:网络控制器中的安全认证模块对节点身份进行认证,对于身份认证成功的节点通过安全通道周期性上传节点运行状态参数;
步骤3:根据周期性上传的节点运行状态参数来计算节点的综合信任值,并生成节点的综合信任值时间序列,过程如下:
步骤3.1:网络控制器全局监测网络运行时的节点状态,根据周期性收集到的网络节点运行状态参数计算节点的近期信任值;
所述节点的近期信任值的计算过程如下:
步骤3.1.1:计算节点的近期信任值控制器收集节点发送率因子sfi、节点间通信频率因子cfi、节点转发率因子tfi、节点丢弃率因子dfi、节点剩余能量因子efi;
步骤3.1.2:控制器计算完近期信任值中五种计算因子后,采用加权平均方法计算节点的近期信任值或者调整节点的各个因子对应的权重数值,获得更合理的近期信任值。
所述调整节点的各个因子对应的权重数值,获得更合理的近期信任值的过程如下:
步骤3.1.2.1:各因子的权值采用模糊变权法来评估,就是在计算近期信任值时权重随各因子评估值改变的计算方法,其具体计算公式如下:
其中:um1,...,um(i-1),0,um(i 1),...,umn分别代表计算因子的权重,i,j=1,2,3,4,5;
设近期信任值计算的五种计算因子为ci(i=1,2,3,4,5),ci的权重为wi=(u1,u2,u3,u4,u5),(i=1,2,3,4,5),其中u1,u2,u3,u4,u5分别为5个计算因子c1,c2,c3,c4,c5的评价值,当ui为最大值um时,因子ci的评价值为最大值,说明因子ci处于最佳情况;当ui为0时,因子ci的评价值为最小值,说明因子ci完全失去作用;当各因子评价值均为最高值,总体计算情况为最佳时,因子ci的权重为wmi=wi(um,um,um,um,um),(i=1,2,3,4,5),wmi∈(0,1),
步骤3.1.2.2:为了对于任意因子,能够更加快速方便地求出wi=(u1,u2,u3,u4,u5),(i=1,2,3,4,5),构造一个计算函数,函数具体公式如下:
其中:λi(ui)则是为了快速计算权值引入的辅助函数,设计辅助函数时需要考虑该辅助函数一定得满足λi(0)=λ0i,λmi=wmi;
步骤3.1.2.3:当计算完各个因子的相应权值之后,节点vi在周期t时段内节点近期信任值ctvi(t)的计算公式可以定义为:
ctvi(t)=w1sfi(t) w2cfi(t) w3tfi(t) w4dfi(t) w5efi(t)
其中:wi∈(0,1),(i=1,2,3,4,5)分别为因子的加权系数,并且
步骤3.2:网络控制器存储节点各个周期性时间的历史综合信任值并记录到数据库中,计算网络中节点vi在周期t时段内的节点历史信任值;
所述节点历史信任值计算过程如下:
其中:tvi(t-j)为节点vi历史综合信任值,(t-j)为控制器中历史信任记录序列,γ为衰退值,反映出信任记录中的历史信任值随着时间的增长对当前节点历史信任值的计算所起到的作用在不断减小,η为权重,其值与信任记录中的历史信任值成反比,防止历史恶意行为随着时间被淹没。
步骤3.3:根据节点的近期信任值和历史信任值计算节点的当前的综合任值,并生成节点的综合信任值时间序列。
步骤4:设计相似度计算基准序列o,该序列作为网络中节点综合信任值时间序列的参考序列;采集节点vi的综合信任值时间序列,在连续的m个周期中综合信任值时间序列为ai={tvi(t1),tvi(t2),......,tvi(tm)},i=1,2,3......n;若
所述基准序列o的长度要与节点收集的综合信任值时间序列的长度相同,且基准序列是一个等值序列,所有值都为恶意节点判断阈值
步骤5:采用欧式距离计算方法计算节点的综合信任值时间序列与基准序列的相似度,并对网络中节点计算的相似度结果构成相似度数据集m;
步骤6:使用k-means算法对相似度数据集m进行聚类,分析聚类结构识别出恶意节点和亚攻击节点,过程如下:
步骤6.1:随机选出3个节点作为3个簇的初始中心,然后将剩余节点指定到离簇中心节点相似度最近的对应簇中;
步骤6.2:再随机的选取一个非中心点的节点作为备选,然后计算当使用这个备选节点作为簇中心点之后与步骤6.1相比是否会得到更佳的聚类结果;
步骤6.3:如果可以得到更佳的聚类结果则保存替换,得到新的分类簇,反之恢复原中心点;
步骤6.4:当不管中心点怎么替换聚类效果都不会提高时,结束聚类,将质心最大即最接近1的聚簇中心的相似度所对应的节点识别为亚攻击节点,即具有亚攻击性的智能攻击节点。
步骤7:根据网络拓扑g=(v,e)初始化网络节点的邻居节点集sn以及邻居链路集sli;其中,有向图g=(v,e)中使用v表示网络中节点的集合,而e则是用来代表网络中无线链路的集合;网络由控制器、正常节点、接入点、恶意节点包括亚攻击节点组成;
步骤8:初始化网络中无线链路质量dij和无线链路损耗指数e;
步骤9:控制器执行步骤1至步骤6识别出网络拓扑中的恶意节点和亚攻击节点,控制器在计算网络路由时会将这些恶意节点和亚攻击节点排除,保证网络传输数据的高度可信,控制器再结合节点的综合信任值计算选择路径,并设置参数集合用来存储最优的路由路径节点集,过程如下:
步骤9.1:根据绒泡菌的觅食过程建立数学模型,模拟多头绒泡菌在两个食物源的环境中的行为机制,将食物源作为网络中各个节点,绒泡菌的条状形体表示边,则每条管道中的流量数学模型公式如下:
其中:lij表示绒泡菌形体管道的长度,rij表示绒泡菌形体管道的半径,κ是绒泡菌形体管道内流体的粘滞系数,pi-pj表示流体在i点到j点的压力差,qij为每条管道中的流量;
步骤9.2:定义绒泡菌i点到j点的形体管道传导性为
步骤9.3:绒泡菌管状形体自适应调节,公式如下所示:
其中:z是绒泡菌形体管道的衰减率,f(|qij|)是一个单调并且递增的函数;绒泡菌的管状形体随着时间能够不断改变,当f(|qij|)=zdij时,表示,该绒泡菌管状形体是稳定的,不会随意改变形状,当f(|qij|)<zdij时,表示传导性下降,绒泡菌的管道半径在减小,反之,则半径增加,从而绒泡菌可以对自身的管状形体进行调节;
步骤9.4:使用工业无线网络中固有的链路质量d'ij替代形体管道传导性为dij;使用无线链路中无线传输时链路损耗指数
步骤9.5:用步骤9.4中替换后的变量改写步骤9.2中的公式,如下所示:
步骤9.6:控制器计算下一跳节点链路质量以及路径损耗指数是不随时间变化的,而潜势差随时间变化而变化,故可以通过δpij随时间的变化来获得控制器对路径的选择,公式如下:
其中,v是一个常数并且需要满足v>0;
步骤9.7:结合步骤9.5和步骤9.6,得到最终的计算公式如下:
控制器根据
步骤10:重复步骤9直到对所有节点完成最优路由计算,直到从源节点到目的节点之间有链路通信;
步骤11:控制器对记录最优路径的集合转发到各个网络节点;
步骤12:网络根据接受到的最优路径集合来转发数据。
采用上述技术方案所产生的有益效果在于:
1、本发明将工业无线网络模型与新型的sdn网络架构结合,改善了原有的工业无线网络无法根据网络全局运行状态以及网络资源实时制定路由的问题,大大提高了网络对资源以及时间的合理利用;
2、本发明提出的安全路由方法,该方法除了采用传统网络安全技术外,还使用了可信机制,控制器集中计算网络节点的信任值,根据信任值采用基于绒泡菌觅食启发的安全路由算法计算安全可信路由,来增强网络的安全性。
附图说明
图1为本发明实施例中基于sdn的工业无线网络安全路由方法的流程示意图;
图2为本发明实施例中安全路由方法具体设计框架图;
图3为本发明实施例中节点可信模型图;
图4为本发明实施例中网络节点的近期信任值计算因子分类图;
图5为本发明实施例中智能攻击特性图;
图6为本发明实施例中两种绒泡菌管体竞争食物图;
图7为本发明实施例中基于sdn的工业无线网络拓扑模型;
图8为本发明实施例中仿真拓扑图;
图9为本发明实施例中dos攻击下数据包交付率随时间变化趋势图;
图10为本发明实施例中dos攻击下平均端到端的延迟随时间变化趋势图;
图11为本发明实施例中自私攻击下数据包交付率随时间变化趋势图;
图12为本发明实施例中自私攻击下平均端到端的延迟随时间变化趋势图;
图13为本发明实施例中sinkhole攻击下数据包交付率随时间变化趋势图;
图14为本发明实施例中sinkhole攻击下平均端到端的延迟随时间变化趋势图
图15为本发明实施例中on-off攻击下数据包交付率随时间变化趋势图;
图16为本发明实施例中on-off攻击下平均端到端的延迟随时间变化趋势图。
具体实施方式
下面结合附图和实施例,对本发明的具体实施方式作进一步详细描述。以下实施例用于说明本发明,但不用来限制本发明的范围。
如图1所示,sdn架构中存在网络控制器,以及底层网络设备,其中,控制器中包含了安全路由机制中的信任模块(它包含了计算节点信任值和计算安全路由路径以及生成安全路由的转发策略等功能)、节点身份安全认证模块、控制器与节点间通信的安全通道模块以及网络拓扑与数据包解析模块,同时网络中底层设备具有转发数据和上传节点自身运行参数的功能。将安全路由机制中安全模块按其具体功能划分为三层,其中安全路由机制中底层模块中数据加密以及安全通道保证了网络传输数据的安全以及网络节点与控制器之间通信信息的安全,当数据以及交互信息的安全得到保证,控制器采用身份认证,从而保证网路节点的身份可信。控制器对节点周期性上传的运行状态参数将用来计算节点的信任值,计算完节点的综合信任值后基于综合信任值采用生物启发式路由算法设计安全路由,即基于绒泡菌觅食启发的安全路由算法。设计安全通道保证控制器与网络节点间的安全通信。该安全通道可以使用信息加密方法避免攻击者窃取或篡改控制器与节点之间的交互信息,保证网络能够安全运行网络中各个节点分别对其自身周期性运行状态参数进行加密,加密之后上传到其所处域的控制器上。控制器解密这些参数用来计算信任值并使用这些信任值,根据可信路由算法找到安全路由路径后,生成网络设备转发策略的配置参数,控制器再对这些配置参数进行加密后下发至节点,节点解密这些配置参数后安装配置,这时就完成了安全的控制器与网络节点间的通信。通过节点的综合信任值来判断网络节点的行为是否可信。从而可以保证网络传输时避开恶意节点保证网络传输数据的高度可信。
如图2所示,本实施例的中一种基于sdn的工业无线网络安全路由方法,包括如下步骤:
步骤1:sdn架构中底层网络设备周期性上传节点自身运行参数至sdn架构中的网络控制器中;
步骤2:网络控制器中的安全认证模块对节点身份进行认证,对于身份认证成功的节点通过安全通道周期性上传节点运行状态参数;使用加密方法维持控制器与节点间信息交互的安全时,使用椭圆曲线加密算法(ellipticcurvecryptography,ecc)作为交互信息加密方法。
步骤3:根据周期性上传的节点运行状态参数来计算节点的综合信任值,并生成节点的综合信任值时间序列,过程如下:
步骤3.1:网络控制器全局监测网络运行时的节点状态,根据周期性收集到的网络节点运行状态参数计算节点的近期信任值;
所述节点的近期信任值的计算过程如下:
步骤3.1.1:计算节点的近期信任值控制器收集节点发送率因子sfi、节点间通信频率因子cfi、节点转发率因子tfi、节点丢弃率因子dfi、节点剩余能量因子efi;
如图4所示,上述五种计算因子的计算公式为:
节点的发送率因子sfi(t)的具体计算公式(1)如下:
其中:spi(t)为周期t时段内节点vi的发包数量,esi(t)为周期性时间t内网络节点的发包数量期望值,该值由控制器根据网络应用状况预先设置,当网络运行正常时,节点的发送率因子为理想范围值,则节点的信任值较高,tsl为节点发送数据包数量阈值下限,tsh为节点发送数据包数量阈值上限。
节点间通信频率因子cfi(t)的具体的计算公式(2)如下:
其中:cni(t)为周期t时段内节点vi与邻居节点间的通信交互数量。eci(t)为周期t时段内通信次数的期望值。k1是用来调节函数,使通信频率因子值快速下降以达到快速降低节点的近期信任值的目的让恶意节点所造成的破坏达到最低,tc为该节点与邻居节点通信频率的阈值,如果在一段时间内该节点与邻居节点通信频率高于该阈值则可认为是该节点在进行虫洞攻击,节点不是可信节点。
节点的转发率因子tfi(t)具体公式(3)如下:
其中:tpi(t)为周期t时段内节点vi的转发包的数量,eti(t)为周期t时段内节点转发包的个数的期望值,ttl为节点转发数据包数量阈值上限,tth为节点转发数据包数量高于阈值下限;
节点的丢弃率因子dfi(t)的具体公式(4)如下:
其中:tpi(t)为周期t时段内节点vi的转发包的数量,dpi(t)为周期t时段内节点vi的丢弃包的数量。k2是用来调节函数,使丢弃率因子值快速下降达到快速降低近期信任值的目的让恶意节点所造成的破坏达到最低。
剩余能量因子efi(t)的具体计算公式(5)如下:
其中:eni(t)为周期t时段内节点vi的剩余能量,eni(0)为周期t时段前节点vi的初始化能量。
步骤3.1.2:控制器计算完近期信任值中五种计算因子后,采用加权平均方法计算节点的近期信任值或者调整节点的各个因子对应的权重数值,获得更合理的近期信任值。
所述调整节点的各个因子对应的权重数值,获得更合理的近期信任值的过程如下:
步骤3.1.2.1:各因子的权值采用模糊变权法来评估,就是在计算近期信任值时权重随各因子评估值改变的计算方法,其具体计算公式如下:
其中:um1,...,um(i-1),0,um(i 1),...,umn分别代表计算因子的权重,i,j=1,2,3,4,5;
设近期信任值计算的五种计算因子为ci(i=1,2,3,4,5),ci的权重为wi=(u1,u2,u3,u4,u5),(i=1,2,3,4,5),其中u1,u2,u3,u4,u5分别为5个计算因子c1,c2,c3,c4,c5的评价值,当ui为最大值um时,因子ci的评价值为最大值,说明因子ci处于最佳情况;当ui为0时,因子ci的评价值为最小值,说明因子ci完全失去作用;当各因子评价值均为最高值,总体计算情况为最佳时,因子ci的权重为wmi=wi(um,um,um,um,um),(i=1,2,3,4,5),wmi∈(0,1),
步骤3.1.2.2:为了对于任意因子,能够更加快速方便地求出wi=(u1,u2,u3,u4,u5),(i=1,2,3,4,5),构造一个计算函数,函数具体公式如下:
其中:λi(ui)则是为了快速计算权值引入的辅助函数,设计辅助函数时需要考虑该辅助函数一定得满足λi(0)=λ0i,λmi=wmi;
步骤3.1.2.3:当计算完各个因子的相应权值之后,节点vi在周期t时段内节点近期信任值ctvi(t)的计算公式可以定义为:
ctvi(t)=w1sfi(t) w2cfi(t) w3tfi(t) w4dfi(t) w5efi(t)
其中:wi∈(0,1),(i=1,2,3,4,5)分别为因子的加权系数,并且
步骤3.2:网络控制器存储节点各个周期性时间的历史综合信任值并记录到数据库中,计算网络中节点vi在周期t时段内的节点历史信任值;
所述节点历史信任值计算过程如下:
其中:tvi(t-j)为节点vi历史综合信任值,(t-j)为控制器中历史信任记录序列,γ为衰退值,反映出信任记录中的历史信任值随着时间的增长对当前节点历史信任值的计算所起到的作用在不断减小,η为权重,其值与信任记录中的历史信任值成反比,防止历史恶意行为随着时间被淹没。
步骤3.3:根据节点的近期信任值和历史信任值计算节点的当前的综合任值,并生成节点的综合信任值时间序列,如图3所示。
节点vi在周期性时间段t内的综合信任值的具体计算公式(10)如下:
tvi(t)=α×ctvi(t) β×htvi(t)(10)
其中:ctvi(t)表示节点vi在周期性时间段t内的近期信任值,htvi(t)表示节点vi在周期性时间段t内的历史信任值。α与β代表权重,α β=1,α>0,β>0。权重越大代表越注重该信任种类。表1是当控制器计算综合信任值时,近期信任值与历史信任值差值对相应权重的影响。
表1近期信任值和历史信任值权重设置
步骤4:设计相似度计算基准序列o,该序列作为网络中节点综合信任值时间序列的参考序列;采集节点vi的综合信任值时间序列,在连续的m个周期中综合信任值时间序列为ai={tvi(t1),tvi(t2),......,tvi(tm)},i=1,2,3......n;若
所述基准序列o的长度要与节点收集的综合信任值时间序列的长度相同,且基准序列是一个等值序列,所有值都为恶意节点判断阈值
步骤5:采用欧式距离计算方法计算节点的综合信任值时间序列与基准序列的相似度,并对网络中节点计算的相似度结果构成相似度数据集m;
当节点vi的综合信任值时间序列为ai={tvi(t1),tvi(t2),......,tvi(tm),},i=1,2,3......n,基准序列为
计算完节点vi的综合信任值时间序列与基准序列之间的欧氏距离后,将其归一化后作为节点vi的综合信任值时间序列与基准序列之间的相似度,归一化具体公式为:s(ai,o)=e^(-d(ai,o))。当归一化后可以得到节点的综合信任值时间序列与基准序列间的相似度,相似度越高即越接近与1,即节点越可能为智能的亚攻击节点;
步骤6:使用k-means算法对相似度数据集m进行聚类,分析聚类结构识别出恶意节点和亚攻击节点,过程如下:
步骤6.1:随机选出3个节点作为3个簇的初始中心,然后将剩余节点指定到离簇中心节点相似度最近的对应簇中;
步骤6.2:再随机的选取一个非中心点的节点作为备选,然后计算当使用这个备选节点作为簇中心点之后与步骤6.1相比是否会得到更佳的聚类结果;
步骤6.3:如果可以得到更佳的聚类结果则保存替换,得到新的分类簇,反之恢复原中心点;
步骤6.4:当不管中心点怎么替换聚类效果都不会提高时,结束聚类,将质心最大即最接近1的聚簇中心的相似度所对应的节点识别为亚攻击节点,即具有亚攻击性的智能攻击节点。
判断聚类结果采用平方误差准则,具体公式(12)定义如下:
其中:k为聚类的类簇个数,ci为第i个类簇,p为各个类簇中需要聚类节点的相似度,oi为第i个类簇的中心点相似度,e代表所有对象的平方误差和。
在进行完一轮中心的替换后可得到新的分簇,即newci,i=1,2,......k。新旧类簇的评价函数公式可用公式(13)(14)表示:
由此可知进行一次中心替换后的成本函数为:cost=enew-eold。当进行中心节点替换之后。如果成本函数为正数或者等于0时,说明这一次替换是无意义的替换,返回原中心点,放弃这次操作。如果成本函数为负数,则说明这一次替代是成功的,此时,保留这一次替换的结果。当所有备选的替换节点都无法使成本函数的结果为负数时,就说明此时算法收敛,已经得到了最优的聚类分簇结果。最后就是通过分析聚类结构识别具有亚攻击性的智能攻击节点。
步骤7:根据如图7所示的网络拓扑g=(v,e)初始化网络节点的邻居节点集sn以及邻居链路集sli;其中,有向图g=(v,e)中使用v表示网络中节点的集合,而e则是用来代表网络中无线链路的集合;网络由控制器、正常节点、接入点、恶意节点包括亚攻击节点组成;v={c,f,a,m}={{v1,...,v|c|},{v|c| 1,...,v|c| |f|},{v|c| |f| 1,...,v|c| |f| |a|},{v|c| |f| |a| 1,...,v|c| |f| |a| |m|}},其中c代表无线网络中的控制器集合,f代表无线网络中正常的网络节点,a代表无线网络中接入点的集合,m代表着无线网络中执行内部恶意攻击的恶意网络节点,|c|、|f|、|a|、|m|分别代表控制器、正常节点、接入点以及恶意节点的数量。
步骤8:初始化网络中无线链路质量dij和无线链路损耗指数e;
步骤9:控制器执行步骤1至步骤6识别出网络拓扑中的恶意节点和亚攻击节点,控制器在计算网络路由时会将这些恶意节点和亚攻击节点排除,保证网络传输数据的高度可信,控制器再结合节点的综合信任值计算选择路径,并设置参数集合用来存储最优的路由路径节点集,过程如下:
步骤9.1:根据绒泡菌的觅食过程建立数学模型,模拟多头绒泡菌在两个食物源的环境中的行为机制,将食物源作为网络中各个节点,绒泡菌的条状形体表示边,则每条管道中的流量数学模型公式如下:
其中:lij表示绒泡菌形体管道的长度,rij表示绒泡菌形体管道的半径,κ是绒泡菌形体管道内流体的粘滞系数,pi-pj表示流体在i点到j点的压力差,qij为每条管道中的流量;
步骤9.2:定义绒泡菌i点到j点的形体管道传导性为
绒泡菌根据自身流体所携带的信息调节自身形体进行觅食动作,结合图6介绍绒泡菌的形体调节过程。图6有两个食物源即节点i和节点j以及两个形体不同的绒泡菌分别为
步骤9.3:绒泡菌管状形体自适应调节,公式如下所示:
其中:z是绒泡菌形体管道的衰减率,f(|qij|)是一个单调并且递增的函数;绒泡菌的管状形体随着时间能够不断改变,当f(|qij|)=zdij时,表示,该绒泡菌管状形体是稳定的,不会随意改变形状,当f(|qij|)<zdij时,表示传导性下降,绒泡菌的管道半径在减小,反之,则半径增加,从而绒泡菌可以对自身的管状形体进行调节;
步骤9.4:使用工业无线网络中固有的链路质量d'ij替代形体管道传导性为dij;使用无线链路中无线传输时链路损耗指数
步骤9.5:用步骤9.4中替换后的变量改写步骤9.2中的公式,如下所示:
其中,q'ij为工业无线网络中节点i和节点j之间的工业无线链路的通信量;
步骤9.6:控制器计算下一跳节点链路质量以及路径损耗指数是不随时间变化的,而潜势差随时间变化而变化,故可以通过δpij随时间的变化来获得控制器对路径的选择,公式如下:
其中,v是一个常数并且需要满足v>0;
步骤9.7:结合步骤9.5和步骤9.6,得到最终的计算公式如下:
控制器根据
步骤10:重复步骤9直到对所有节点完成最优路由计算,直到从源节点到目的节点之间有链路通信;
步骤11:控制器对记录最优路径的集合转发到各个网络节点;
步骤12:网络根据接受到的最优路径集合来转发数据。
本实施例中,仿真时在windows2007系统下安装omnet 5.0版本进行路由算法的仿真实现,在此版本上对实施例所提出的基于sdn的工业无线网络安全路由方法进行仿真及评价。所采用的仿真拓扑如图8所示,仿真实现拓扑中的具体仿真参数设置如表2所示
表2仿真拓扑参数设置
基于所提出的拓扑对路由机制进行仿真实现,具体仿真参数设置如表3所示。
表3仿真参数
基于绒泡菌觅食启发的安全路由算法(physarum-inspiredroutingalgorithm,p-ira)以及所提出的对比算法图路由算法(graphroutingalgorithm,gra)和基于信任的源路由算法(trust-basedsourceroutingalgorithm,tsra)在基于sdn的工业无线网络中仿真运行,并且运行过程中受到网络内部恶意节点发动的dos攻击、自私攻击、sinkhole攻击以及on-off攻击。仿真实验得到结果后,根据仿真结果对三种路由算法在四种恶意攻击下,数据包交付率以及平均端到端的延迟两个指标进行对比分析,如图所示,验证了本文所提出的安全路由方法的安全性和可行性。
当在dos攻击下,数据包交付率排序:p-ira=tsra>gra,如图9所示,平均端到端的延迟排序为:gra>trsa>p-ira,如图10所示;
当节点发动自私攻击时,数据包交付率排序为:p-ira=tsra>gra,如图11所示,端到端的延迟排序为:gra>trsa>p-ira,如图12所示;
当恶意节点执行sinkhole攻击时,如图13和图14所示,数据包交付率排序为:p-ira=tsra>gra,平均端到端的延迟排序为gra>trsa>p-ira;
当基于sdn的工业无线网络中执行on-off恶意攻击时,当网络运行稳定后,数据包交付率排序为:p-ira=tsra>gra,如图15所示,端到端的时延排序为gra>trsa>p-ira,如图16所示。
在基于上述分析中,可以得到在网络内部恶意节点发动的dos攻击、自私攻击、sinkhole攻击以及on-off攻击时,本发明所设计的基于绒泡菌觅食启发的安全路由算法和基于信任的源路由算法相对比,本发明具有更加优越的数据包交付率。
然后在四种内部恶意攻击中,基于平均端到端的延迟分析后发现本发明所设计的基于绒泡菌觅食启发的安全路由算法相对于基于信任的源路由算法的数据包发送平均端到端的延迟低。所以本发明所设计的安全路由方法不但体现出路由的安全性同时满足工业环境下的时延要求,具有可行性以及高效性。
1.一种基于sdn的工业无线网络安全路由方法,其特征在于,包括如下步骤:
步骤1:sdn架构中底层网络设备周期性上传节点自身运行参数至sdn架构中的网络控制器中;
步骤2:网络控制器中的安全认证模块对节点身份进行认证,对于身份认证成功的节点通过安全通道周期性上传节点运行状态参数;
步骤3:根据周期性上传的节点运行状态参数来计算节点的综合信任值,并生成节点的综合信任值时间序列;
步骤4:设计相似度计算基准序列o,该序列作为网络中节点综合信任值时间序列的参考序列;采集节点vi的综合信任值时间序列,在连续的m个周期中综合信任值时间序列为ai={tvi(t1),tvi(t2),......,tvi(tm)},i=1,2,3......n;若
步骤5:采用欧式距离计算方法计算节点的综合信任值时间序列与基准序列的相似度,并对网络中节点计算的相似度结果构成相似度数据集m;
步骤6:使用k-means算法对相似度数据集m进行聚类,分析聚类结构识别出恶意节点和亚攻击节点;
步骤7:根据网络拓扑g=(v,e)初始化网络节点的邻居节点集sn以及邻居链路集sli;其中,有向图g=(v,e)中使用v表示网络中节点的集合,而e则是用来代表网络中无线链路的集合;网络由控制器、正常节点、接入点、恶意节点包括亚攻击节点组成;
步骤8:初始化网络中无线链路质量dij和无线链路损耗指数e;
步骤9:控制器执行步骤1至步骤6识别出网络拓扑中的恶意节点和亚攻击节点,控制器在计算网络路由时会将这些恶意节点和亚攻击节点排除,保证网络传输数据的高度可信,控制器再结合节点的综合信任值计算选择路径,并设置参数集合用来存储最优的路由路径节点集;
步骤10:重复步骤9直到对所有节点完成最优路由计算,直到从源节点到目的节点之间有链路通信;
步骤11:控制器对记录最优路径的集合转发到各个网络节点;
步骤12:网络根据接受到的最优路径集合来转发数据。
2.根据权利要求1所述的基于sdn的工业无线网络安全路由方法,其特征在于:所述步骤3的过程如下:
步骤3.1:网络控制器全局监测网络运行时的节点状态,根据周期性收集到的网络节点运行状态参数计算节点的近期信任值;
步骤3.2:网络控制器存储节点各个周期性时间的历史综合信任值并记录到数据库中,计算网络中节点vi在周期t时段内的节点历史信任值;
步骤3.3:根据节点的近期信任值和历史信任值计算节点的当前的综合任值,并生成节点的综合信任值时间序列。
3.根据权利要求2所述的基于sdn的工业无线网络安全路由方法,其特征在于:所述节点的近期信任值的计算过程如下:
步骤3.1.1:计算节点的近期信任值控制器收集节点发送率因子sfi、节点间通信频率因子cfi、节点转发率因子tfi、节点丢弃率因子dfi、节点剩余能量因子efi;
步骤3.1.2:控制器计算完近期信任值中五种计算因子后,采用加权平均方法计算节点的近期信任值或者调整节点的各个因子对应的权重数值,获得更合理的近期信任值。
4.根据权利要求3所述的基于sdn的工业无线网络安全路由方法,其特征在于:所述调整节点的各个因子对应的权重数值,获得更合理的近期信任值的过程如下:
步骤3.1.2.1:各因子的权值采用模糊变权法来评估,就是在计算近期信任值时权重随各因子评估值改变的计算方法,其具体计算公式如下:
其中:um1,...,um(i-1),0,um(i 1),...,umn分别代表计算因子的权重,i,j=1,2,3,4,5;
设近期信任值计算的五种计算因子为ci(i=1,2,3,4,5),ci的权重为wi=(u1,u2,u3,u4,u5),(i=1,2,3,4,5),其中u1,u2,u3,u4,u5分别为5个计算因子c1,c2,c3,c4,c5的评价值,当ui为最大值um时,因子ci的评价值为最大值,说明因子ci处于最佳情况;当ui为0时,因子ci的评价值为最小值,说明因子ci完全失去作用;当各因子评价值均为最高值,总体计算情况为最佳时,因子ci的权重为wmi=wi(um,um,um,um,um),(i=1,2,3,4,5),wmi∈(0,1),
步骤3.1.2.2:为了对于任意因子,能够更加快速方便地求出wi=(u1,u2,u3,u4,u5),(i=1,2,3,4,5),构造一个计算函数,函数具体公式如下:
其中:λi(ui)则是为了快速计算权值引入的辅助函数,设计辅助函数时需要考虑该辅助函数一定得满足λi(0)=λ0i,λmi=wmi;
步骤3.1.2.3:当计算完各个因子的相应权值之后,节点vi在周期t时段内节点近期信任值ctvi(t)的计算公式可以定义为:
ctvi(t)=w1sfi(t) w2cfi(t) w3tfi(t) w4dfi(t) w5efi(t)
其中:wi∈(0,1),(i=1,2,3,4,5)分别为因子的加权系数,并且
5.根据权利要求2所述的基于sdn的工业无线网络安全路由方法,其特征在于:所述节点历史信任值计算过程如下:
其中:tvi(t-j)为节点vi历史综合信任值,(t-j)为控制器中历史信任记录序列,γ为衰退值,反映出信任记录中的历史信任值随着时间的增长对当前节点历史信任值的计算所起到的作用在不断减小,η为权重,其值与信任记录中的历史信任值成反比,防止历史恶意行为随着时间被淹没。
6.根据权利要求1所述的基于sdn的工业无线网络安全路由方法,其特征在于:所述基准序列o的长度要与节点收集的综合信任值时间序列的长度相同,且基准序列是一个等值序列,所有值都为恶意节点判断阈值
7.根据权利要求1所述的基于sdn的工业无线网络安全路由方法,其特征在于:所述步骤6的过程如下:
步骤6.1:随机选出3个节点作为3个簇的初始中心,然后将剩余节点指定到离簇中心节点相似度最近的对应簇中;
步骤6.2:再随机的选取一个非中心点的节点作为备选,然后计算当使用这个备选节点作为簇中心点之后与步骤6.1相比是否会得到更佳的聚类结果;
步骤6.3:如果可以得到更佳的聚类结果则保存替换,得到新的分类簇,反之恢复原中心点;
步骤6.4:当不管中心点怎么替换聚类效果都不会提高时,结束聚类,将质心最大即最接近1的聚簇中心的相似度所对应的节点识别为亚攻击节点,即具有亚攻击性的智能攻击节点。
8.根据权利要求1所述的基于sdn的工业无线网络安全路由方法,其特征在于:所述步骤9的过程如下:
步骤9.1:根据绒泡菌的觅食过程建立数学模型,模拟多头绒泡菌在两个食物源的环境中的行为机制,将食物源作为网络中各个节点,绒泡菌的条状形体表示边,则每条管道中的流量数学模型公式如下:
其中:lij表示绒泡菌形体管道的长度,rij表示绒泡菌形体管道的半径,κ是绒泡菌形体管道内流体的粘滞系数,pi-pj表示流体在i点到j点的压力差,qij为每条管道中的流量;
步骤9.2:定义绒泡菌i点到j点的形体管道传导性为
步骤9.3:绒泡菌管状形体自适应调节,公式如下所示:
其中:z是绒泡菌形体管道的衰减率,f(|qij|)是一个单调并且递增的函数;绒泡菌的管状形体随着时间能够不断改变,当f(|qij|)=zdij时,表示,该绒泡菌管状形体是稳定的,不会随意改变形状,当f(|qij|)<zdij时,表示传导性下降,绒泡菌的管道半径在减小,反之,则半径增加,从而绒泡菌可以对自身的管状形体进行调节;
步骤9.4:使用工业无线网络中固有的链路质量d'ij替代形体管道传导性为dij;使用无线链路中无线传输时链路损耗指数
步骤9.5:用步骤9.4中替换后的变量改写步骤9.2中的公式,如下所示:
其中,q'ij为工业无线网络中节点i和节点j之间的工业无线链路的通信量;
步骤9.6:控制器计算下一跳节点链路质量以及路径损耗指数是不随时间变化的,而潜势差随时间变化而变化,故可以通过δpij随时间的变化来获得控制器对路径的选择,公式如下:
其中,v是一个常数并且需要满足v>0;
步骤9.7:结合步骤9.5和步骤9.6,得到最终的计算公式如下:
控制器根据