一种资源访问方法、服务器及计算机存储介质与流程

文档序号:18135712发布日期:2019-07-10 10:35阅读:181来源:国知局
一种资源访问方法、服务器及计算机存储介质与流程

本申请涉及通信技术领域,涉及但不限于一种资源访问方法、服务器及计算机存储介质。



背景技术:

现有的网站静态资源都是存储在公司内部服务器,或者自行建设的内容分发网络(contentdeliverynetwork,cdn)服务器,或者外部租赁的云盘。一般通过在多地部署服务器来满足不同地域用户的访问,降低访问网络延迟。

发明人在实施本申请的过程中发现,由于服务节点分布相对较少,只能覆盖一片较大区域,例如某几个省,并且服务节点部署相对成本还是比较高的,一旦某台服务器宕机,对其他服务器的压力会陡增,另外由于有限的服务节点,在高并发请求下,及时分流,也会造成某个节点的服务器网络带宽被占满。



技术实现要素:

有鉴于此,本申请实施例期望提供一种资源访问方法、服务器及计算机存储介质。

本申请实施例的技术方案是这样实现的:

本申请实施例提供一种资源访问方法,所述方法包括:

获取服务器存储的第一静态资源数据;

基于所述第一静态资源数据,对内容分发网络中各个节点设备按照预设的安全机制进行安全检测以确定检测不通过的节点设备,将所述检测不通过的节点设备移出以更新所述内容分发网络中的节点设备;

基于接收到的资源访问请求,从所述内容分发网络更新的节点设备中确定出对应于所述资源访问请求的第一节点设备;

将所述第一节点设备的地址信息发送给所述资源访问请求对应的第一终端。

本申请实施例提供一种服务器,所述服务器至少包括:存储器和处理器,其中:

所述存储器,配置为存储有资源访问程序;

所述处理器,配置为执行存储器中存储的资源访问程序,以实现本申请其他实施例提供的资源访问方法的步骤。

本申请实施例提供一种计算机存储介质,所述计算机存储介质上存储有资源访问程序,所述资源访问程序被处理器执行时实现本申请其他实施例中所述的资源访问方法的步骤。

本申请实施例提供一种资源访问、服务器及计算机存储介质,其中,首先,获取服务器存储的第一静态资源数据;然后再基于所述第一静态资源数据,对内容分发网络中各个节点设备按照预设的安全机制进行安全检测以确定检测不通过的节点设备,将所述检测不通过的节点设备移出以更新所述内容分发网络中的节点设备;进而基于接收到的资源访问请求,从所述内容分发网络更新的节点设备中确定出对应于所述资源访问请求的第一节点设备;最后将所述第一节点设备的地址信息发送给所述资源访问请求对应的第一终端;如此,由于需要利用预设的安全机制对内容分发网络中的节点设备进行安全检测,这样能够保证各个节点设备中的静态资源数据与服务器是一致的,而在扩容时可以不进行安全检测,从而实现网络带宽租赁,硬盘容量租赁,进而节约企业成本。另外当接收到资源访问请求中,从内容分发网络中确定出第一节点设备,并将第一节电设备的地址信息发送给资源访问请求对应的终端,使得终端可以从第一节点设备中获取静态资源,进而能够降低服务器的压力。

附图说明

图1为本申请实施例的网络架构示意图;

图2为本申请实施例资源访问方法的实现流程示意图;

图3为本申请实施例资源访问方法的又一实现流程示意图;

图4为本申请实施例中私有区块链的示意图;

图5为本申请实施例服务器的组成结构示意图。

具体实施方式

为使本申请实施例的目的、技术方案和优点更加清楚,下面将结合本申请实施例中的附图,对发明的具体技术方案做进一步详细描述。以下实施例用于说明本申请,但不用来限制本申请的范围。

图1为本申请实施例的网络架构示意图,如图1所示,该网络架构包括第一终端11、服务器12和节点设备13,其中,第一终端11中可以安装有浏览器应用,用户可以通过该浏览器应用访问网页;所述服务器12可以是企业的超文本传输协议域名系统(hypertexttransferprotocoldomainnamesystem,httpdns)服务器,还可以是企业的用于存储静态资源的内部服务器,在其他实施例中也可以称为账本服务器,当然,所述服务器12还可以是同时承载httpdns服务器和账本服务器的物理实体;所述各个节点设备13可以是任意能够接入互联网的设备,可以小到个人电脑,大到服务器集群。节点设备需要遵守私有网络设计规约。当第一终端通过某一运营商网络访问一网址时,(例如https://www.jd.com),运营商确定jd.com这一域名有提前备案的httpdns服务器,此时运营商将jd.com域名查询工作上升到该httpdns服务器,httpdns服务器确定与第一终端匹配的第一节点设备,那么httpdns服务器将该节点设备的ip地址发送给第一终端,第一终端与该节点设备建立连接,进行后续http数据传输。

需要说明的是,在实际实现过程中,第一服务器12和第二服务器131可以是一台服务器,也可以是由多台服务器构成的服务器集群、云计算中心等等,在此不加以限定。

本申请实施例提供一种资源访问方法,图2为本申请实施例资源访问方法的实现流程示意图,如图2所示,所述方法包括以下步骤:

步骤s201,获取服务器存储的第一静态资源数据。

这里,所述步骤s201可以是由服务器实现的,所述服务器可以是创建静态资源的服务器,在所述服务器中存储有网站的静态资源数据,所述服务器可以是网站的源站点服务器。

在本实施例中,当客户端发送资源访问请求到服务器,服务器直接把相应文件发送到客户端的文件都可以认为是静态资源数据,客户端接收到静态资源数据解析并渲染显示出来,不同的用户接收到的静态资源数据显示出来是相同的。

步骤s202,基于所述第一静态资源数据,对内容分发网络中各个节点设备按照预设的安全机制进行安全检测以确定检测不通过的节点设备,将所述检测不通过的节点设备移出以更新所述内容分发网络中的节点设备。

这里,所述步骤s202可以是由服务器实现的,所述服务器可以认为是内容分发网络中的管理服务器,或者是账本服务器,在实际应用中,所述服务器还可以是企业内部的源站点服务器。

所述步骤s202在实现时,可以是服务器获取各个节点设备中存储的第二静态资源数据,然后将自身获取到的第一静态资源数据和各个节点设备的第二静态资源数据进行比较,如果节点设备自身存储的第二静态资源数据与所述第一静态资源数据满足第一预设条件时,则表明节点设备自身存储的第二静态资源数据与第一静态资源数据相比没有发生变更,此时认为该节点设备检测通过;如果节点设备自身存储的第二静态资源数据与所述第一静态资源数据不满足第一预设条件时,则表明节点设备自身存储的第二静态资源数据与第一静态资源数据相比发生了变更,此时认为该节点设备检测不通过。检测不通过的节点设备会被移出当前的内容分发网络。

在实际实现过程中,第一预设条件可以是第二静态资源数据和第一静态资源数据一致,第一预设条件还可以是第二静态资源数据中文件版本的版本号与第一静态资源数据中文件版本的版本号相同。

需要说明的是,所述内容分发网络中的各个节点设备为任意可接入互联网的设备,可以小到个人电脑,大到服务器集群。节点设备需要遵守私有网络设计规约,例如定时接收来自服务器的变更信息,定时接收来自服务器的账本内容(也就是静态资源数据)。同时,各个节点设备需要开启web服务,能够让外界访问。并且,节点设备在加入到内容分发网络时需要提供所在网络信息,以及实际的地理位置和ip地址等信息。

步骤s203,基于接收到的资源访问请求,从所述内容分发网络更新的节点设备中确定出对应于所述资源访问请求的第一节点设备。

这里,步骤s203在实现时可以是由服务器实现的,所述服务器可以是httpdns服务器。

所述步骤s203在实现过程中,第一节点设备是与所述资源访问请求对应的第一终端相匹配的一个节点设备。

在本申请实施例中,所述第一终端中可以安装有浏览器客户端,用户在需要访问一个网页时,可以首先通过浏览器客户端输入一个网址,请求访问该网址,然后浏览器客户端对网址中的域名进行解析,以查找域名的ip地址。如果在本地存储的文件没有能够找到域名对应的ip地址,浏览器会发出一个dns请求到本地dns服务器。本地dns服务器一般都是第一终端的网络运营商提供,比如中国电信,中国移动。查询输入的网址的dns请求到达本地dns服务器之后,本地dns服务器会首先查询它的缓存记录,如果缓存中有此条记录,就可以直接返回结果。如果没有,本地dns服务器进一步确定是否预先存储有该域名相的httpdns服务器,如果有,则将访问请求发送给httpdns服务器,也就是本实施例中的服务器,进而服务器基于接收到的资源访问请求,从所述内容分发网络中确定出第一节点设备。

所述步骤s203在实现时,可以首先获取所述资源访问请求对应的第一终端的第一属性信息;然后再基于所述第一属性信息,从所述内容分发网络中确定与所述第一终端匹配的第一节点设备。

步骤s204,将所述第一节点设备的地址信息发送给所述资源访问请求对应的第一终端。

这里,所述第一终端基于接收到的第一节点设备的地址信息,与所述第一节点设备建立连接,并接收所述第一节点设备发送的静态资源,所述第一终端在接收到第一节点设备发送的静态资源后,加载所述静态资源,从而在所述第一终端上显示所述静态资源对应的网页,完成资源访问过程。

在本申请实施例提供的资源访问方法中,首先,获取服务器存储的第一静态资源数据;然后再基于所述第一静态资源数据,对内容分发网络中各个节点设备按照预设的安全机制进行安全检测以确定检测不通过的节点设备,将所述检测不通过的节点设备移出以更新所述内容分发网络中的节点设备;进而基于接收到的资源访问请求,从所述内容分发网络更新的节点设备中确定出对应于所述资源访问请求的第一节点设备;最后将所述第一节点设备的地址信息发送给所述资源访问请求对应的第一终端;如此,由于需要利用预设的安全机制对内容分发网络中的节点设备进行安全检测,这样能够保证各个节点设备中的静态资源数据与服务器是一致的,而在扩容时可以不进行安全检测,从而实现网络带宽租赁,硬盘容量租赁,进而节约企业成本。另外当接收到资源访问请求中,从内容分发网络中确定出第一节点设备,并将第一节电设备的地址信息发送给资源访问请求对应的终端,使得终端可以从第一节点设备中获取静态资源,进而能够降低服务器的压力。

基于前述的实施例,本申请实施例再提供一种资源访问方法,图3为本申请实施例资源访问方法的又一实现流程示意图,如图3所示,所述方法包括以下步骤:

步骤s301,第一服务器按照预设规则组建内容分发网络。

这里,所述步骤s301在实现时,可以是第一服务器根据历史的访问记录,筛选出各个地理区域中符合一定规则的终端设备,然后向这些终端设备发送加入内容分发网络的请求,再从响应了该请求的终端设备中选择出符合第三预设条件的终端设备,进而组建成内容分发网络,其中,第一服务器在向终端设备发送加入内容分发网络的请求中,可以携带有需要终端设备返回的信息,例如,可以请求终端返回ip地址、地理位置、所属运营商以及可提供的存储空间大小,可提供的网络带宽等信息,在接收到终端设备的响应之后,获取终端返回的响应消息中携带的ip地址、地理位置、所属运营商以及可提供的存储空间大小等相关信息,然后再基于这些信息,确定组建内容分发网络的终端设备。

例如,可以首先根据可提供的存储空间大小进行筛选,如果终端设备可提供的存储空间大小都不足以存储静态资源数据,那么这样的终端设备是不可以作为节点设备组建内容分发网络的,然后再基于可提供的网络带宽和地理位置等信息进行判断,确定组建内容分发网络的终端设备。

在本实施例中,可以由所述第一服务器存储各个节点设备的信息。

步骤s302,所述第一服务器向内容分发网络中各个节点设备发送加入成功通知消息,以通知各个节点设备从所述第一服务器获取当前的第一静态资源数据。

这里,在组建了内容分发网络后,由第一服务器将加入成功通知消息发送给各个节点设备,各个节点在接收到加入成功通知消息后,会从服务器下载当前的第一静态资源数据并存储到自身的存储空间,这样,当有终端请求访问这些静态资源数据时,可以通过就近的节点设备获取要访问的静态资源数据。

步骤s303,所述第一服务器接收第二终端发送的加入请求。

这里,所述加入请求用于请求将所述第二终端加入所述内容分发网络作为所述内容分发网络中的节点设备,所述加入请求中至少携带有所述第二终端的可提供存储空间大小。需要说明的是,所述第二终端的可提供存储空间大小是指第二终端可以提供的用于存储静态资源数据的空间大小。

所述第二终端可以是任意可接入互联网的设备,所述第二终端可以是个人计算机,还可以是其他公司的服务器,甚至还可以是服务器集群。

步骤s304,所述第一服务器判断所述第二终端的可提供存储空间大小是否大于第一预设阈值。

这里,如果所述第二终端的可提供存储空间大于第一预设阈值,则认为所述第二终端的可提供存储空间足够存储静态资源数据,那么此时进入步骤s305;如果所述第二终端的可提供存储空间大小小于或等于第一预设阈值,则认为所述第二终端的可提供存储空间大小不足以存储静态资源数据,那么此时不将第二终端加入到内容分发网络,在实现过程中,可以向第二终端返回一个拒绝加入的响应消息,并在响应消息中携带拒绝加入的原因为可提供存储空间大小不足,这样,如果第二终端还想加入时,可以对可提供存储空间大小进行调整。

步骤s305,所述第一服务器允许所述第二终端加入所述内容分发网络。

这里,所述步骤s305在实现时,可以是首先获取所述第二终端的属性信息,然后将所述第二终端的属性信息加入到存储节点设备属性信息的数据表中,其中,所述第二终端的属性信息可以是携带于第二终端的加入请求中,还可以是第一服务器在确定了第二终端的可提供存储空间大小大于第一预设阈值之后,向第二终端返回一个获取属性信息的请求消息,进而根据第二终端发送的响应消息中获取属性信息。

在本实施例中,所述第一服务器将所述第二终端加入所述内容分发网络后,可以向第二终端发送一个加入成功通知消息,以通知第二终端从第一服务器获取当前的第一静态资源数据。

步骤s306,所述第二终端从第一服务器下载当前的第一静态资源数据。

这里,在将第二终端加入到内容分发网络之后,所述第二终端从第一服务器下载当前的第一静态资源数据,以便第二终端能够为就近的第一终端提供静态资源数据。

步骤s307,第一终端基于用户发出访问网页的操作指令,向第二服务器发送资源访问请求。

这里,用户可以通过多种方式发出访问网页的操作指令,例如,可以通过在浏览器应用中输入待访问网页的网址,还可以是在浏览器应用中输入待访问网页的文字信息,当然还可以通过发出预设的语音信息触发访问网页的操作指令。

当第一终端接收到用户发出的访问页面的操作指令后,对操作指令进行解析,获取待访问页面的域名信息,进而向第二服务器发送资源访问请求,其中,所述资源访问请求中至少包括待访问页面的域名信息、第一终端的ip,所述资源访问请求中还可以包括第一终端所述的运营商、地理位置等信息。

所述第二服务器可以是本地dns服务器,而本地dns服务器一般都是第一终端的网络运营商提供,比如中国电信,中国移动。

步骤s308,所述第二服务器将所述资源访问请求发送给第一服务器。

这里,所述步骤s308在实现时,首先第二服务器查询自身的缓存记录,如果缓存中有第一终端请求访问的域名对应的ip地址,就可以直接向第一终端返回结果。如果没有,第二服务器进一步确定是否预先存储有该域名相对应的httpdns服务器,如果有,则将访问请求发送给httpdns服务器,也就是本实施例中的第一服务器。

步骤s309,所述第一服务器基于接收到的资源访问请求,获取所述资源访问请求对应的第一终端的第一属性信息。

这里,所述第一属性信息可以包括但不限于第一终端的ip地址、所属的运营商标识以及地址位置,所述第一属性信息可以是携带于资源访问请求中。

步骤s310,所述第一服务器获取所述内容分发网络中各个节点设备的第二属性信息。

这里,所述第二属性信息包括所述各个节点设备ip地址、地理位置、所属运营商中的至少之一。

步骤s311,所述第一服务器根据所述各个节点设备的第二属性信息和所述第一终端的第二属性信息,确定满足第二预设条件的第一节点设备。

这里,所述步骤s313在实现时,可以是,所述第一服务器将所述各个节点设备中,ip地址与所述第一终端的ip地址满足第一预设子条件,

和/或地理位置与所述第一终端的地址位置满足第二预设子条件,

和/或所属运营商与所述第一终端的所属运营商满足第三预设子条件的节点设备确定为第一节点设备。

在其他实施例中,所述方法还包括:所述第一服务器监测各个节点设备的负荷系数;当所述节点设备的负荷系统大于第二预设阈值时,将所述节点设备确定为不满足所述第二预设条件的第二节点设备。

步骤s312,所述第一服务器将所述第一节点设备的地址信息发送给所述第一终端。

步骤s313,所述第一终端基于接收到的第一节点设备的地址信息,与所述第一节点设备建立连接,接收并加载所述第一节点设备发送的静态资源。

这里,所述第一终端在接收到第一节点设备发送的静态资源后,加载所述静态资源,从而在所述第一终端上显示所述静态资源对应的网页。

在本申请实施例提供的资源访问方法中,首先第一服务器按照预设规则组建内容分发网络,然后向内容分发网络中各个节点设备发送当前的第一静态资源数据,当有第二终端想要加入该内容分发网络时,第一服务器接收第二终端发送的加入请求,如果所述第二终端的可提供存储空间大小大于第一预设阈值,将所述第二终端加入所述内容分发网络;并向所述第二终端发送当前的第一静态资源数据,也就是说,当任何一个想要加入内容分发网络的可提供存储空间足够时,就可以将加入到内容分发网络,这样使得内容分发网络的扩容更加便捷。

当第一终端基于用户发出访问网页的操作指令,向第二服务器发送资源访问请求,所述第二服务器将所述资源访问请求发送给第一服务器,进而第一服务器基于接收到的资源访问请求,获取所述资源访问请求对应的第一终端的第一属性信息以及各个节点设备的第二属性信息,并根据所述各个节点设备的第二属性信息和所述第一终端的第二属性信息,确定满足第二预设条件的第一节点设备,最后第一服务器将所述第一节点设备的地址信息发送给所述第一终端,以使得第一终端与所述第一节点设备建立连接,并接收所述第一节点设备发送的静态资源。

在其他实施例中,所述第一服务器还会基于自身存储的静态资源数据,对内容分发网络中各个节点设备按照预设的安全机制进行安全检测,在实际实现过程中,可以按照以下步骤进行安全检测:

步骤41,获取各个节点设备中存储的第二静态资源数据。

步骤42,判断所述第一静态资源数据和所述第二静态资源数据是否满足第一预设条件。

这里,如果节点设备自身存储的第二静态资源数据与所述第一静态资源数据满足第一预设条件时,则表明节点设备自身存储的第二静态资源数据与第一静态资源数据相比没有发生变更,此时认为该节点设备检测通过;如果节点设备自身存储的第二静态资源数据与所述第一静态资源数据不满足第一预设条件时,则表明节点设备自身存储的第二静态资源数据与第一静态资源数据相比发生了变更,此时认为该节点设备检测不通过。

在实际实现过程中,第一预设条件可以是第二静态资源数据和第一静态资源数据一致,第一预设条件还可以是第二静态资源数据中文件版本的版本号与第一静态资源数据中文件版本的版本号相同。

步骤43,将检测不通过的节点设备移出以更新所述内容分发网络中的节点设备。

这里,将所述检测不通过的节点设备移出所述内容分发网络,在实现时,可以是将所述检测不通过的节点设备的工作状态设置为未激活。

步骤44,向所述检测不通过的节点设备发送移出网络通知消息。

步骤45,所述检测不通过的节点设备在接收到移出网络通知消息后,更新自身存储的静态资源数据。

这里,如果所述检测不通过的节点设备未通过安全检测是由于自身对静态资源数据进行了篡改,并且检测不通过的节点设备可以确定如何更新自身存储的静态资源数据时,那么所述步骤45在实现时可以是,检测不通过的节点设备可以自主更新自身存储的第二静态资源数据,以保证自身存储的静态资源数据与第一服务器中存储的一致。

如果检测不通过的节点设备并不能确定因为何种原因使得未通过安全检测,那么所述步骤45在实现时可以是,检测不通过的节点设备在接收到移出网络通知消息后,从第一服务器中下载当前的第一静态资源数据。所述检测不通过的节点设备在下载完第一静态资源数据之后,可以是将自身存储的第二静态资源删除,存储接收到的第一静态资源数据,已完成对自身存储的第二静态资源数据的更新。

步骤46,每间隔第三预设时长,对所述检测不通过的节点设备按照预设的安全机制再次进行安全检测。

步骤47,如果所述检测不通过的节点设备在预设的时长阈值内通过检测,将所述检测不通过的节点设备加入所述内容分发网络。

步骤48,如果所述检测不通过的节点设备在预设的时长阈值内仍未通过检测,将所述检测不通过的节点设备彻底移除所述内容分发网络。

这样,通过步骤41至步骤48,可以将第二静态资源数据与服务器中存储的当前的第一静态资源数据相比,是发生了变更的节点设备移出内容分发网络,并通知被移出的节点设备更新自身存储的第二静态资源数据,以保证各个节点设备中存储的第二静态资源数据与第一静态资源数据是一致的。

在其他实施例中,所述方法还包括:

步骤51,当检测到第一静态资源数据发生变更,服务器基于第一静态资源数据的变更生成变更信息。

步骤52,服务器向各个节点设备发送更新通知消息,以通知各个节点设备基于所述变更信息对自身存储的第二静态资源数据进行更新。

这里,各个节点设备在接收到服务器发送的更新通知消息后,从服务器下载所述更新信息,并根据所述更新信息对自身存储的第二静态资源数据进行更新。

步骤53,服务器每间隔第一预设时长向各个节点设备发送会话请求。

步骤54,服务器如果在第二预设时长内没有接收到所述各个节点设备中的部分节点设备的会话响应,将所述部分节点设备移出所述内容分发网络。

在步骤51至步骤54所在的实施例中,服务器会在静态资源发生变更时,向各个节点设备发送更新通知消息,以通知各个节点设备能够对自身存储的静态资源数据进行更新,从而使自身存储的静态资源数据与服务器存储的静态资源数据保持一致,进而能够保证用户所访问静态资源数据的准确性。

本申请实施例再提供一种资源访问方法,在实现过程中可以通过以下步骤实现:

步骤61,某上海普陀区用户在通过电信网络访问https://www.jd.com。

步骤62,用户所在的运营商会根据京东是否有本地httpdns服务来确定是否转发,若存在,运营商将jd.com域名查询工作移交到京东的httpdns服务器上。

步骤63,该httpdns服务器根据用户信息,通过最小路径算法,给用户返回一个离他最近的私有网络节点的ip。

这里,例如,该httpdns服务器通过查询私有区块链网络,找到了同样在普陀区的电信网络的小明的服务器,将小明的服务器的ip地址返回给用户。

步骤64,用户浏览器与小明服务器建立tcp/ip连接,进行后续httpdns数据传输。

在本实施例中,组建私有区块链网络可以通过以下步骤实现:

步骤71,招募。通过公告向社会,群体,合作伙伴发起招募,有意向者提供节点信息,例如ip、设备类型、容量、地理位置、网络运营商信息及带宽信息等,同时填报合作志愿合同,类似某种组织的法律法规;

步骤72,评估步骤71中申报者的信息,将一些不符合条件的节点排除。

例如,将带宽接入较小,容量较小,硬件配置较差,无法保证持续在线等节点排除。

步骤73,通过步骤72评估的节点,即可接入私有区块链网络。

发起者需要从本地httpdns服务器中记录每个节点的信息。发起者会对每一个接入节点创建一个账户,用于访问发起者的静态资源版本管理系统(例如git),定期同步数据到本地仓库。

步骤74,发起者会提供一个统一的“账本”计算方式,以明确加密算法和密钥信息,用于各个节点计算本地静态资源生成的“账本”信息。

这里,静态资源库的更新会导致账本信息变更,从而生成一个新版本。发起方会在非常短的时间间隔内,定时与每个节点通信,校验节点的账本信息,若某个节点的账本信息与发起者不同,则认为该节点的数据有异常,将该节点从本地httpdns服务器中排除,若该节点在规定的时间内无法恢复数据,则彻底将该节点从私有区块链网络中去除,并在私有信用记录中记录该节点行为。

步骤75,所有为私有网络提供容量的节点,发起方将根据其所贡献的大小提供一定的奖励机制。其中,奖励机制可以自行协商,例如提供无偿cdn服务,提供发起方公司的产品等等。

需要说明的是,私有区块链网络的组建流程与用户访问流程是相互独立的,这意味着,即使本申请实施例中私有区块链网络尚未组建部署完成,用户依旧可以访问内容提供商(例如京东商城)所拥有的服务器集群(京东的服务器,cdn等)。

图4为本申请实施例中私有区块链的示意图,如图4所示,在所述私有区块链网络中包括:公司服务器401、cdn服务器402、小明的pc403、某公司的小型机404、小刚的个人服务器405,其中:

公司服务器401可以作为记账服务器,cdn服务器402、小明的pc403、某公司的小型机404、小刚的个人服务器405可以作为参与方设备。

由于静态资源由服务发起方创建,因此,记账工作由服务发起方的公司服务器401负责记录。每当有静态资源发生变更,例如增加,修改,下线,都会由该服务器401负责添加新的账本记录,同时同步账本到各个参与方设备。

参与方设备可以是任何能够接入互联网的计算机,可以小到个人电脑,大到服务器集群。参与方需要遵守私有网络设计规约,如定时接收来自账本服务器的数据变更,定时接收来自账本服务器的账本内容。同时,参与方设备需要开启web服务,能够让外界访问,需要提供所在网络信息,以及实际的地理位置。所有参与方设备,都会被httpdns服务器记录在案,用于后续流量分配。

在本实施例中,所述私有区块链网络的安全机制包括:账本服务器需要定时校验各个参与方设备的账本记录,若某台参与方设备的文件内容发生更改,则账本校验失败,将该参与方设备排除出区块链网络中,同时,通知该参与方设备重新接收账本服务器的数据内容,再次校验该参与方设备的账本内容,直至账本匹配,才能将该参与方设备重新接入到网络中

在本实施例中,所述私有区块链网络的可靠性机制包括:

账本服务器需要定时与各参与方保持会话,确保参与方在线,否则,将参与方排除出区块链网络中,直至该参与方重新上线。

在本实施例中,所述私有区块链网络的奖励机制包括:

所有参与到该网络的参与方服务器,通过保持在线记录,给与一定的奖励。奖励可分为多种形式,例如奖励服务发起方的一些虚拟货币奖励,或是有权获取其他参与机参与其自行发起的私有区块链网络中,简单理解就是你帮助了我,后续你随时可以获取其他权威人士的帮助。

在本实施例中,在节点分布上面,为现有节点分布提供了类似扩容的机制,任意可以接入互联网的设备都可以加入网络,并且通过区块链技术的理念,在成本上做到一劳永逸,同时为后续的扩容提供了基础建设,在用户请求访问静态资源数据时,通过就近原则确定与用户相匹配的参与方设备,不仅能够降低用户网络延迟,并且能够为现有的各个节点减负。

本申请实施例提供一种服务器,图5为本申请实施例服务器的组成结构示意图,如图5所示,所述服务器至少包括:存储器501和处理器502,其中:

所述存储器501,配置为存储资源访问程序;

所述处理器502,配置为执行存储器中存储的资源访问程序,以实现如下步骤:

获取服务器存储的第一静态资源数据;

基于所述第一静态资源数据,对内容分发网络中各个节点设备按照预设的安全机制进行安全检测以确定检测不通过的节点设备,将所述检测不通过的节点设备移出以更新所述内容分发网络中的节点设备;

基于接收到的资源访问请求,从所述内容分发网络更新的节点设备中确定出对应于所述资源访问请求的第一节点设备;

将所述第一节点设备的地址信息发送给所述资源访问请求对应的第一终端。

在其他实施例中,所述对内容分发网络中各个节点设备按照预设的安全机制进行安全检测以确定检测不通过的节点设备,包括:

获取各个节点设备中存储的第二静态资源数据;

判断所述第一静态资源数据和所述第二静态资源数据是否满足第一预设条件;其中,如果所述第一静态资源数据和所述第二静态资源数据不满足第一预设条件,将所述第二静态资源数据对应的节点设备确定为所述检测不通过的节点设备。

在其他实施例中,所述处理器502还配置为执行存储器中存储的资源访问程序,以实现如下步骤:

在将所述检测不通过的节点设备移出所述内容分发网络后,每间隔第三预设时长再对所述检测不通过的节点设备按照所述预设的安全机制进行安全检测;

如果所述检测不通过的节点设备中存在有节点设备通过检测,将通过检测的节点设备加入所述内容分发网络。

在其他实施例中,所述处理器502还配置为执行存储器中存储的资源访问程序,以实现如下步骤:

接收第二终端发送的加入请求,其中,所述加入请求用于请求将所述第二终端加入所述内容分发网络作为所述内容分发网络中的节点设备,所述加入请求中至少携带有所述第二终端的可提供存储空间大小;

如果所述第二终端的可提供存储空间大小大于第一预设阈值,允许所述第二终端加入所述内容分发网络;

向所述第二终端发送加入成功通知消息,以通知所述第二终端从所述服务器获取所述第一静态资源数据。

在其他实施例中,所述处理器502还配置为执行存储器中存储的资源访问程序,以实现如下步骤:

当检测到第一静态资源数据发生变更,基于所述第一静态资源数据的变更生成变更信息;

向各个节点设备发送更新通知消息,以通知各个节点设备基于所述变更信息对自身存储的第二静态资源数据进行更新。

在其他实施例中,所述处理器502还配置为执行存储器中存储的资源访问程序,以实现如下步骤:

每间隔第一预设时长向各个节点设备发送会话请求;

如果在第二预设时长内没有收到所述各个节点设备中的部分节点设备的会话响应,将所述部分节点设备移出所述内容分发网络。

在其他实施例中,所述基于接收到的资源访问请求,从所述内容分发网络更新的节点设备中确定出对应于所述资源访问请求的第一节点设备,包括:

获取所述资源访问请求对应的第一终端的第一属性信息;

基于所述第一属性信息,从所述内容分发网络更新的节点设备中确定与所述第一终端匹配的第一节点设备。

在其他实施例中,所述基于所述第一属性信息,从所述内容分发网络更新的节点设备中确定与所述第一终端匹配的第一节点设备,包括:

获取所述内容分发网络中各个节点设备的第二属性信息;

根据所述各个节点设备的第二属性信息和所述第一终端的第二属性信息,确定满足第二预设条件的第一节点设备。

在其他实施例中,所述第一属性信息包括所述第一终端的ip地址、地理位置、所属运营商中的至少之一,所述第二属性信息包括所述各个节点设备ip地址、地理位置、所属运营商中的至少之一,相应地,所述第一服务器根据所述各个节点设备的第二属性信息和所述第一终端的第二属性信息,确定满足第二预设条件的第一节点设备,包括:

所述第一服务器将所述各个节点设备中,ip地址与所述第一终端的ip地址满足第一预设子条件,

和/或地理位置与所述第一终端的地址位置满足第二预设子条件,

和/或所属运营商与所述第一终端的所属运营商满足第三预设子条件的节点设备确定为第一节点设备。

在其他实施例中,所述处理器502还配置为执行存储器中存储的资源访问程序,以实现如下步骤:

监测各个节点设备的当前负荷系数;

当所述节点设备的当前负荷系数大于第二预设阈值时,将所述节点设备确定为不满足所述第二预设条件的第二节点设备。

相应地,本申请实施例再提供一种计算机存储介质,所述计算机存储介质上存储有资源访问程序,所述资源访问程序被处理器执行时实现上述的资源访问方法的步骤。

以上服务器和存储介质实施例的描述,与上述方法实施例的描述是类似的,具有同方法实施例相似的有益效果。对于本申请服务器和计算机存储介质实施例中未披露的技术细节,请参照本申请方法实施例的描述而理解。

本申请实施例中,如果以软件功能模块的形式实现上述方法,并作为独立的产品销售或使用时,也可以存储在一个计算机可读取存储介质中。基于这样的理解,本申请实施例的技术方案本质上或者说对现有技术做出贡献的部分可以以软件产品的形式体现出来,该计算机软件产品存储在一个存储介质中,包括若干指令用以使得一台计算机设备(可以是个人计算机、服务器、或者网络设备等)执行本申请各个实施例所述方法的全部或部分。而前述的存储介质包括:u盘、移动硬盘、只读存储器(rom,readonlymemory)、磁碟或者光盘等各种可以存储程序代码的介质。这样,本申请实施例不限制于任何特定的硬件和软件结合。

应理解,说明书通篇中提到的“一个实施例”或“一实施例”意味着与实施例有关的特定特征、结构或特性包括在本申请的至少一个实施例中。因此,在整个说明书各处出现的“在一个实施例中”或“在一实施例中”未必一定指相同的实施例。此外,这些特定的特征、结构或特性可以任意适合的方式结合在一个或多个实施例中。应理解,在本申请的各种实施例中,上述各过程的序号的大小并不意味着执行顺序的先后,各过程的执行顺序应以其功能和内在逻辑确定,而不应对本申请实施例的实施过程构成任何限定。上述本申请实施例序号仅仅为了描述,不代表实施例的优劣。

需要说明的是,在本文中,术语“包括”、“包含”或者其任何其他变体意在涵盖非排他性的包含,从而使得包括一系列要素的过程、方法、物品或者装置不仅包括那些要素,而且还包括没有明确列出的其他要素,或者是还包括为这种过程、方法、物品或者装置所固有的要素。在没有更多限制的情况下,由语句“包括一个……”限定的要素,并不排除在包括该要素的过程、方法、物品或者装置中还存在另外的相同要素。

在本申请所提供的几个实施例中,应该理解到,所揭露的设备和方法,可以通过其它的方式实现。以上所描述的设备实施例仅仅是示意性的,例如,所述单元的划分,仅仅为一种逻辑功能划分,实际实现时可以有另外的划分方式,如:多个单元或组件可以结合,或可以集成到另一个系统,或一些特征可以忽略,或不执行。另外,所显示或讨论的各组成部分相互之间的耦合、或直接耦合、或通信连接可以是通过一些接口,设备或单元的间接耦合或通信连接,可以是电性的、机械的或其它形式的。

上述作为分离部件说明的单元可以是、或也可以不是物理上分开的,作为单元显示的部件可以是、或也可以不是物理单元;既可以位于一个地方,也可以分布到多个网络单元上;可以根据实际的需要选择其中的部分或全部单元来实现本实施例方案的目的。

另外,在本申请各实施例中的各功能单元可以全部集成在一个处理单元中,也可以是各单元分别单独作为一个单元,也可以两个或两个以上单元集成在一个单元中;上述集成的单元既可以采用硬件的形式实现,也可以采用硬件加软件功能单元的形式实现。

本领域普通技术人员可以理解:实现上述方法实施例的全部或部分步骤可以通过程序指令相关的硬件来完成,前述的程序可以存储于计算机可读取存储介质中,该程序在执行时,执行包括上述方法实施例的步骤;而前述的存储介质包括:移动存储设备、只读存储器(readonlymemory,rom)、磁碟或者光盘等各种可以存储程序代码的介质。

或者,本申请上述集成的单元如果以软件功能模块的形式实现并作为独立的产品销售或使用时,也可以存储在一个计算机可读取存储介质中。基于这样的理解,本申请实施例的技术方案本质上或者说对现有技术做出贡献的部分可以以软件产品的形式体现出来,该计算机软件产品存储在一个存储介质中,包括若干指令用以使得一台计算机设备(可以是个人计算机、服务器、或者网络设备等)执行本申请各个实施例所述方法的全部或部分。而前述的存储介质包括:移动存储设备、rom、磁碟或者光盘等各种可以存储程序代码的介质。

以上所述,仅为本申请的具体实施方式,但本申请的保护范围并不局限于此,任何熟悉本技术领域的技术人员在本申请揭露的技术范围内,可轻易想到变化或替换,都应涵盖在本申请的保护范围之内。因此,本申请的保护范围应以所述权利要求的保护范围为准。

当前第1页1 2 
网友询问留言 已有0条留言
  • 还没有人留言评论。精彩留言会获得点赞!
1