The present disclosure relates to the computer network technology, and particularly to a system and method for providing an on-site service.
With increased service requirements and improved processing demand in a network, the current main solution is that a service is provided by transmitting and processing a service request in the network over the cloud and returning the processed result to a requesting end. However, as media businesses increase, larger data volume and high real-time demand thereof makes it difficult for cloud service to meet a user's requirements, leading to a low degree of satisfaction of the service quality. This is because the main contradiction between the cloud service and media processing in network lies in the following two aspects: one aspect is that the transmission delay of large-scale data over the cloud leads to the media service being incapable of providing users with high efficient processing assurance; the other aspect is that the location-independent characteristic of cloud computing leads to being incapable of meeting the processing requirement based on a location.
In an actual network, one the one hand, since cloud computing resources are usually centrally deployed in a regional way by a cloud computing service supplier, it is difficult for a user to specify a specific service node and service location, and there is a long time for transmitting data between a centrally deployed cloud server and an actual user; on the other hand, there are a substantial amount of edge serving devices and scattered network resources are unused and not applied in a reasonable way. However, these resources are not only close to users but also have a certain processing ability, there is a problem needed to be solved that how to manage and utilize reasonably service resources at edge of network.
An objective of the presently described embodiments lies in improving the processing efficiency of network tasks and making full use of idle resources, thereby providing a system and method for providing an on-site service.
In order to achieve the above objectives, the described embodiments provide a system for providing an on-site system, said system comprises a plurality of nodes, and each node comprises:
a neighborhood node set generation module, used for generating a neighborhood node set on the basis of the bidirectional link bandwidth information between a local node and a neighboring node, and ordering usable bandwidths of various neighboring nodes in the set from large to small or from small to large;
a neighborhood information index table generation module, used for generating a neighborhood information index table of the local node, the neighborhood information index table is used for storing node status information of various neighboring nodes and description information of a service type provided by the nodes;
a candidate service node selection module, used for selecting according to a selection function a candidate service node from a set of neighboring nodes; wherein the definition of the selection function is: for a current service request, a difference between QoS of the neighboring node i executing the service request and the QoS of the local node executing the service request is computed; the neighboring node i is used as the candidate service node if the computed difference is smaller than a set threshold;
a service scheduling module, used for receiving status information and feedback information provided in real time by the candidate service nodes, and matching the status information and feedback information of various candidate service nodes with content in a service request command, then to select a service execution node from the candidate service nodes and the local node, wherein,
the status information comprises: an idle resource status, an occupied resource status, a current resource margin, a currently hosted service type and history service information;
the feedback information comprises: quality of service, service resource consumption and service status;
the service request command comprises: content of the requested service, a type of the requested service, QoS demand of the requested service and information on a service result output destination.
Optionally, the above described node further comprises: a receiving module, used for receiving the service request command and transmitting the received service request command to the candidate service point selection module.
Optionally, the above described node further comprises:
a measurement module, used for measuring connection characteristics of network to obtain information related to network connection, and inputting the obtained information related to network connection to the neighborhood node set generation module; wherein the information related to network connection comprises the bidirectional link bandwidth information and delay information between nodes;
an information exchanging module, used for acquiring information of the neighboring nodes and inputting the acquired information of the neighboring nodes to the neighborhood information index table generation module; wherein the information of the neighboring nodes comprises: information related to network connection measured by the neighboring nodes, status information of the neighboring nodes and description information of the service types provided by the neighboring nodes.
Optionally, the above described candidate service node selection module comprises:
a first filtration submodule, used for selecting, from the neighborhood node set, a node with the service type required by the service request command or a node capable of dynamically loading the service type requested by the service request command, and composing all the selected nodes as a preliminary candidate service node set;
a second filtration submodule, used for further selecting, from the preliminary candidate service node set, a neighboring node simultaneously meeting the following two conditions as a node in a second candidate service node set:
condition one: the usable bandwidth between the neighboring node and a service receiving point is larger than the bandwidth required by the service request;
condition two: the following equation is utilized to obtain a candidate service node for the local node pi:
F1(Σir)=Σi,1r={ζjεΣir|ti,j,k
the above described function T(i,j,σk
the above described function D(i,j,ψk
the above described function T(i,i,σk
tk
a third service node set generation submodule, used for selecting, from the second candidate service node set, Nk
F2Σi,1r)=Σi,2r={ζjεΣi,1r| selecting the first Nk
Optionally, the above described service scheduling module further comprises:
a status information and feedback information receiving submodule, used for receiving status information and feedback information of nodes returned by various candidate nodes in the candidate service node set, said status information comprises the idle resource status, the occupied resource status, the current resource margin, the currently hosted service type and the history service information; said feedback information comprises the quality of service, the service resource consumption and the service status; and
a matching submodule, used for matching the requested service type with the service types that the local node and the candidate service nodes are capable of providing, and using one node of the candidate service nodes or the local node as a service execution node when the one node supports the requested service type and the resources of the one node is sufficient to support processing of the requested service.
In addition, the present description further provides a method for providing an on-site service which acquires the requested service based on the above described on-site service system, said method comprises:
step 101) considering node pi in a network as a service request accessing node, when the node pi receives a service request command r;
wherein said request command r comprises: a requested service type kr, a processing requirement σk
step 102) extracting service type information and QoS demand regarding a request contained in the service request command, selecting a candidate service node by a candidate service point selection module, in conjunction with a neighborhood information index table and a neighborhood node set maintained by the node pi, and then to obtain a set of candidate service nodes Σir with a size of Ni,r; wherein said QoS demand comprises bandwidth and delay;
step 103) selecting, according to the set time limit tk
step 104) providing service directly by the current service request accessing node, if the service execution node selected in step 103) is the current service request accessing node;
transmitting the service request command to a service execution node and executing the requested service by the service execution node, if the service execution node is a node from a candidate service node list.
Optionally, transmitting the processed result to a service result output destination in the service request in one of the following ways according to information on the service result output destination, after the execution node executes and completes the requested task:
returning, by the execution node, a processing result to the service result output destination; or returning the processing result to the service request accessing node, and returning, by the service request accessing node, it back to the service result output destination; or returning the processing result to a specified node in the neighborhood node set, and returning, by the specified node, it back to the service result output destination.
Optionally, the above described size “Nk
Further optionally, the above described candidate service point selection module selects a candidate service node utilizing the following selection function:
Σir=F(Σ)=F3(F2(F1(Σ)))
Where
F1(Σir)=Σi,1r={ζjεΣir|ti,j,k
F2(Σi,1r)=Σi,2r={ζjεΣi,1r| selecting the first Nk
F3(Σ)=Σir={ζjεΣi,2r|τj,k
the above described ζj={wi, sup, scur, cup, ccur, v1, . . . , vk, . . . , vM},
where wj represents the usable bandwidth of node pj, sup and scur represents respectively the maximum storage capacity and the currently occupied storage capacity of node pj, cup and ccur represents respectively the maximum computing ability and the currently occupied computing ability of node pj, vk represents the ability measurement of node pj when a service of type k is processed by the node pj, M is the amount of service types that all the nodes in the neighborhood node set are capable of supporting;
the above described function T(i,j,σk
the above described function D(i,j,ψk
Optionally, after said step 104), the method further comprises: step 105) releasing resources of the execution node occupied for service processing, updating current status information of the service request accessing node and the execution node, and releasing the candidate service nodes for the service request accessing node.
In a word, the selection of candidate service nodes is implemented by means of a computing selection function. The selection function is to compute, for a current service request, a difference between the QoS of executing the service request by other nodes in a network and the QoS of executing the request by a service receiving node, and the smaller the difference is, the bigger the possibility for executing the request by other nodes in place of the service receiving node is. The selection function may be computed by, but not limited to, the bidirectional link bandwidths of network, the type of the service request, computing demand of the service request, QoS demand of service, related information to network connection, and a combination of one or more thereof. The selection function may also be implemented by means of definitions or learning relevant rules. The service scheduling means that for the current service request, a suitable service execution node is selected from the service receiving node and the set of candidate service nodes. The selection process may be computed by a combination of one or more of the available status, the execution condition of historical tasks, features of queued tasks and other network features. The selection process may also be implemented by means of definitions or learning rules.
As compared with the prior art, the advantage of the present embodiments lies in that:
the present embodiments may detect and maintain information on network edge node close to a service request, dynamically and flexibly construct a computing service network, and provide high efficient on-site services for processing requests with low-delay service requirements, thereby meeting the increasing network processing demand and providing a new distributed network processing system. The technical solution provided herein not only improves resource utilization, but also may provide a high efficient service for network processing requirements with low-delay demands.
The present inventions will be described below in detail through the accompanying drawings and embodiments.
It is supposed that, a network contains N nodes, a set of which P={p1, . . . , pi, . . . , PN}, a corresponding set of attributes of network nodes Σ={ζ1, ζ2, . . . , ζN}. Each ζi (1≦i≦N) maintains related information to node pi in real time, ζj={wi, sup, scur, cup, ccur, v1, . . . , vk, . . . , vM}, where wi represents usable bandwidth of node pj, sup and scur represents respectively a maximum storage capacity and currently occupied storage capacity of the node, cup and ccur represents respectively a maximum computing ability and currently occupied computing ability of the node, vk represents a ability measurement of node pi, when a service of type k is processed by node pi, M is the total amount of all service types that all the nodes in a service node set can implement. τi,k represents whether node pi has the service ability of the service type k required by a current request, where
Step 1), considering a certain node pi in the network as a service request accessing node when the node pi receives a service request command information r;
wherein the request command information r comprises: the requested service type kr, processing requirements of requested service, requested data volume ψk
Step 2) selecting a candidate processing node from all neighboring nodes of node pi by a selection function, according to a task feature and QoS demand regarding the service request command r, on the basis of a neighborhood information index table and a neighborhood node set in the network maintained by node pi, thus to form a candidate service node set Σir with a size of Ni,r;
optionally, the above described size of node set “Nk
Optionally, the above described selection function is described as follows:
Σir=F(Σ)=F3(F2(F1(Σ)))
where
F1(Σir)=Σi,1r={ζjεΣir|ti,j,k
F2(Σi,1r)=Σi,2r={ζjεΣi,1r| selecting the first Nk
F3(Σ)=Σir={ζjεΣi,2r|τj,k
where
the function T(i,j,σk
D(i,j,ψk
Step 3) matching by a scheduling module, according to a set time limit tk
Step 4), providing service directly by the current service request accessing node, if the service node selected in step 103) is the current service request accessing node; processing procedure of a node from a candidate service node list is as follows, if the execution node is the node from a candidate service node list:
the service request accessing node transmits, according to the execution node selected by the scheduling module, control information and data required for service processing to the execution node, and the requested service is executed by the node. After the selected execution node executes and completes the requested task, the processed result is transmitted to an output destination in one of the following ways according to information on a service result output destination in the service request:
1) returning, by the execution node, the processing result to the service result output destination; 2) returning the processing result to the service request accessing node, and then returning, by the service request accessing node, it back to the service result output destination;
3) returning the processing result to a specified node in the neighborhood node set, and then returning, by the specified node, it back to the service result output destination.
Step 5), releasing resources occupied for service processing, updating current status information of nodes and releasing the candidate service nodes for the service request accessing node, if the node selected in step 4) executes and completes the requested task and the service requesting end has achieved the task objective.
In addition, the present embodiments further provide a non-volatile computer readable medium with computer readable instructions stored thereon which, upon executed by one or more processors, cause the one or more processors to perform the following steps:
step 101) considering node pi in a network as a service request accessing node, when the node pi receives a service request command r;
wherein, the request command r comprises: a requested service type kr, processing requirements σk
step 102) extracting service type information and QoS demand regarding a request contained in the service request command, selecting by means of a candidate service point selection module a candidate service node, in conjunction with a neighborhood information index table and a neighborhood node set maintained by the node pi, and then to obtain a set of candidate service nodes Σir with a size of Ni,r;
step 103) matching by a scheduling module, according to the set time limit tk
step 104) providing service directly by the current service request accessing node, if the service node selected in step 103) is the current service request accessing node;
transmitting the service request command to the execution node and executing the requested service by the execution node, if the execution node is a node from a candidate service node list.
Optionally, the above described candidate service point selection module selects a candidate service node utilizing the following selection function:
Σir=F(Σ)=F3(F2(F1(Σ)))
where
F1(Σir)=Σi,1r={ζjεΣir|ti,j,k
F2(Σi,1r)=Σi,2r={ζjεΣi,1r| selecting the first Nk
F3(Σ)=Σir={ζjεΣi,2r|τj,k
the above described ζj={wi, sup, scur, cup, ccur, v1, . . . , vk, . . . , vM}, where wj represents the usable bandwidth of node pj, sup and scur represents respectively the maximum storage capacity and the currently occupied storage capacity of node pj, cup and ccur represents respectively the maximum computing ability and the currently occupied computing ability of node pj, vk represents the ability measurement of node pj when a service of type k is processed by the node pj, M is the total amount of all service types which all the nodes in the neighborhood node set are capable of implementing;
the above described function T(i,j,σk
the above described function D(i,j,ψk
Further optionally, after the above described step 104), the following step is further included:
step 105) releasing resources of the execution node occupied for service processing, updating current status information of the service request accessing node and the execution node, and releasing the candidate service nodes for the service request accessing node.
In a word, an objective of the technical solution provided in the present description lies in solving problems of network task efficient processing and nearby services, thereby providing a computing method through which the service node scope is flexible and adjustable, the service resource area is dynamic and autonomous, and the service provider is close to a source originating a request. With the above described embodiments, information on network edge node close to a service request may be detected and maintained to dynamically and flexibly construct a computing service network, high efficient on-site services may be provided to processing requests with low-delay service requirements, thereby meeting the increasing network processing demand and providing a new distributed network processing system.
Finally, it should be explained that the aforementioned embodiments are merely used for illustrating, rather than limiting the technical solutions of the present claims. Although described in detail with reference to the embodiments, those skilled in the art will understand that modifications or equivalent substitutions can be made to the technical solutions without departing from the scope and spirit of the technical solutions, and thereby should all be encompassed within the scope of the claims.
Number | Date | Country | Kind |
---|---|---|---|
2014 1 0083167 | Mar 2014 | CN | national |
Filing Document | Filing Date | Country | Kind |
---|---|---|---|
PCT/CN2014/081300 | 6/30/2014 | WO | 00 |
Publishing Document | Publishing Date | Country | Kind |
---|---|---|---|
WO2015/131470 | 9/11/2015 | WO | A |
Number | Name | Date | Kind |
---|---|---|---|
9160571 | Banerjee | Oct 2015 | B2 |
20120331147 | Dutta | Dec 2012 | A1 |
Number | Date | Country |
---|---|---|
103067524 | Apr 2013 | CN |
103347055 | Oct 2013 | CN |
103458052 | Dec 2013 | CN |
Entry |
---|
International Search Report issued in PCT/CN2014/081300 dated Dec. 12, 2014. |
Number | Date | Country | |
---|---|---|---|
20170019342 A1 | Jan 2017 | US |