The present disclosure relates to the field of computer technology, and in particular, to pulling a live stream.
With the development of network technology, more and more users watch network live streaming online. In addition to the existing live streaming platforms, more and more third-party business platforms have also joined the live streaming business. When a user watches network live streaming through a client of the third-party business platform, he or she usually needs to save the live stream generated by the existing live streaming platform to a source station of the third-party business platform, and then the client of the third-party business platform pulls the live stream from the source station of the third-party business platform.
The present disclosure provides a method for pulling a live stream, an electronic device, and a storage medium. The technical solutions of the present disclosure are as follows.
According to some arrangements of the present disclosure, a method for pulling a live stream, applied to a content delivery network, includes receiving a third-party business stream pull request for a target live stream from a third-party business client, determining a source business domain name and a live stream name of the target live stream based on the third-party business stream pull request, searching one or more local live streams for the target live stream based on the source business domain name and the live stream name, where the one or more local live streams are at a first node of the content delivery network, and forwarding, in response to a presence of the target live stream in the one or more local live streams, the target live stream in the one or more local live streams to the third-party business client.
According to some arrangements of the present disclosure, a method for pulling a live stream, applied to a third-party business client, includes obtaining a source business domain name and a live stream name of a target live stream, generating a third-party business stream pull request based on the source business domain name and the live stream name; sending the third-party business stream pull request to a first node in a content delivery network, causing the first node to search one or more local live streams for the target live stream based on the source business domain name and the live stream name in the third-party business stream pull request, and to forward the target live stream in the one or more local live streams to the third-party business client in response to a presence of the target live stream in the one or more local live streams; and receiving the target live stream forwarded by the first node.
According to some arrangements of the present disclosure, an electronic device includes a processor and a memory storing instructions executable by the processor. The processor is configured to execute the instructions to receive a third-party business stream pull request for a target live stream from a third-party business client, determine a source business domain name and a live stream name of the target live stream based on the third-party business stream pull request, search one or more local live streams for the target live stream based on the source business domain name and the live stream name, and forward, in response to a presence of the target live stream in the one or more local live streams, the target live stream in the one or more local live streams to the third-party business client.
According to some arrangements of the present disclosure, an electronic device includes a processor and a memory storing instructions executable by the processor. The processor is configured to execute instructions to obtain a source business domain name and a live stream name of a target live stream; generating a third-party business stream pull request based on the source business domain name and the live stream name, send the third-party business stream pull request to a first node in a content delivery network, causing the first node to search one or more local live streams for the target live stream based on the source business domain name and the live stream name in the third-party business stream pull request, and to forward the target live stream in the one or more local live streams to the third-party business client in response to a presence of the target live stream in the one or more local live streams; and receive the target live stream forwarded by the first node.
According to some arrangements of the present disclosure, there is provided a non-transitory storage medium, in response to instructions in the storage medium executed by a processor of an electronic device, causing the electronic device to receive a third-party business stream pull request for a target live stream from a third-party business client, determine a source business domain name and a live stream name of the target live stream based on the third-party business stream pull request; searching one or more local live streams for the target live stream based on the source business domain name and the live stream name, and forward, in response to a presence of the target live stream in the one or more local live streams, the target live stream in the one or more local live streams to the third-party business client.
According to some arrangements of the present disclosure, there is provided a non-transitory storage medium, in response to instructions in the storage medium executed by a processor of an electronic device, causing the electronic device to obtain a source business domain name and a live stream name of a target live stream, generate a third-party business stream pull request based on the source business domain name and the live stream name, send the third-party business stream pull request to a first node in a content delivery network, causing the first node to search one or more local live streams for the target live stream based on the source business domain name and the live stream name in the third-party business stream pull request, and to forward the target live stream in the one or more local live streams to the third-party business client in response to a presence of the target live stream in the one or more local live streams, and receive the target live stream forwarded by the first node.
It should be understood that the foregoing general description and the following detailed descriptions are exemplary and explanatory only and do not limit the present disclosure.
The accompanying drawings herein, incorporated into and form part of the specification, illustrate arrangements consistent with the present disclosure, and are used to explain the principles of the present disclosure in conjunction with the specification and do not constitute an undue limitation of the present disclosure.
In order to allow those of ordinary skills in the art to better understand the technical solutions of the present disclosure, the technical solutions in the arrangements of the present disclosure will be clearly and completely described below with reference to the accompanying drawings.
It should be noted that the terms “first,” “second,” etc. in the specification and claims of the present disclosure and the accompanying drawings above are used to distinguish similar objects and not necessarily used to describe a particular order or sequence. It should be understood that the term so used may be interchanged, where appropriate, so that arrangements of the present disclosure described herein can be implemented in an order other than those illustrated or described herein. The arrangements described in the following examples are not intended to represent all arrangements consistent with the present disclosure. Rather, they are only examples of devices and methods that are consistent with some aspects of the present disclosure, as detailed in the appended claims.
In a Content Delivery Network (CDN), a layer of virtual network on the basis of the existing Internet is formed by placing node servers in various parts of the network, enabling the CDN system to redirect user requests to the closest service node according to the comprehensive information such as network traffic and the connection and load of each node, as well as the distance to the user and the response time in real time, so that users can obtain the required content nearby to reduce network congestion, improve the response speed and hit rate of user access. The CDN system is applicable to site acceleration, on-demand, live streaming and other scenarios. When CDN is applied to live streaming, the data flow direction of the live stream is shown in
The method for pulling a live stream provided by the present disclosure may be applied in an application environment as shown in
In S210, a third-party business stream pull request for a target live stream is received from a third-party business client.
The third-party business client refers to the client of the business platform other than the source business platform that produces the live stream. The third-party business stream pull request refers to the request initiated by the third-party business client to pull the target live stream, which may be generated based on the pull-stream address of the third-party business client to pull the target live stream.
The initiator of the live streaming initiates the live streaming in the source business platform, and the viewer who wants to watch the live streaming watches the live streaming of the initiator through the third-party business platform. In this case, the viewer initiates the third-party business stream pull request to the edge node in the content delivery network through the third-party business client. The edge node, after receiving the third-party business stream pull request, pulls the live stream from the live streaming source station of the source business platform and returns the pulled live stream to the third-party business client, enabling the viewer to watch the corresponding live streaming. In some arrangements, the third-party business client generates the third-party business stream pull request based on the source business domain name and live stream name of the target live stream, and sends the third-party business stream pull request to a server corresponding to an edge node of the content delivery network. The server of the edge node receives the third-party business stream pull request sent by the third-party business client.
In S220, a source business domain name and a live stream name of the target live stream are determined based on the third-party business stream pull request.
The source business domain name is the domain name of the source business platform that produces the target live stream. The live stream name is the only unique identifier of the live stream. After receiving the third-party business stream pull request, the server of the edge node parses the third-party business stream pull request, and obtains the domain name of the source business platform where the target live stream is located and the live stream name of the target live stream from the third-party business stream pull request.
In one arrangement, the third-party business stream pull request includes a third-party business domain name, an agreed path, a live stream name, authentication information, and a source business domain name. The third-party business domain name is the domain name where the third-party platform for the new live streaming business is located. The agreed path is a static identifier agreed between the business party and the CDN vendor.
With respect to the target live stream, the initiator initiates the live streaming in the source business platform, and the live stream thereof is pushed to the live streaming source station of the source business platform, and the viewer of the third-party business platform wishes to pull the live stream from the live streaming source station of the source business platform, at which time the third-party business client adds a shared business party parameter to the stream pull request, which is marked as for example “shareHost,” and the parameter value is the domain name of the source business platform where the target live stream is located.
In some arrangements, the third-party business stream pull request may be specified using an Uniform Resource Locator (URL), such as http://third-party business domain name/agreed path/{live stream name}?{authentication information}&shareHost={source business domain name}. Other examples of the party business stream pull request can be likewise implemented.
In S230, one or more local live streams are searched for the target live stream based on the source business domain name and the live stream name.
After the edge node obtains the source business domain name and the live stream name of the target live stream, the edge node searches the local live stream(s) for the live stream with the same live stream name under the source service domain.
The local live stream of the edge node is a live stream that has been pulled in the past. In some arrangements, the edge node, after obtaining the source business domain name as well as the live stream name of the target live stream, compares the source business domain name as well as the live stream name of the target live stream, respectively, with the business domain name as well as the live stream name of the local live stream, and searches the local live stream(s) for the live stream whose business domain name is consistent with the source business domain name of the target live stream and whose live stream name is consistent with the live stream name of the target live stream.
In S240, in response to a presence of the target live stream in the one or more local live streams, the target live stream in the one or more local live streams is forwarded to the third-party business client.
When the edge node found the live stream with the same source service domain name and the same live stream name as the target live stream from the local live stream(s), the edge node forwards the live stream to the third-party business client.
In some arrangements, the edge node compares the source business domain name and the live stream name of the target live stream with the business domain name and the live stream name of the local live stream, respectively, and when it found a live stream in the local live stream(s) whose business domain name is consistent with the source business domain name of the target live stream and whose live stream name is consistent with the live stream name of the target live stream, the live stream is determined as the target live stream, and the edge node forwards the target live stream to the third-party business client.
For example, it is assumed that the source business platform is Kuaishou® live streaming platform, whose domain name (i.e., source business domain name) is represented as domainB, and the third-party business platform is AcFun, whose domain name (i.e., third-party business domain name) is represented as domainA. In this case, a live stream “kwai” exists in the live streaming source station of the Kuaishou® live streaming platform, and for any user of the Kuaishou® live streaming platform who wants to watch the live stream “kwai,” the user can send a source business stream pull request through the client of Kuaishou® platform to the edge node in the content delivery network, and the edge node can source back to the live streaming source station level by level according to the source business stream pull request, and pull the live stream “kwai”. The source business stream pull request is an URL such as http://domainB/app/kwai.flv?timestamp&signature. Other examples of the source business stream pull request can be likewise implemented. After the edge node pulls the live stream “kwai,” it forwards the live stream “kwai” to the client of Kuaishou® platform for users to watch.
In this case, when any user of the third-party business platform AcFun of the new live streaming business wants to watch the live stream “kwai” in Kuaishou® live streaming platform, the user triggers the viewing event for the live stream “kwai” in the third-party business client, causing the third-party business client to generate a third-party business stream pull request based on the source business domain name and the live stream name of the live stream “kwai,” and to send the third-party business stream pull request to the edge node in the content delivery network, where the third-party business pull request is an URL such as http://domianA/app/kwai.flv?timestamp& signature& shareHost=domainB. Other examples of the third-party business pull request can be likewise implemented. After receiving the request from the third-party business client, the edge node parses the parameters of the third-party business stream pull request, obtains the source business domain name and the live stream name of the live stream “kwai,” and since the edge node has previously pulled the live stream “kwai” once, i.e., the live stream “kwai” under the corresponding domain name of Kuaishou® live streaming platform already exists in the local live stream(s) of the edge node, the edge node directly reuses the live stream “kwai” and forwards the live stream “kwai” to the third-party business client for users to watch. It can be understood that reusing the edge node to pull the live stream “kwai” to the third-party business client in the content delivery network allows the content delivery network to reuse the popularity of the live stream to the greatest extent and reduce the back-to-source, providing for the user low latency, more fluid viewing experience.
In the above method for pulling the live stream, the third-party business stream pull request for the target live stream is received from the third-party business client, the source business domain name and the live stream name of the target live stream are determined according to the third-party business stream pull request, the local live stream(s) is searched for the target live stream according to the source business domain name and the live stream name, and in response to the presence of the target live stream in the local live stream(s), the pulled target live stream is forwarded to the third-party business client, so that when a new live streaming business is provided in the third-party business client, there is no need to save the live stream produced by the source business platform to the source station of the third-party business platform, but to directly obtain the live stream pulled by the edge node of the content delivery network from the live streaming source station of the source business platform, and share the live stream with the source business platform through the content delivery network, without producing the live stream, reducing the time for pulling the live stream and improving the efficiency of pulling streams.
In some arrangements, after searching the local live stream(s) for the target live stream based on the source business domain name and the live stream name, the method further includes: generating, in response to an absence of the target live stream in the one or more local live streams, a source business stream pull request based on the source business domain name and the live stream name; pulling the target live stream from an upper-level node by sourcing back to the upper-level node based on the source business stream pull request, causing the upper-level node to forward the target live stream; and receiving the target live stream forwarded by the upper-level node and forwarding the target live stream to the third-party business client.
The source business stream pull request is a request from the user of the source business platform to pull a live stream from the live streaming source station.
In some arrangements, when the target live stream does not exist in the local live stream(s) of the edge node, the edge node can generate a source business stream pull request based on the source business domain name and the live stream name in the third-party business stream pull request, and then source back to the upper-level node based on the source business stream pull request. After the upper-level node receives the source business stream pull request, the upper-level node can parse the source business stream pull request to obtain the source business domain name and live stream name of the target live stream, and then search the local live stream(s) of the upper-level node for the live stream whose source business domain name is consistent with the source business domain name of the target live stream, and whose live stream name is consistent with the live stream name of the target live stream. The upper-level node can also continue to source back to the live streaming source station level by level according to the source business stream pull request, and pull the target live stream from the live streaming source station of the source business platform. After the upper-level node obtains the target live stream, the upper-level node forwards the target live stream to the edge node, and then the edge node forwards the target live stream to the third-party business client for playback.
In the arrangements of the present disclosure, when the local live stream(s) of the edge node has no target live stream, the target live stream can be pulled from the upper-level node through the edge node in the content delivery network back to the source to the upper-level node, to achieve direct access to the target live stream of the live streaming source station of the source business platform pulled by the upper-level node, or to pull the target live stream through the upper-level node back to the source to the live streaming source station of the source business platform. Therefore, the popularity of the live stream is reused by the content delivery network to the greatest extent, realizing the live stream shared with the source business platform through the content delivery network, without producing live streams, reducing the time for pulling the live stream and improving the pulling efficiency.
In some arrangements, the upper-level node includes a first upper-level node at a level previous to the edge node. Pulling the target live stream from the upper-level node by sourcing back to the upper-level node based on the source business stream pull request includes: sending the source business stream pull request to the first upper-level node at the upper level, causing the first upper-level to search one or more local live streams of the first upper-level node for the target live stream based on the source business stream pull request; and receiving, in response to a presence of the target live stream in the one or more local live streams of the first upper-level node, the target live stream forwarded by the first upper-level node, where the target live stream is pulled from the live streaming source station by the first upper-level node reusing a back-to-source link of the target live stream.
The first upper-level node is a node at the level previous to the edge node and is an upper-level node of the content delivery network scheduling the edge node back to the source. In one arrangement, the first upper-level node may be the upper-level node that is closest to the edge node. For example, as shown in
After generating the source business stream pull request based on the source business domain name as well as the live stream name in the third-party business stream pull request, the edge node may source back to the closest first upper-level node based on the source business stream pull request. In some arrangements, the edge node sends the source business stream pull request to the first upper-level node. The first upper-level node, after receiving the source business stream pull request, searches the local live stream(s) of the first upper-level node for the target live stream based on the source business stream pull request, and when the target live stream exists in the local live stream(s) of the first upper-level node, the first upper-level node forwards the pulled target live stream to the edge node, and the edge node forwards the target live stream to the third-party business client. It is understood that the first upper-level node may reuse the back-to-source link of the target live stream to pull the target live stream from the live streaming source station, and then forward the pulled live stream to the edge node.
In the above arrangements, when there is no target live stream in the local live stream(s) of the edge node, the target live stream can be obtained by sourcing back to the upper node at the previous level, and the target live stream can be pulled from the local live stream(s) of the first upper-level node closest to the edge node to achieve that most of the back-to-source of the live stream is absorbed in the edge node and the upper-level node at the level previous to the edge node to reduce unnecessary sourcing and improve viewing quality while reduce the pressure on the source station.
The arrangements of the present disclosure are still illustrated with the source business platform being Kuaishou® live streaming platform and the third-party business platform being Acfun, where the domain name of the source business platform (i.e., the source business domain name) is represented as domainB, and the domain name of the third-party business platform station Acfun (i.e., the third-party business domain name) is represented as domainA. Referring to
In this case, when any user of the third-party business platform AcFun provided with a new live streaming business wants to watch the live stream “stream,” the user may trigger a watch event for the live stream “stream” at the third-party business client of terminal 110b, causing the third-party business client to generate a third-party business stream pull request based on the source business domain name and the live stream name of the live streaming “stream,” and to send the third-party business stream pull request to edge node 120c in the content delivery network, where the third-party business stream pull request is an URL such as http://domianA/app/stream.flv?timestamp&signature&shareHost=domainB. Other examples of the third-party business stream pull request can be likewise implemented. After receiving the request from the third-party business client, edge node 120c parses the parameters of the third-party business stream pull request and obtains the source business domain name and live stream name of the live stream “stream”. Since edge node 120c has not pulled the live stream “steam” before, there is no live stream “stream” in edge node 120c. In this case, edge node 120c processes the third-party business stream pull request as a source business stream pull request based on the source business domain name and the live stream name of the live stream, and sends the source business stream pull request to upper-level node 130a at a previous level. Upper-level node 130a, after receiving the source business stream pull request, searches the local live stream(s) of upper-level node 130a for the live stream “stream” according to the source business stream pull request. Since upper-level node 130a has pulled the live stream “stream” from the business source station, i.e., the live stream “stream” exists in the local live stream(s) of upper-level node 130a, upper-level node 130a forwards the pulled live stream “stream” to edge node 120c, and edge node 120a forwards the live stream “stream” to the third-party business client.
In some arrangements, after sending the source business stream pull request to the first upper-level node at the previous level, causing the first upper-level to search one or more local live streams of the first upper-level node for the target live stream based on the source business stream pull request, the method further includes: sourcing back through the first upper-level node to a second upper-level node of a same level as the first upper-level node in response to an absence of the target live stream in the one or more local live streams of the first upper-level node, causing the second upper-level node to search one or more local live streams of the second upper-level node for the target live stream based on the source business stream pull request; and obtaining, in response to a presence of the target live stream in the one or more local live streams of the second upper-level node, the target live stream pulled by the second upper-level node, where the target live stream is pulled by the second upper-level node reusing the back-to-source link of the target live stream from the live streaming source station of the source business platform or from the content delivery network.
The second upper-level node is a node at a level previous to the edge node, at the same level as the first upper-level node, and can be any upper-level node other than the first upper-level node of the content delivery network scheduling edge node back to the source.
After obtaining the source business stream pull request, the edge node sends the source business stream pull request to the first upper-level node. The first upper-level node, after receiving the source business stream pull request, searches the local live stream(s) of the first upper-level node for the target live stream according to the source business stream pull request. When the target live stream does not exist in the local live stream(s) of the first upper-level node, the first upper-level node sends the source business stream pull request to the second upper-level node of the same level. After receiving the source business stream pull request, the second upper-level node searches the local live stream(s) of the second upper-level node for the target live stream according to the source business stream pull request. When the target live stream exists in the local live stream(s) of the second upper-level node, the second upper-level node forwards the pulled target live stream to the first upper-level node. The first upper-level node forwards the received target live stream to the edge node, and the edge node forwards the target live stream to the third-party business client. It is understood that the second upper-level node may reuse the back-to-source link of the target live stream to pull the target live stream from the live streaming source station, and then forward the pulled live stream to the edge node.
In the above arrangements, when there is no target live stream in the local live stream(s) of the edge node, the target live stream can be obtained by sourcing back to the upper-level node at the level previous to the edge node, and when there is no target live stream in the local live stream(s) of the first upper-level node, the target live stream is pulled from the local live stream(s) of the second upper-level node by sending the source business stream pull request to the second upper-level node at the same level as the first upper-level node, in order to achieve that most of the back-to-source of the live stream is absorbed in the edge node and the upper-level node at the level previous to the edge node to reduce unnecessary sourcing and improve viewing quality while reduce the pressure on the source station.
The arrangements of the present disclosure are still illustrated with the source business platform being Kuaishou® live streaming platform and the third-party business platform being AcFun, where the domain name of the source business platform (i.e., the source business domain name) is represented as domainB and the domain name of the third-party business platform AcFun (i.e., the third-party business domain name) is represented as domainA. Referring to
In this case, when any user of the third-party business platform AcFun provided with a new live streaming business wants to watch the live stream “stream,” the user may trigger a watch event for the live stream “stream” at the third-party business client of terminal 110b, causing the third-party business client to generate a third-party business stream pull request based on the source business domain name and the live stream name of the live streaming “stream,” and to send the third-party business stream pull request to edge node 120c in the content delivery network, where the third-party business stream pull request is an URL such as http://domianA/app/stream.flv?timestamp&signature&shareHost=domainB Other examples of the third-party business stream pull request can be likewise implemented. After receiving the request from the third-party business client, edge node 120c parses the parameters of the third-party business stream pull request and obtains the source business domain name and live stream name of the live stream “stream”. Since edge node 120c has not pulled the live stream “steam” before, there is no live stream “stream” in edge node 120c. In this case, edge node 120c processes the third-party business stream pull request as a source business stream pull request based on the source business domain name and the live stream name of the live stream “stream,” and sends the source business stream pull request to upper-level node 130b at a previous level. Upper-level node 130b, after receiving the source business stream pull request, searches the local live stream(s) of upper-level node 130b for the live stream “stream” according to the source business stream pull request. Since upper-level node 130b has not pulled the live stream “steam” before, there is no live stream in upper-level node 130b, and upper-level node 130b sends the source business stream pull request to upper-level node 130a of the same level. After receiving the source business stream pull request, upper-level node 130a searches the local live stream(s) of upper-level node 130a for the live stream “stream” according to the source business stream pull request. Since upper-level node 130a has pulled the live stream from the business source station, that is, the live stream “stream” exists in the local live stream(s) of upper-level node 130a, upper-level node 130a forwards the pulled live stream “stream” to upper-level node 130b, and upper-level node 130b forwards the live stream “stream” to edge node 120c, which in turn forwards the live stream “stream” to the third-party business client.
In some arrangements, after pulling the target live stream from the upper-level node by sourcing back to the upper-level node based on the source business stream pull request, the method further includes: pulling, in response to an absence of the target live stream in the one or more local live streams of the second upper-level node, the target live stream through the first upper-level node from a live streaming source station or a source node of the content delivery network by sourcing back to the live streaming source station or the source node in a level-by-level mode based on the source business stream pull request.
The live streaming source station is the business self-built source station of the source business platform. Taking the source business platform as Kuaishou® live streaming platform for example, the live streaming source station is the live streaming source station in Kuaishou® live streaming platform. The source node of the content delivery network refers to the source station in the content delivery network that saves the live streaming source.
After obtaining the source business stream pull request, the edge node sends the source business stream pull request to the first upper-level node. The first upper-level node, after receiving the source business stream pull request, searches the local live stream(s) of the first upper-level node for the target live stream according to the source business stream pull request. When the target live stream does not exist in the local live stream(s) of the first upper-level node, the first upper-level node sends the source business stream pull request to the second upper-level of the same level. The second upper-level node, after receiving the source business stream pull request, searches the local live stream(s) of the second upper-level node for the target live stream according to the source business stream pull request. When the target live stream does not exist in the local live stream(s) of the second upper-level node, the first upper-level node sources back to the live stream station of the source business platform or the source node of the content delivery network level by level according to the source business stream pull request, and pulls the target live stream from the live streaming source station or the source node. After the first upper-level node pulls the target live stream, the first upper-level node forwards the target live stream to the edge node, and the edge node forwards the target live stream to the third-party business client.
In should be understood that, the decision of whether to source back to the live streaming source station of the source business platform or to the source node of the content delivery network is based on the scheduling results of the content delivery network.
In the above arrangements, when the edge node and the upper-level node(s) in the content delivery network have not pulled the target live stream, there is no target live stream in the local live stream(s) of the edge node and the upper-level node. In this case, the edge node can process the third-party business stream pull request as the source business stream pull request, so as to source back to the live streaming source station of the source business platform or the source node of the content delivery network level by level according to the source business stream pull request, and to pull the live stream from the live streaming source station or the source node, without saving the live stream produced by the source business platform to the source station of the third-party business platform, thereby sharing the live stream with the source business platform through the content delivery network, without producing the live stream, reducing the time for pulling the live stream and improving the pulling stream efficiency.
In S310, a source business domain name and a live stream name of a target live stream are obtained.
The source business domain name is the domain name of the source business platform that produces the target live stream. A third-party business client is installed on the terminal, and the user selects the live stream to be watched by operating on the third-party business client. The third-party business client, after receiving the operation information of the user, generates the source business domain name and the live stream name of the target live stream based on the user's selection.
In S320, a third-party business stream pull request is generated based on the source business domain name and the live stream name.
The third-party business client, after obtaining the source business domain name and the live stream name of the target live stream, generates a third-party business stream pull request based on the source business domain name and the live stream name.
In one arrangement, the third-party business stream pull request includes a third-party business domain name, an agreed path, a live stream name, authentication information, and a source business domain name. The third-party business domain name is the domain name where the third-party platform for the new live streaming business is located. The agreed path is a static identifier agreed between the business party and the CDN vendor. In some arrangements, the third-party business stream pull request may be specified as an URL such as http://third-party business domain name/agreed path/{live stream name}?{authentication information}&shareHost={source business domain name}. Other examples of the third-party business stream pull request can be likewise implemented.
In S330, the third-party business stream pull request is sent to an edge node in a content delivery network, causing the server of the edge node to search one or more local live streams for the target live stream based on the source business domain name and the live stream name in the third-party business stream pull request, and to forward the target live stream in the one or more local live streams to the third-party business client in response to a presence of the target live stream in the one or more local live streams.
The third-party business client sends the third-party business stream pull request to the edge node in the content delivery network, and the edge node, after receiving the third-party business stream pull request, obtains the source business domain name and the live stream name in the third-party business pull stream request, and searches the local live stream(s) of the edge node for the live stream with the same live stream name as the target live stream under the source business domain name. When the edge node found the live stream with the same source business domain name and the same live stream name as the target live stream from the local live stream(s), the edge node forwards the target live stream to the third-party business client.
In S340, the target live stream forwarded by the edge node is received.
The third-party business client receives the target live stream forwarded by the edge node and will play the live stream through the display device, enabling the user to watch the live stream through the third-party business terminal.
In the above method for pulling the live stream, the source business domain name and the live stream name of the target live stream are obtained; the third-party business stream pull request is generated based on the source business domain name and the live stream name; the third-party business stream pull request is sent to the edge node in the content delivery network, causing the edge node to search the local live stream(s) for the target live stream based on the source business domain name and the live stream name in the third-party business stream pull request, and to forward the pulled target live stream to the third-party business client in response to a presence of the target live stream in the local live stream(s); the target live stream forwarded by the edge node is received, realizing the corresponding client of the third-party business platform to play the live stream, and supporting the rapid incubation of the new live streaming business. The third-party business platform does not need to produce the live stream, and directly reuses the live stream of the existing source business platform to speed up the time for pulling the live stream.
The third-party business client obtains the source business domain name and the live stream name of the target live stream.
The third-party business client generates the third-party business stream pull request based on the source business domain name and the live stream name.
The third-party business client sends the third-party business stream pull request to the edge node in the content delivery network.
The edge node receives the third-party business stream pull request for the target live stream from the third-party business client.
The edge node determines the source business domain name and the live stream name of the target live stream based on the third-party business stream pull request.
The edge node searches the local live stream(s) for the target live stream based on the source business domain name and the live stream name.
When the target live stream exists in the local live stream(s), the edge node forwards the target live stream in the local live stream(s) to the third-party business client.
The third-party business client receives the target live stream forwarded by the edge node.
The above method for pulling the live stream can realize the live stream played by the corresponding client of the third-party business platform, supporting the rapid incubation of new business of live streaming. The third-party business platform does not need to produce the live stream, and directly reuses the live stream of the existing source business platform to speed up the time for pulling the live stream.
It should be understood that although the above blocks in the flowchart are shown in the order indicated by the arrows, the blocks are not necessarily executed in the order indicated by the arrows. Except as expressly stated herein, there is no strict order in which these blocks may be performed, and these blocks may be performed in other orders. Moreover, at least some of the above blocks in the flowchart may include multiple blocks or multiple stages, which are not necessarily executed at the same time, but may be executed at different times, and the order in which these blocks or stages are executed is not necessarily sequential, but may be executed alternately or alternately with other blocks or at least some of the blocks or stages in other blocks.
The request acquisition unit 510 is configured to receive a third-party business stream request for a target live stream from a third-party business client.
The domain name acquisition unit 520 is configured to determine a source business domain name and a live stream name of the target live stream based on the third-party business stream pull request.
The live stream search unit 530 is configured to search one or more local live streams for the target live stream based on the source business domain name and the live stream name.
The first live stream forwarding unit 540 is configured to forward, in response to a presence of the target live stream in the one or more local live streams, the target live stream in the one or more local live streams to the third-party business client.
In some arrangements, the apparatus for pulling the live stream further includes: a request generation unit configured to generate, in response to an absence of the target live stream in the one or more local live streams, a source business stream pull request based on the source business domain name and the live stream name; a request back-to-source unit configured to pull the target live stream from an upper-level node of the first node by sourcing back to the upper-level node based on the source business stream pull request, causing the upper-level node to forward the target live stream; and a second live stream forwarding unit configured to receive the target live stream forwarded by the upper-level node and forward the target live stream to the third-party business client.
In some arrangements, the upper-level node includes a first upper-level node at a level previous to the first node. The request back-to-source unit is configured to: send the source business stream pull request to the first upper-level node at the level previous to the first node, causing the first upper-level to search one or more local live streams of the first upper-level node for the target live stream based on the source business stream pull request; and receive, in response to a presence of the target live stream in the one or more local live streams of the first upper-level node, the target live stream forwarded by the first upper-level node, where the target live stream is pulled by the first upper-level node reusing a back-to-source link of the target live stream.
In one arrangement, the request back-to-source unit is configured to: send, in response to an absence of the target live stream in the one or more local live streams of the first upper-level node, the source business stream pull request through the first upper-level node to a second upper-level node of a same level as the first upper-level node, causing the second upper-level node to search one or more local live streams of the second upper-level node for the target live stream based on the source business stream pull request; and obtain, in response to a presence of the target live stream in the one or more local live streams of the second upper-level node, the target live stream pulled by the second upper-level node, wherein the target live stream is pulled by the second upper-level node reusing the back-to-source link of the target live stream.
In some arrangements, the request back-to-source unit is configured to: pull, in response to an absence of the target live stream in the one or more local live streams of the second upper-level node, the target live stream from a live streaming source station or a source node of the content delivery network by sourcing back to the live streaming source station or the source node in a level-by-level mode based on the source business stream pull request.
In some arrangements, the third-party business stream pull request includes a third-party business domain name, the live stream name, and the source business domain name.
The information acquisition unit 610 is configured to obtain a source business domain name and a live stream name of a target live stream.
The request generation unit 620 is configured to generate a third-party business stream pull request based on the source business domain name and the live stream name.
The request sending unit 630 is configured to send the third-party business stream pull request to a first node in a content delivery network, causing the first node to search one or more local live streams for the target live stream based on the source business domain name and the live stream name in the third-party business stream pull request, and to forward the target live stream in the one or more local live streams to the third-party business client in response to a presence of the target live stream in the one or more local live streams.
The live stream acquisition unit 640 is configured to receive the target live stream forwarded by the first node.
Regarding the apparatuses in the above arrangements, the specific way in which each module performs its operation has been described in detail in the arrangements concerning the method, and will not be described in detail here.
Referring to
The processing component 702 generally controls the overall operation of the device 700, such as operations associated with display, phone calls, data communications, camera operations, and recording operations. The processing component 702 may include one or more processors 720 to execute instructions to perform all or some blocks of the methods described above. Further, the processing component 702 may include one or more modules to facilitate interaction between the processing component 702 and other components. For example, the processing component 702 may include a multimedia module to facilitate interaction between the multimedia component 708 and the processing component 502.
The memory 704 is configured to store various types of data to support operation at device 700. Examples of such data include instructions, contact data, phonebook data, messages, pictures, videos, and the like, for any application or method operating on the device 700. The memory 704 may be implemented by any type of volatile or non-volatile storage device or combination thereof, such as a static random access memory (SRAM), an electrically erasable programmable read only memory (EEPROM), an erasable programmable read only memory (EPROM), a programmable read only memory (PROM), a read only memory (ROM), a magnetic memory, a flash memory, a magnetic disk, or an optical disk.
The power component 706 provides power to the various components of the device 700. The power component 706 may include a power management system, one or more power supplies, and other components associated with generating, managing, and distributing power to the device 700.
The multimedia component 708 includes a screen that provides an output interface between the device 700 and the user. In some arrangements, the screen may include a liquid crystal display (LCD) and a touch panel (TP). If the screen includes a touch panel, the screen may be implemented as a touch screen to receive input signals from the user. The touch panel includes one or more touch sensors to sense touch, swipe, and gestures on the touch panel. The touch sensor may not only sense the boundaries of a touch or swipe action, but also detect the duration and pressure associated with the touch or swipe action. In some arrangements, the multimedia component 708 includes a front-facing camera and/or a rear-facing camera. In response to the device 700 being in an operating mode, such as a shooting mode or a video mode, the front camera and/or the rear camera may receive external multimedia data. Each of the front and rear cameras may be a fixed optical lens system or have focal length and optical zoom capability.
The audio component 710 is configured to output and/or input audio signals. For example, the audio component 710 includes a microphone (MIC) that is configured to receive external audio signals in response to the device 700 being in an operating mode, such as a call mode, a recording mode, and a voice recognition mode. The received audio signals may be further stored in the memory 704 or transmitted via the communication component 716. In some arrangements, the audio component 710 also includes a speaker for outputting the audio signals.
The I/O interface 712 provides an interface between the processing component 702 and a peripheral interface module, and the above peripheral interface module may be keyboards, click wheels, buttons, or the like. These buttons may include, but are not limited to: home buttons, volume buttons, start buttons, and lock buttons.
The sensor component 714 includes one or more sensors for providing status assessment of various aspects of the device 700. For example, the sensor component 714 may detect the on/off state of the device 700, the relative positioning of components (for example, the components are the displayer and keypad of the device 700), and the sensor component 714 may also detect a change in the position of the device 700 or a component of the device 700, the presence or absence of the contact of the user with the device 700, the orientation or acceleration/deceleration of the device 700, and the temperature change of the device 700. The sensor component 714 may include a proximity sensor configured to detect the presence of a nearby object in response to the absence of any physical contact. The sensor component 714 may also include a light sensor, such as a CMOS or CCD image sensor, for use in imaging applications. In some arrangements, the sensor component 714 may also include an acceleration sensor, a gyroscope sensor, a magnetic sensor, a pressure sensor, or a temperature sensor.
The communication component 716 is configured to facilitate wired or wireless communication between the device 700 and other devices. The device 700 may access wireless networks based on communication standards, such as WiFi, carrier networks (for example, 2G 3G 4G or 5G), or a combination thereof. In one exemplary arrangement, the communication component 716 receives broadcast signals or broadcast related information from an external broadcast management system via a broadcast channel. In some arrangements, the communication component 716 also includes a near field communication (NFC) module to facilitate short-range communication. For example, the NFC module may be implemented based on radio frequency identification (RFID) technology, infrared data association (IrDA) technology, ultra-wideband (UWB) technology, Bluetooth (BT) technology and other technologies.
In some arrangements, the device 700 may be implemented by one or more application specific integrated circuits (ASICs), digital signal processors (DSPs), digital signal processing devices (DSPDs), programmable logic devices (PLDs), field Programmable gate arrays (FPGAs), controllers, microcontrollers, microprocessors or other electronic components for performing the above method.
In some arrangements, a non-transitory storage medium including instructions, such as a memory 704 including instructions, is also provided, and the instructions are executable by the processor 720 of the device 700 to perform the method described above. For example, the non-transitory computer-readable storage medium may be a ROM, a random access memory (RAM), a CD-ROM, a magnetic tape, a floppy disk, an optical disk data storage device, or the like.
The electronic device 800 may further include: a power component 824 configured to perform power management of the device 800; a wired or wireless network interface 826 configured to connect the device 800 to a network; and an input/output (I/O) interface 828. The electronic device 800 may operate based on an operating system stored in the memory 822, for example, Windows Server™, Mac OS X™, Unix™, Linux™, FreeBSD™, and the like.
In exemplary arrangements, there is also provided a storage medium including instructions, such as a memory 822 including instructions, the instructions being executable by a processor of an electronic device to accomplish the method described above. The storage medium may be a non-transitory computer readable storage medium, for example, the non-transitory computer readable storage medium may be ROM, random access memory (RAM), CD-ROM, magnetic tape, floppy disk, and optical data storage device, among others.
Other arrangements of the present disclosure will readily come to the mind of one skilled in the art upon consideration of the specification and practice of the arrangements disclosed herein. This application is intended to cover any variation, use, or adaptation of the present disclosure that follows the general principles of the present disclosure and includes commonly known or customary technical means in the art that are not disclosed herein. The specification and arrangements are to be considered exemplary only, and the true scope and spirit of the present disclosure is indicated by the following claims.
It should be understood that the present disclosure is not limited to the precise construction already described above and illustrated in the accompanying drawings, and that various modifications and changes may be made without departing from its scope. The scope of the present disclosure is limited only by the appended claims.
Number | Date | Country | Kind |
---|---|---|---|
202010051613.3 | Jan 2020 | CN | national |
The present application claims is a continuation application of International Application No. PCT/CN2021/072280 filed on Jan. 15, 2021, which claims priority to Chinese Patent Application No. 202010051613.3 filed on Jan. 17, 2020, the contents of which are incorporated herein by reference in their entireties.
Number | Date | Country | |
---|---|---|---|
Parent | PCT/CN2021/072280 | Jan 2021 | US |
Child | 17866267 | US |