本發(fā)明涉及通信技術領域,具體涉及一種流數(shù)據(jù)的傳輸資源的選取方法,以及和一種流數(shù)據(jù)的傳輸資源的選取裝置。
背景技術:
流數(shù)據(jù)為可以采用流式傳輸?shù)姆绞皆诰W(wǎng)絡上傳輸?shù)臄?shù)據(jù),大型網(wǎng)站系統(tǒng)經(jīng)常依賴于內(nèi)容分發(fā)網(wǎng)絡(Content Delivery Network,CDN)對流數(shù)據(jù)進行傳輸,內(nèi)容分發(fā)網(wǎng)絡是通過在現(xiàn)有的網(wǎng)絡中增加一層新的網(wǎng)絡結構,使用戶可以將數(shù)據(jù)傳輸?shù)綄墓?jié)點上或從對應的節(jié)點獲取所需的數(shù)據(jù)。在內(nèi)容分發(fā)網(wǎng)絡中,部署有傳輸節(jié)點,用于緩沖流數(shù)據(jù),就近給用戶提供服務,由于目前選取傳輸節(jié)點主要是基于靜態(tài)域名解析或者網(wǎng)絡地址,而域名劫持或網(wǎng)絡地址顯示為異地的情況經(jīng)常發(fā)生,導致選取的傳輸節(jié)點不準確,影響了傳輸?shù)乃俣群头€(wěn)定性。
尤其是在視頻直播應用或遠程攝像頭應用中,由于傳輸節(jié)點選取錯誤會導致視頻上傳或下載時卡頓,丟幀等現(xiàn)象。
技術實現(xiàn)要素:
鑒于上述問題,提出了本發(fā)明以便提供一種克服上述問題或者至少部分地解決上述問題的一種流數(shù)據(jù)的傳輸資源的選取方法和相應的裝置。
依據(jù)本發(fā)明的一個方面,提供了一種流數(shù)據(jù)的傳輸資源的選取方法,包括:
接收移動客戶端對當前流數(shù)據(jù)的傳輸資源的調(diào)度請求;
獲取所述移動客戶端所處位置的信息;
選取所述移動客戶端所處位置的信息的對應區(qū)域的傳輸資源。
可選地,所述獲取所述移動客戶端所處位置的信息包括:
根據(jù)所述移動客戶端的至少一種位置指示信息確定所述移動客戶端所處位置的信息。
可選地,所述位置指示信息包括所述移動客戶端的網(wǎng)絡地址信息,所述移動客戶端所處位置的信息包括所述移動客戶端所處地理區(qū)域的信息,所述根據(jù)所述移動客戶端的至少一種位置指示信息確定所述移動客戶端所處位置的信息包括:
從所述調(diào)度請求中提取所述移動客戶端的網(wǎng)絡地址信息;
查找所述網(wǎng)絡地址信息對應指示的所述移動客戶端所處地理區(qū)域的信息。
可選地,所述位置指示信息包括所述移動客戶端的定位信息,所述移動客戶端所處位置的信息包括所述移動客戶端所處地理區(qū)域的信息,所述根據(jù)所述移動客戶端的至少一種位置指示信息確定所述移動客戶端所處位置的信息包括:
接收所述移動客戶端調(diào)用位置定位程序獲取的定位信息;
通過訪問操作系統(tǒng)的地理區(qū)域信息獲取接口獲得的所述定位信息指示的所述移動客戶端所處地理區(qū)域的信息。
可選地,所述傳輸資源包括根據(jù)所述移動客戶端所處位置的信息選取的多個傳輸資源,每一傳輸資源包括傳輸節(jié)點集群,所述方法還包括:
從各傳輸節(jié)點集群選取多個候選傳輸節(jié)點。
可選地,所述方法還包括:
分別檢測所選取的各個候選傳輸節(jié)點的傳輸速度;
從多個候選傳輸節(jié)點中選取傳輸速度符合設定要求的目標傳輸節(jié)點以用于傳輸所述流數(shù)據(jù)。
可選地,所述分別檢測所選取的各個候選傳輸節(jié)點的傳輸速度包括:
根據(jù)所述移動客戶端對當前流數(shù)據(jù)的傳輸資源的調(diào)度請求,確定對應的測速類型;
向所述移動客戶端發(fā)送針對所述測速類型設置的測速策略,并接收反饋的傳輸速度。
可選地,所述根據(jù)所述移動客戶端對當前流數(shù)據(jù)的傳輸資源的調(diào)度請求,確定對應的測速類型包括:
若所述調(diào)度請求對應請求上行傳輸資源,則所述測速類型為上行測速;
所述測速策略包括:
向各個傳輸節(jié)點發(fā)送攜帶第一數(shù)據(jù)包的測速請求,根據(jù)所述傳輸節(jié)點針對所述第一數(shù)據(jù)包反饋的第二數(shù)據(jù)包進行測速,所述第一數(shù)據(jù)包大于第一設定數(shù)據(jù)量。
可選地,所述根據(jù)所述移動客戶端對當前流數(shù)據(jù)的傳輸資源的調(diào)度請求,確定對應的測速類型包括:
若所述調(diào)度請求對應請求下行傳輸資源,則所述測速類型為下行測速;
所述測速策略包括:
向各個傳輸節(jié)點發(fā)送攜帶第一數(shù)據(jù)包的測速請求,根據(jù)所述傳輸節(jié)點針對所述第一數(shù)據(jù)包反饋的第二數(shù)據(jù)包進行測速,所述第二數(shù)據(jù)包大于第一設定數(shù)據(jù)量。
可選地,所述根據(jù)所述移動客戶端對當前流數(shù)據(jù)的傳輸資源的調(diào)度請求,確定對應的測速類型包括:
若所述調(diào)度請求對應請求數(shù)據(jù)通信,則所述測速類型為網(wǎng)絡連通檢測;
所述測速策略包括:
向各個傳輸節(jié)點發(fā)送攜帶第一數(shù)據(jù)包的測速請求,根據(jù)所述傳輸節(jié)點針對所述第一數(shù)據(jù)包反饋的第二數(shù)據(jù)包進行測速,所述第一數(shù)據(jù)包和第二數(shù)據(jù)包均小于第二設定數(shù)據(jù)量。
可選地,所述方法還包括:
根據(jù)預先獲取的所選取傳輸節(jié)點的當前負載,預估所述傳輸節(jié)點應對調(diào)度節(jié)點集群的實際負載;
根據(jù)所述實際負載修正所選取的傳輸節(jié)點。
可選地,所述根據(jù)預先獲取的所選取傳輸節(jié)點的當前負載,預估所述傳輸節(jié)點應對調(diào)度節(jié)點集群的實際負載包括:
預估所述當前流數(shù)據(jù)被分配至所述傳輸節(jié)點后導致所述傳輸節(jié)點增加的第一負載增量;
根據(jù)所述第一負載增量,預估所述調(diào)度節(jié)點集群調(diào)度所述傳輸節(jié)點后導致所述傳輸節(jié)點增加的第二負載增量;
以所述調(diào)度節(jié)點集群導致所述傳輸節(jié)點增加的第二負載增量與所述當前負載之和,作為所述傳輸節(jié)點應對所述調(diào)度節(jié)點集群的實際負載。
可選地,所述根據(jù)所述第一負載增量,預估所述調(diào)度節(jié)點集群調(diào)度所述傳輸節(jié)點后導致所述傳輸節(jié)點增加的第二負載增量包括:
以所述第一負載增量與設定負載倍數(shù)的乘積,作為所述調(diào)度節(jié)點集群調(diào)度所述傳輸節(jié)點后導致所述傳輸節(jié)點增加的第二負載增量,所述設定負載倍數(shù)表征所述調(diào)度節(jié)點集群對所述傳輸節(jié)點的調(diào)度次數(shù)。
可選地,所述根據(jù)所述實際負載修正所選取的傳輸節(jié)點包括:
若所述實際負載超出所述傳輸節(jié)點的負載性能參數(shù)的值,則將所述傳輸節(jié)點替換為所述傳輸節(jié)點負載性能的值超出實際負載的另一傳輸節(jié)點。
可選地,所述方法還包括:
檢測所述移動客戶端所連接網(wǎng)絡歸屬的網(wǎng)絡運營商。
可選地,所述檢測所述移動客戶端所連接網(wǎng)絡歸屬的網(wǎng)絡運營商包括:
根據(jù)從所述調(diào)度請求中提取的網(wǎng)絡地址,識別所述移動客戶端所連接網(wǎng)絡歸屬的網(wǎng)絡運營商。
可選地,所述選取所述移動客戶端所處位置的信息的對應區(qū)域的傳輸資源包括:
選取與所述移動客戶端所處位置的信息指示的地理區(qū)域?qū)儆谕粎^(qū)域且與所述移動客戶端所連接網(wǎng)絡屬于同一網(wǎng)絡運營商的傳輸資源。
根據(jù)本發(fā)明的另一方面,提供了一種流數(shù)據(jù)的傳輸資源的選取裝置,包括:
調(diào)度請求接收模塊,用于接收移動客戶端對當前流數(shù)據(jù)的傳輸資源的調(diào)度請求;
位置獲取模塊,用于獲取所述移動客戶端所處位置的信息;
傳輸資源選取模塊,用于選取所述移動客戶端所處位置的信息的對應區(qū)域的傳輸資源。
可選地,所述位置獲取模塊,具體用于根據(jù)所述移動客戶端的至少一種位置指示信息確定所述移動客戶端所處位置信息。
可選地,所述位置指示信息包括所述移動客戶端的網(wǎng)絡地址信息,所述移動客戶端所處位置的信息包括所述移動客戶端所處地理區(qū)域的信息,所述位置獲取模塊包括:
網(wǎng)絡地址提取子模塊,用于從所述調(diào)度請求中提取所述移動客戶端的網(wǎng)絡地址信息;
地理區(qū)域查找子模塊,用于查找所述網(wǎng)絡地址信息對應指示的所述移動客戶端所處地理區(qū)域的信息。
可選地,所述位置指示信息包括所述移動客戶端的定位信息,所述移動客戶端所處位置的信息包括所述移動客戶端所處地理區(qū)域的信息,所述位置獲取模塊包括:
定位信息接收子模塊,用于接收所述移動客戶端調(diào)用位置定位程序獲取的定位信息;
地理區(qū)域獲取子模塊,用于通過訪問操作系統(tǒng)的地理區(qū)域信息獲取接口獲得的所述定位信息指示的所述移動客戶端所處地理區(qū)域的信息。
可選地,所述傳輸資源包括根據(jù)所述移動客戶端所處位置的信息選取的多個傳輸資源,每一傳輸資源包括傳輸節(jié)點集群,所述裝置還包括:
選取模塊,用于從各傳輸節(jié)點集群選取多個候選傳輸節(jié)點。
可選地,所述裝置還包括:
傳輸速度檢測模塊,用于分別檢測所選取的各個候選傳輸節(jié)點的傳輸速度;
傳輸節(jié)點選取模塊,用于從多個候選傳輸節(jié)點中選取傳輸速度符合設定要求的目標傳輸節(jié)點以用于傳輸所述流數(shù)據(jù)。
可選地,所述傳輸速度檢測模塊包括:
測速類型確定子模塊,用于根據(jù)所述移動客戶端對當前流數(shù)據(jù)的傳輸資源的調(diào)度請求,確定對應的測速類型;
傳輸速度接收子模塊,用于向所述移動客戶端發(fā)送針對所述測速類型設置的測速策略,并接收反饋的傳輸速度。
可選地,所述測速類型確定子模塊,具體用于若所述調(diào)度請求對應請求上行傳輸資源,則所述測速類型為上行測速;
所述測速策略包括:
向各個傳輸節(jié)點發(fā)送攜帶第一數(shù)據(jù)包的測速請求,根據(jù)所述傳輸節(jié)點針對所述第一數(shù)據(jù)包反饋的第二數(shù)據(jù)包進行測速,所述第一數(shù)據(jù)包大于第一設定數(shù)據(jù)量。
可選地,所述測速類型確定子模塊,具體用于若所述調(diào)度請求對應請求下行傳輸資源,則所述測速類型為下行測速;
所述測速策略包括:
向各個傳輸節(jié)點發(fā)送攜帶第一數(shù)據(jù)包的測速請求,根據(jù)所述傳輸節(jié)點針對所述第一數(shù)據(jù)包反饋的第二數(shù)據(jù)包進行測速,所述第二數(shù)據(jù)包大于第一設定數(shù)據(jù)量。
可選地,所述測速類型確定子模塊,具體用于若所述調(diào)度請求對應請求數(shù)據(jù)通信,則所述測速類型為網(wǎng)絡連通檢測;
所述測速策略包括:
向各個傳輸節(jié)點發(fā)送攜帶第一數(shù)據(jù)包的測速請求,根據(jù)所述傳輸節(jié)點針對所述第一數(shù)據(jù)包反饋的第二數(shù)據(jù)包進行測速,所述第一數(shù)據(jù)包和第二數(shù)據(jù)包均小于第二設定數(shù)據(jù)量。
可選地,所述裝置還包括:
負載預估模塊,用于根據(jù)預先獲取的所選取傳輸節(jié)點的當前負載,預估所述傳輸節(jié)點應對調(diào)度節(jié)點集群的實際負載;
傳輸節(jié)點修正模塊,用于根據(jù)所述實際負載修正所選取的傳輸節(jié)點。
可選地,所述負載預估模塊包括:
第一負載增量預估子模塊,用于預估所述當前流數(shù)據(jù)被分配至所述傳輸節(jié)點后導致所述傳輸節(jié)點增加的第一負載增量;
第二負載增量預估子模塊,用于根據(jù)所述第一負載增量,預估所述調(diào)度節(jié)點集群調(diào)度所述傳輸節(jié)點后導致所述傳輸節(jié)點增加的第二負載增量;
實際負載子模塊,用于以所述調(diào)度節(jié)點集群導致所述傳輸節(jié)點增加的第二負載增量與所述當前負載之和,作為所述傳輸節(jié)點應對所述調(diào)度節(jié)點集群的實際負載。
可選地,所述第二負載增量預估子模塊,具體用于以所述第一負載增量與設定負載倍數(shù)的乘積,作為所述調(diào)度節(jié)點集群調(diào)度所述傳輸節(jié)點后導致所述傳輸節(jié)點增加的第二負載增量,所述設定負載倍數(shù)表征所述調(diào)度節(jié)點集群對所述傳輸節(jié)點的調(diào)度次數(shù)。
可選地,所述傳輸節(jié)點修正模塊,具體用于若所述實際負載超出所述傳輸節(jié)點的負載性能參數(shù)的值,則將所述傳輸節(jié)點替換為所述傳輸節(jié)點負載性能的值超出實際負載的另一傳輸節(jié)點。
可選地,所述裝置還包括:
網(wǎng)絡運營商檢測模塊,用于檢測所述移動客戶端所連接網(wǎng)絡歸屬的網(wǎng)絡運營商。
可選地,所述網(wǎng)絡運營商檢測模塊,具體用于根據(jù)從所述調(diào)度請求中提取的網(wǎng)絡地址,識別所述移動客戶端所連接網(wǎng)絡歸屬的網(wǎng)絡運營商。
可選地,所述傳輸資源選取模塊,具體用于選取與所述移動客戶端所處位置的信息指示的地理區(qū)域?qū)儆谕粎^(qū)域且與所述移動客戶端所連接網(wǎng)絡屬于同一網(wǎng)絡運營商的傳輸資源。
根據(jù)本發(fā)明的一種流數(shù)據(jù)的傳輸資源的選取方法和裝置可以通過接收移動客戶端對當前流數(shù)據(jù)的傳輸資源的調(diào)度請求,獲取所述移動客戶端所處位置的信息,選取所述移動客戶端所處位置的信息的對應區(qū)域的傳輸資源,根據(jù)移動客戶端所處的位置選取傳輸資源,由于所處位置可以準確獲取,相比于根據(jù)網(wǎng)絡地址選取的方式,提高了選取傳輸資源的準確度,可以避免域名劫持導致的基于域名解析的傳輸資源調(diào)度不準確的問題,保障了傳輸?shù)乃俣群头€(wěn)定性。
上述說明僅是本發(fā)明技術方案的概述,為了能夠更清楚了解本發(fā)明的技術手段,而可依照說明書的內(nèi)容予以實施,并且為了讓本發(fā)明的上述和其它目的、特征和優(yōu)點能夠更明顯易懂,以下特舉本發(fā)明的具體實施方式。
附圖說明
通過閱讀下文優(yōu)選實施方式的詳細描述,各種其他的優(yōu)點和益處對于本領域普通技術人員將變得清楚明了。附圖僅用于示出優(yōu)選實施方式的目的,而并不認為是對本發(fā)明的限制。而且在整個附圖中,用相同的參考符號表示相同的部件。在附圖中:
圖1示出了根據(jù)本發(fā)明實施例一的流數(shù)據(jù)的傳輸資源的選取方法的步驟流程示意圖;
圖2示出了根據(jù)本發(fā)明實施例二的流數(shù)據(jù)的傳輸資源的選取方法的步驟流程示意圖;
圖3示出了根據(jù)本發(fā)明實施例三的流數(shù)據(jù)的傳輸資源的選取方法的步驟流程示意圖;
圖4示出了根據(jù)本發(fā)明實施例四的流數(shù)據(jù)的傳輸資源的選取裝置的結構框圖。
具體實施方式
下面將參照附圖更詳細地描述本公開的示例性實施例。雖然附圖中顯示了本公開的示例性實施例,然而應當理解,可以以各種形式實現(xiàn)本公開而不應被這里闡述的實施例所限制。相反,提供這些實施例是為了能夠更透徹地理解本公開,并且能夠?qū)⒈竟_的范圍完整的傳達給本領域的技術人員。
參照圖1,示出了根據(jù)本發(fā)明實施例一的流數(shù)據(jù)的傳輸資源的選取方法的步驟流程示意圖,具體可以包括如下步驟:
步驟101,接收移動客戶端對當前流數(shù)據(jù)的傳輸資源的調(diào)度請求。
在本發(fā)明實施例中,流數(shù)據(jù)為可以采用流式傳輸?shù)姆绞皆诰W(wǎng)絡上傳輸?shù)臄?shù)據(jù),傳輸資源是指傳輸當前流數(shù)據(jù)的至少一個傳輸節(jié)點,具體可以是傳輸節(jié)點或傳輸節(jié)點集群,傳輸節(jié)點集群是指由至少一個傳輸節(jié)點組成的傳輸節(jié)點集群,調(diào)度節(jié)點可以選擇傳輸節(jié)點集群中的至少一個傳輸節(jié)點作為當前流數(shù)據(jù)的傳輸節(jié)點。在具體實現(xiàn)中,流數(shù)據(jù)的傳輸大多存在于內(nèi)容分發(fā)網(wǎng)絡中,組建內(nèi)容分發(fā)網(wǎng)絡會分地區(qū)部署傳輸資源,因為一個傳輸節(jié)點無法承受很高的并發(fā)量,內(nèi)容分發(fā)網(wǎng)絡中通常存在多個傳輸節(jié)點,由調(diào)度節(jié)點分配流數(shù)據(jù)傳輸?shù)膫鬏敼?jié)點。
移動客戶端向調(diào)度節(jié)點發(fā)送調(diào)度請求,請求當前流數(shù)據(jù)的傳輸資源,調(diào)度節(jié)點接收調(diào)度請求。
調(diào)度節(jié)點在多種應用場景下均可以為流數(shù)據(jù)的傳輸選擇至少一個傳輸節(jié)點,具體而言,在視頻直播應用場景中,調(diào)度節(jié)點為視頻直播客戶端的流數(shù)據(jù)傳輸選取至少一個傳輸節(jié)點,視頻直播客戶端把錄制的視頻以流式傳輸方式傳送到至少一個傳輸節(jié)點,以使視頻流數(shù)據(jù)可以傳送到內(nèi)容分發(fā)網(wǎng)絡上的各個節(jié)點,從而讓其他客戶端能夠獲取,也就是流數(shù)據(jù)從傳輸節(jié)點傳送到需要的客戶端上;在遠程攝像頭應用場景中,調(diào)度節(jié)點為遠程攝像頭客戶端的流數(shù)據(jù)傳輸選取至少一個傳輸節(jié)點,遠程攝像頭客戶端把錄制的視頻以流式傳輸方式傳送到至少一個傳輸節(jié)點,以使視頻流數(shù)據(jù)可以傳送到內(nèi)容分發(fā)網(wǎng)絡上的各個節(jié)點,從而讓其他客戶端能夠獲取,也就是流數(shù)據(jù)從傳輸節(jié)點傳送到需要的客戶端上。
步驟102,獲取所述移動客戶端所處位置的信息。
在本發(fā)明實施例中,所處位置可以是地理區(qū)域,也可以是地理上的一個定位點,還可以是其他精度或是表述方式的信息,所處位置的信息可以是該位置的標識、具體內(nèi)容、還可以是該位置的其他維度的信息,以所處位置為地理區(qū)域為例,所處位置的信息可以是該區(qū)域的實際內(nèi)容、該區(qū)域的區(qū)域標識、該區(qū)域內(nèi)的人群信息等。調(diào)度節(jié)點可以用各種方式獲取移動客戶端所處位置的信息,本發(fā)明對此不作限制,例如從接收到的調(diào)度請求中提取出移動客戶端所處位置的信息、或在接收到調(diào)度請求后,向移動客戶端發(fā)送位置獲取請求,移動客戶端將所處位置的信息反饋給調(diào)度節(jié)點。
步驟103,選取所述移動客戶端所處位置的信息的對應區(qū)域的傳輸資源。
在本發(fā)明實施例中,調(diào)度節(jié)點獲取移動客戶端所處位置的信息后,根據(jù)獲取的所處位置的信息,查找信息指示的位置所屬的區(qū)域,選取該區(qū)域中至少一個傳輸資源,例如移動客戶端所處位置信息是北京市海淀區(qū)中關村,屬于北京市海淀區(qū),則選取處于北京市海淀區(qū)的傳輸資源。在具體實現(xiàn)中,組建內(nèi)容分發(fā)網(wǎng)絡會分地區(qū)部署傳輸資源,例如會在北京市海淀區(qū)部署傳輸節(jié)點或傳輸節(jié)點集群。
具體而言,調(diào)度節(jié)點可以根據(jù)獲取的移動客戶端所處位置的一個信息選取多個傳輸資源,也可以根據(jù)獲取的移動客戶端所處位置的多個信息選取多個傳輸資源,其中根據(jù)每個信息選取一個或多個傳輸資源。
綜上所述,依據(jù)本發(fā)明實施例,通過接收移動客戶端對當前流數(shù)據(jù)的傳輸資源的調(diào)度請求,獲取所述移動客戶端所處位置信息,選取與所述移動客戶端所處位置的信息對應區(qū)域的傳輸資源,根據(jù)移動客戶端的所處位置選取傳輸資源,由于所處位置可以準確獲取,相比于根據(jù)網(wǎng)絡地址選取的方式,提高了選取傳輸資源的準確度,可以避免域名劫持導致的基于域名解析的傳輸資源調(diào)度不準確的問題,保障了傳輸?shù)乃俣群头€(wěn)定性。
在本發(fā)明實施例中,優(yōu)選地,所述獲取所述移動客戶端所處位置信息的一種實現(xiàn)方式為,根據(jù)所述移動客戶端的至少一種位置指示信息確定所述移動客戶端所處位置的信息。
具體而言,位置指示信息至少有一種,具體可以包括網(wǎng)絡地址、定位信息等,在獲取到移動客戶端的至少一種位置指示信息后,可以根據(jù)獲取的每一種位置指示信息判定該種位置指示信息所對應的位置,也可以結合獲取的多種位置指示信息,共同判定多種位置指示信息所對應的位置。
在本發(fā)明實施例中,優(yōu)選地,所述根據(jù)所述移動客戶端的至少一種位置指示信息確定所述移動客戶端所處位置的信息的一種實現(xiàn)方式為,從所述調(diào)度請求中提取所述移動客戶端的網(wǎng)絡地址信息;查找所述網(wǎng)絡地址信息對應指示的所述移動客戶端所處地理區(qū)域的信息。具體而言,移動客戶端向調(diào)度節(jié)點發(fā)送調(diào)度請求,調(diào)度請求中攜帶有移動客戶端的網(wǎng)絡地址信息,調(diào)度節(jié)點從調(diào)度請求中提取出該網(wǎng)絡地址;調(diào)度節(jié)點可以調(diào)用到網(wǎng)絡地址數(shù)據(jù)庫,從網(wǎng)絡地址數(shù)據(jù)庫中查詢提取的網(wǎng)絡地址對應的地理區(qū)域信息,也就是得到了移動客戶端所處地理區(qū)域信息,例如北京市海淀區(qū)。
在本發(fā)明實施例中,優(yōu)選地,所述根據(jù)所述移動客戶端的至少一種位置指示信息確定所述移動客戶端所處位置的信息的另一種實現(xiàn)方式為,接收所述移動客戶端調(diào)用位置定位程序獲取的定位信息,通過訪問操作系統(tǒng)的地理區(qū)域信息獲取接口獲得的所述定位信息指示的所述移動客戶端所處地理區(qū)域的信息。具體而言,定位信息是指經(jīng)緯度信息,調(diào)度節(jié)點向移動客戶端發(fā)送地理區(qū)域的獲取請求,移動客戶端接收到請求后,開啟位置定位程序,獲取當前的經(jīng)緯度信息,例如獲取GPS(全稱:Global Positioning System,中文名:全球定位系統(tǒng))芯片反饋的經(jīng)緯度信息,訪問操作系統(tǒng)的地理區(qū)域信息獲取接口,獲得所述定位信息指示的所述移動客戶端所處地理區(qū)域的信息。其中,操作系統(tǒng)的地理區(qū)域信息獲取接口可以根據(jù)經(jīng)緯度信息得到對應的地理區(qū)域。由于通過位置定位程序獲取的定位信息,不會受到域名劫持或者網(wǎng)絡地址錯誤的影響,提高了獲取移動客戶端位置信息的準確性。
參照圖2,示出了根據(jù)本發(fā)明實施例二的流數(shù)據(jù)的傳輸資源的選取方法的步驟流程示意圖,具體可以包括如下步驟:
步驟201,接收移動客戶端對當前流數(shù)據(jù)的傳輸資源的調(diào)度請求。
步驟202,獲取所述移動客戶端所處位置的信息。
步驟203,檢測所述移動客戶端所連接網(wǎng)絡歸屬的網(wǎng)絡運營商。
在本發(fā)明實施例中,調(diào)度節(jié)點可以用各種方式檢測移動客戶端所連接網(wǎng)絡歸屬的網(wǎng)絡運營商,本發(fā)明對此不作限制,例如從接收到的調(diào)度請求中提取出所連接網(wǎng)絡歸屬的網(wǎng)絡運營商信息、或在接收到調(diào)度請求后,向移動客戶端發(fā)送位置信息獲取請求,移動客戶端所連接網(wǎng)絡歸屬的網(wǎng)絡運營商信息反饋給調(diào)度節(jié)點。
相比實施例一增加的步驟203為優(yōu)選的步驟,而且步驟202和步驟203的先后順序可以調(diào)整,本發(fā)明對此不作限定。
在本發(fā)明實施例中,優(yōu)選地,所述檢測所述移動客戶端所連接網(wǎng)絡歸屬的網(wǎng)絡運營商的一種實現(xiàn)方式可以是,根據(jù)從所述調(diào)度請求中提取的網(wǎng)絡地址,識別所述移動客戶端所連接網(wǎng)絡歸屬的網(wǎng)絡運營商。
具體而言,移動客戶端向調(diào)度節(jié)點的發(fā)送的調(diào)度請求中攜帶有網(wǎng)絡地址,調(diào)度節(jié)點將該網(wǎng)絡地址提取出來,并根據(jù)該網(wǎng)絡地址,識別出網(wǎng)絡地址對應的網(wǎng)絡運營商,例如調(diào)度節(jié)點可以調(diào)用網(wǎng)絡地址數(shù)據(jù)庫,從網(wǎng)絡地址數(shù)據(jù)庫中獲取網(wǎng)絡運營商信息,也就是移動客戶端所連接網(wǎng)絡歸屬的網(wǎng)絡運營商。
步驟204,選取與所述移動客戶端所處位置的信息指示的地理區(qū)域?qū)儆谕粎^(qū)域且與所述移動客戶端所連接網(wǎng)絡屬于同一網(wǎng)絡運營商的傳輸資源。
在本發(fā)明實施例中,調(diào)度節(jié)點獲取移動客戶端所處位置的信息和所連接網(wǎng)絡歸屬的網(wǎng)絡運營商后,根據(jù)獲取的所處位置的信息,查找信息指示的位置所屬的區(qū)域,再根據(jù)所屬的網(wǎng)絡運營商,選取所屬區(qū)域中和所述移動客戶端所連接網(wǎng)絡屬于同一網(wǎng)絡運營商的至少一個傳輸資源,例如移動客戶端所處位置信息是北京市海淀區(qū)中關村,屬于北京市海淀區(qū),移動客戶端的網(wǎng)絡運營商為中國聯(lián)通,則選取處于北京市海淀區(qū)中國聯(lián)通網(wǎng)絡中的傳輸資源。在具體實現(xiàn)中,組建內(nèi)容分發(fā)網(wǎng)絡會分地區(qū)部署傳輸資源,例如會在北京市海淀區(qū)中國聯(lián)通網(wǎng)絡中部署傳輸節(jié)點或傳輸節(jié)點集群。
具體而言,調(diào)度節(jié)點可以根據(jù)獲取的移動客戶端所處位置的一個信息選取多個傳輸資源,也可以根據(jù)獲取的移動客戶端所處位置的多個信息選取多個傳輸資源,其中根據(jù)每個信息選取一個或多個傳輸資源。
綜上所述,依據(jù)本發(fā)明實施例,通過接收移動客戶端對當前流數(shù)據(jù)的傳輸資源的調(diào)度請求,獲取所述移動客戶端所處位置的信息,檢測所述移動客戶端所連接網(wǎng)絡歸屬的網(wǎng)絡運營商,選取與所述移動客戶端所處位置的信息指示的地理區(qū)域?qū)儆谕粎^(qū)域且與所述移動客戶端所連接網(wǎng)絡屬于同一網(wǎng)絡運營商的傳輸資源,根據(jù)移動客戶端所處的位置和所屬的網(wǎng)絡運營商選取出傳輸資源,由于所處位置和所屬網(wǎng)絡運營商可以準確獲取,相比于根據(jù)網(wǎng)絡地址選取的方式,提高了選取傳輸資源的準確度,可以避免域名劫持導致的基于域名解析的傳輸資源調(diào)度不準確的問題,保障了傳輸?shù)乃俣群头€(wěn)定性。
參照圖3,示出了根據(jù)本發(fā)明實施例三的流數(shù)據(jù)的傳輸資源的選取方法的步驟流程示意圖,具體可以包括如下步驟:
步驟301,接收移動客戶端對當前流數(shù)據(jù)的傳輸資源的調(diào)度請求。
步驟302,獲取所述移動客戶端所處位置信息。
步驟303,選取所述移動客戶端所處位置的信息的對應區(qū)域的傳輸資源。
步驟304,從各傳輸節(jié)點集群選取多個候選傳輸節(jié)點。
在本發(fā)明實施例中,根據(jù)所述移動客戶端所處位置的信息選取的多個傳輸資源,每一傳輸資源包括傳輸節(jié)點集群,具體而言,調(diào)度節(jié)點可以根據(jù)獲取的移動客戶端所處位置的一個信息選取多個傳輸節(jié)點集群,也可以根據(jù)獲取的移動客戶端所處位置的多個信息選取多個傳輸節(jié)點集群,其中根據(jù)每個信息選取一個或多個傳輸節(jié)點集群。傳輸節(jié)點集群是指由至少一個傳輸節(jié)點組成的傳輸節(jié)點集群,調(diào)度節(jié)點可以選擇傳輸節(jié)點集群中的多個傳輸節(jié)點作為當前流數(shù)據(jù)的候選傳輸節(jié)點。相比其他實施例步驟304為優(yōu)選的步驟。
在本發(fā)明實施例中,調(diào)度節(jié)點可以根據(jù)流數(shù)據(jù)傳輸請求為流數(shù)據(jù)的傳輸在傳輸節(jié)點集群中選擇至少一個傳輸節(jié)點,具體可以依據(jù)調(diào)度節(jié)點可以調(diào)度的所有傳輸節(jié)點的負載情況等至少一種因素進行選擇。
調(diào)度節(jié)點用于根據(jù)流數(shù)據(jù)傳輸請求為流數(shù)據(jù)的傳輸選擇至少一個傳輸節(jié)點,可以依據(jù)流數(shù)據(jù)傳輸請求的發(fā)出端所在的網(wǎng)絡位置和/或調(diào)度節(jié)點可以調(diào)度的所有傳輸節(jié)點的負載情況進行選擇,還可以選擇歷史記錄中為當前流數(shù)據(jù)選取的傳輸節(jié)點。
從每個傳輸節(jié)點集群選取至少一個傳輸節(jié)點的一種優(yōu)選的實現(xiàn)方式具體可以分為以下幾個子步驟:
子步驟1,定期獲取當前傳輸節(jié)點集群中所有傳輸節(jié)點的當前負載。
在本發(fā)明實施例中,由于實時的從所有傳輸節(jié)點獲取當前負載將產(chǎn)生大量的輸入輸出需求,出于整體效率的考慮,調(diào)度節(jié)點集群的各調(diào)度節(jié)點分別定期獲取所有傳輸節(jié)點的當前負載,可以是所有傳輸節(jié)點將當前負載分別發(fā)送給各個調(diào)度節(jié)點,也可以是所有傳輸節(jié)點將當前負載發(fā)送至一個用于維護傳輸節(jié)點狀態(tài)的管理節(jié)點,再由調(diào)度節(jié)點定期從該管理節(jié)點獲取所有傳輸節(jié)點的當前負載。
實際應用中,內(nèi)容分發(fā)網(wǎng)絡中傳輸節(jié)點可以將當前負載發(fā)送至一個管理節(jié)點,管理節(jié)點將傳輸節(jié)點的當前負載發(fā)送至一個存儲節(jié)點中,調(diào)度節(jié)點定期從所述存儲節(jié)點獲取各個傳輸節(jié)點的當前負載。
子步驟2,按照各個傳輸節(jié)點的負載性能參數(shù)為各個傳輸節(jié)點構建對應的負載區(qū)間。
在本發(fā)明實施例中,負載性能參數(shù)是指描述傳輸節(jié)點最大負載能力的參數(shù),例如最大活動連接數(shù)、最大負載量、最大網(wǎng)絡帶寬等,各個傳輸節(jié)點的最大負載能力各不相同,負載區(qū)間是指在劃定的數(shù)值范圍中為各個傳輸節(jié)點分配一定的區(qū)間,使得所有傳輸節(jié)點的區(qū)間的合集可以占滿整個數(shù)值范圍,并且各區(qū)間無交集且邊界點連續(xù),也就是說分配給任意兩個傳輸節(jié)點的區(qū)間相互沒有共同的部分,并且一個區(qū)間的兩個邊界點一定是兩個相鄰區(qū)間的邊界點。調(diào)度節(jié)點為各個傳輸節(jié)點構建對應的負載區(qū)間,以用于后續(xù)通過計算當前流數(shù)據(jù)歸屬的負載區(qū)間選取出當前流數(shù)據(jù)的傳輸節(jié)點。
其中一種優(yōu)選的實現(xiàn)方式可以是劃定一個以各個傳輸節(jié)點的負載性能參數(shù)的值的總和為最大值,以零為最小值的數(shù)值范圍,在這個數(shù)值范圍內(nèi)根據(jù)各個傳輸節(jié)點的負載性能參數(shù)的值分配一定的負載區(qū)間,使得所有傳輸節(jié)點的區(qū)間的合集可以占滿整個數(shù)值范圍,其中根據(jù)各個傳輸節(jié)點的負載性能參數(shù)分配一定的負載區(qū)間的具體分配方式可以不作限定,可以根據(jù)實際需要設定比例,然后按照設定的比例進行分配。
將一個傳輸節(jié)點的負載性能參數(shù)的值到上一個傳輸節(jié)點的負載性能參數(shù)的值,且不包括上一個傳輸節(jié)點的負載性能參數(shù)的值之間的區(qū)間作為該傳輸節(jié)點的負載區(qū)間
實際應用中,優(yōu)選地,可以是使用任何合適的哈希函數(shù)來產(chǎn)生各個傳輸節(jié)點的負載性能參數(shù)的值對應的哈希值,然后按照各個傳輸節(jié)點的負載性能參數(shù)對應的哈希值為各個傳輸節(jié)點構建對應的負載區(qū)間,由于傳輸節(jié)點的負載性能參數(shù)的值對應的字符串可能是不規(guī)范的,用哈希函數(shù)可以將任意長度的負載性能參數(shù)變換成固定長度的哈希值。
在本發(fā)明實施例中,優(yōu)選地,各個傳輸節(jié)點的負載區(qū)間的寬度與其負載性能參數(shù)的值成正比,所述按照各個傳輸節(jié)點的負載性能參數(shù)為各個傳輸節(jié)點構建對應的負載區(qū)間的一種實現(xiàn)方式可以是,以各個負載性能參數(shù)的值為負載區(qū)間的寬度為各個傳輸節(jié)點構建負載區(qū)間。從而使得傳輸節(jié)點的負載性能參數(shù)的值和傳輸節(jié)點的負載區(qū)間成正比,以實現(xiàn)選取傳輸節(jié)點的概率與傳輸節(jié)點的最大負載能力成正比,優(yōu)化了傳輸節(jié)點分配效率,更大限度地利用了不同最大負載能力的傳輸節(jié)點的負載。
具體而言,各個傳輸節(jié)點的負載區(qū)間的寬度與其負載性能參數(shù)的值成正比,一種實現(xiàn)方式可以是劃定一個以各個傳輸節(jié)點的負載性能參數(shù)的值的總和為最大值,以零為最小值的數(shù)值范圍,在構建一個傳輸節(jié)點的負載區(qū)間時,可以以上個負載區(qū)間的終點為起始點,以該傳輸節(jié)點的負載性能參數(shù)的值為區(qū)間寬度,得到當前負載區(qū)間的終點,其中第一個負載區(qū)間的起始點為零,兩個數(shù)值上相鄰的負載區(qū)間相交的邊界點可以歸屬于前一個負載區(qū)間,也可以歸屬于后一個負載區(qū)間。例如,一共有三個傳輸節(jié)點,其中第一個傳輸節(jié)點的負載性能參數(shù)為10,第二個傳輸節(jié)點的負載性能參數(shù)為30,第三個傳輸節(jié)點的負載性能參數(shù)為20,劃定一個以60為最大值,以0為最小值的數(shù)值范圍,第一個傳輸節(jié)點的負載區(qū)間為從0到10,第二個傳輸節(jié)點的負載區(qū)間為從10到40,第四個傳輸節(jié)點的負載區(qū)間為從40到60。
子步驟3,根據(jù)所述當前流數(shù)據(jù)的數(shù)據(jù)標識查找所述當前流數(shù)據(jù)歸屬的負載區(qū)間。
在本發(fā)明實施例中,當前流數(shù)據(jù)的數(shù)據(jù)標識,用來唯一的標識流數(shù)據(jù)。將當前流數(shù)據(jù)的數(shù)據(jù)標識映射到所有傳輸節(jié)點的負載區(qū)間所處的數(shù)值范圍內(nèi),數(shù)據(jù)標識映射到負載區(qū)間就是所述當前流數(shù)據(jù)歸屬的負載區(qū)間,具體計算方式在本發(fā)明實施例中不作限定。
在本發(fā)明實施例中,優(yōu)選地,所述根據(jù)所述當前流數(shù)據(jù)的數(shù)據(jù)標識查找所述當前流數(shù)據(jù)歸屬的負載區(qū)間的一種實現(xiàn)方式可以是,計算所述數(shù)據(jù)標識對應的整數(shù)值;利用所述數(shù)據(jù)標識的整數(shù)值與所有傳輸節(jié)點的負載性能參數(shù)的值的總和做取余運算;查找取余結果對應的負載區(qū)間作為所述當前流數(shù)據(jù)歸屬的負載區(qū)間。計算所述數(shù)據(jù)屬性與所有傳輸節(jié)點的負載性能參數(shù)的總和做取余運算;查找取余結果歸屬的負載區(qū)間。
數(shù)據(jù)標識可以是任意的字符串,用任意可行的方法將該字符串轉換成一個整數(shù)值,本發(fā)明對具體采用的方法不作限制,例如可以采用CRC32算法(全稱循環(huán)冗余校驗32算法)將數(shù)據(jù)標識轉換為一個整數(shù)值。
所劃定的數(shù)值范圍以所有傳輸節(jié)點的負載性能參數(shù)的值的總和為最大值時,可以用數(shù)據(jù)標識的整數(shù)值除以所有傳輸節(jié)點的負載性能參數(shù)的值的總和,得到的余數(shù)一定小于所有傳輸節(jié)點的負載性能參數(shù)的值的總和,所以得到取余結果一定落入所述數(shù)值范圍內(nèi),而且余數(shù)在數(shù)值范圍中所在的區(qū)間就是取余結果對應的負載區(qū)間,也就是所述當前流數(shù)據(jù)歸屬的負載區(qū)間。由于數(shù)據(jù)標識具有隨機性,取余結果可以分散到各個負載區(qū)間,使得為當前流數(shù)據(jù)選取的至少一個傳輸節(jié)點具有隨機性,由于傳輸節(jié)點的負載區(qū)間的寬度和傳輸節(jié)點的負載性能參數(shù)的值成正比,所以每個傳輸節(jié)點被選取的概率和該傳輸節(jié)點的負載性能參數(shù)的值成正比,負載性能比較高的選中概率更大,實現(xiàn)了各個傳輸節(jié)點的負載均衡。
實際應用中,優(yōu)選地,調(diào)度節(jié)點用任意適用的哈希函數(shù)得到當前流數(shù)據(jù)的數(shù)據(jù)標識對應的哈希值,用該哈希值除以所創(chuàng)建的數(shù)值范圍的最大值,取余數(shù),所得余數(shù)在數(shù)值范圍中所在的區(qū)間就是當前流數(shù)據(jù)歸屬的負載區(qū)間。
具體而言,可以任何合適的哈希函數(shù)來產(chǎn)生當前流數(shù)據(jù)的數(shù)據(jù)標識對應的哈希值。例如,可以使用MD5摘要函數(shù)(MD5,全稱Message Digest Algorithm MD5,中文名消息摘要算法第五版),并且可以取MD5摘要函數(shù)結果的前八個字節(jié)來用作哈希值。可替換地,可以取MD5摘要函數(shù)結果的前四個字節(jié)來用作哈希值。可替換地,可以在僅需保證該哈希結果的充分唯一性的條件下使用更少、更多或不同的字節(jié)。根據(jù)當前流數(shù)據(jù)的數(shù)據(jù)標識對應的哈希值計算出當前流數(shù)據(jù)歸屬的負載區(qū)間。
在本發(fā)明實施例中,優(yōu)選地,所述數(shù)據(jù)標識包括客戶端預設字段、客戶端標識、時間戳信息、隨機數(shù)、流數(shù)據(jù)唯一標識中至少一種。
當前流數(shù)據(jù)的數(shù)據(jù)標識,用來唯一的標識流數(shù)據(jù),例如可以包括客戶端預設字段、客戶端標識、時間戳信息、隨機數(shù)、流數(shù)據(jù)唯一標識中至少一種。其中,客戶端預設字段可以是專門為區(qū)分流數(shù)據(jù)按照統(tǒng)一的規(guī)則設置的字段、客戶端標識是指客戶端的機器標識或其他網(wǎng)絡標識、時間戳信息是指字符串或編碼信息用于辨識流數(shù)據(jù)的時間日期、隨機數(shù)是指隨機生成的數(shù)字、流數(shù)據(jù)唯一標識是指可以唯一標識流數(shù)據(jù)的標識信息,例如MD5值(MD5,全稱Message Digest Algorithm MD5,中文名消息摘要算法第五版)。
子步驟4,從所述當前傳輸節(jié)點集群中選取所歸屬的負載區(qū)間對應的傳輸節(jié)點。
在本發(fā)明實施例中,調(diào)度節(jié)點根據(jù)當前流數(shù)據(jù)歸屬的負載區(qū)間,從所述當前傳輸節(jié)點集群中選取所歸屬的負載區(qū)間對應的傳輸節(jié)點。
步驟305,根據(jù)預先獲取的所選取傳輸節(jié)點的當前負載,預估所述傳輸節(jié)點應對調(diào)度節(jié)點集群的實際負載。
在本發(fā)明實施例中,調(diào)度節(jié)點可以預先獲取該調(diào)度節(jié)點所能調(diào)度的所有傳輸節(jié)點的當前負載,當前負載反映傳輸節(jié)點的負載情況,具體可以包括當前活動連接數(shù)、當前負載量、帶寬使用情況等。調(diào)度節(jié)點集群中的調(diào)度節(jié)點分別根據(jù)流數(shù)據(jù)傳輸請求為流數(shù)據(jù)的傳輸選擇至少一個傳輸節(jié)點,而且調(diào)度節(jié)點間相互沒有聯(lián)系,也就是一個調(diào)度節(jié)點為一個流數(shù)據(jù)的傳輸選擇了一個傳輸節(jié)點,其他調(diào)度節(jié)點不能實時的得知該傳輸節(jié)點因新增傳輸而增加的負載。
調(diào)度節(jié)點在為一個流數(shù)據(jù)的傳輸選取一個傳輸節(jié)點時,預估出因該流數(shù)據(jù)的傳輸而為該傳輸節(jié)點新增的負載,同時根據(jù)調(diào)度節(jié)點集群中調(diào)度節(jié)點的數(shù)量估算出調(diào)度節(jié)點集群中所有調(diào)度節(jié)點為該傳輸節(jié)點新增的負載,再以估算出的調(diào)度節(jié)點集群為該傳輸節(jié)點新增的負載和當前負載的總和作為預估的實際負載。
其中,實際負載是調(diào)度節(jié)點估算出的傳輸節(jié)點的負載,不一定是傳輸節(jié)點此時準確的負載。具體而言,以預先設定的每個調(diào)度節(jié)點對應增加至該傳輸節(jié)點的負載的總和,或者以所述當前流數(shù)據(jù)對應增加至所述傳輸節(jié)點的負載與設定負載倍數(shù)的乘積,作為所述調(diào)度節(jié)點集群增加至所述傳輸節(jié)點的負載。
在具體實現(xiàn)中,內(nèi)容分發(fā)網(wǎng)絡中傳輸節(jié)點可以將當前負載發(fā)送至一個管理節(jié)點,管理節(jié)點將各個傳輸節(jié)點的當前負載發(fā)送至一個存儲節(jié)點中,調(diào)度節(jié)點定期從所述存儲節(jié)點獲取各個傳輸節(jié)點的當前負載。
其中一種優(yōu)選的實現(xiàn)方式可以是,首先,預估所述當前流數(shù)據(jù)被分配至所述傳輸節(jié)點后導致所述傳輸節(jié)點增加的第一負載增量。
在本發(fā)明實施例中,第一負載增量是指調(diào)度節(jié)點選取傳輸節(jié)點后,可以根據(jù)當前流數(shù)據(jù)占用的計算資源、網(wǎng)絡帶寬資源等信息和該傳輸節(jié)點的當前活動連接數(shù)、當前負載量、當前網(wǎng)絡帶寬使用情況等信息,估算出當前流數(shù)據(jù)被分配至該傳輸節(jié)點后導致該傳輸節(jié)點增加的負載。
其次,根據(jù)所述第一負載增量,預估所述調(diào)度節(jié)點集群調(diào)度所述傳輸節(jié)點后導致所述傳輸節(jié)點增加的第二負載增量。
在本發(fā)明實施例中,以預先設定的調(diào)度節(jié)點集群調(diào)度傳輸節(jié)點導致所述傳輸節(jié)點增加的負載增量,或者以所述當前流數(shù)據(jù)被分配至所述傳輸節(jié)點后導致所述傳輸節(jié)點增加的第一負載增量與設定負載倍數(shù)的乘積,作為調(diào)度節(jié)點集群調(diào)度所述傳輸節(jié)點后導致所述傳輸節(jié)點增加的第二負載增量。
在本發(fā)明實施例中,優(yōu)選地,所述根據(jù)所述第一負載增量,預估所述調(diào)度節(jié)點集群調(diào)度所述傳輸節(jié)點后導致所述傳輸節(jié)點增加的第二負載增量的一種實現(xiàn)方式可以是,以所述第一負載增量與設定負載倍數(shù)的乘積,作為所述調(diào)度節(jié)點集群調(diào)度所述傳輸節(jié)點后導致所述傳輸節(jié)點增加的第二負載增量,所述設定負載倍數(shù)表征所述調(diào)度節(jié)點集群對所述傳輸節(jié)點的調(diào)度次數(shù)。
具體而言,調(diào)度節(jié)點集群中的調(diào)度節(jié)點分別根據(jù)流數(shù)據(jù)傳輸請求為流數(shù)據(jù)的傳輸選擇至少一個傳輸節(jié)點,而且調(diào)度節(jié)點間相互沒有聯(lián)系,也就是一個調(diào)度節(jié)點為一個流數(shù)據(jù)的傳輸選擇了一個傳輸節(jié)點,其他調(diào)度節(jié)點不能實時的得知該傳輸節(jié)點因新增傳輸而增加的負載,設定負載倍數(shù)表征所述調(diào)度節(jié)點集群對所述傳輸節(jié)點的調(diào)度次數(shù)。以所述當前流數(shù)據(jù)被分配至所述傳輸節(jié)點后導致所述傳輸節(jié)點增加的第一負載增量與設定負載倍數(shù)的乘積,作為所述調(diào)度節(jié)點集群調(diào)度所述傳輸節(jié)點后導致所述傳輸節(jié)點增加的第二負載增量。其中設定負載倍數(shù)可以根據(jù)調(diào)度節(jié)點集群中調(diào)度節(jié)點的數(shù)量確定,調(diào)度節(jié)點集群中調(diào)度節(jié)點的數(shù)量越大,設定負載倍數(shù)越大,但設定負載倍數(shù)小于調(diào)度節(jié)點集群中調(diào)度節(jié)點的數(shù)量,實際應用中,設定負載倍數(shù)可以根據(jù)實際使用情況進行調(diào)試,本發(fā)明對此不作限制,例如,調(diào)度節(jié)點集群中有5個調(diào)度節(jié)點,那么設定負載倍數(shù)可以設置為3.5。
其次,以所述調(diào)度節(jié)點集群導致所述傳輸節(jié)點增加的第二負載與所述當前負載之和,作為所述傳輸節(jié)點應對所述調(diào)度節(jié)點集群的實際負載。
在本發(fā)明實施例中,以調(diào)度節(jié)點集群導致所述傳輸節(jié)點增加的第二負載和當前負載求和,得到傳輸節(jié)點應對所述調(diào)度節(jié)點集群的實際負載,其中實際負載并不一定是該傳輸節(jié)點此時的實際負載,而是調(diào)度節(jié)點估算出的該傳輸節(jié)點的負載。
步驟306,根據(jù)所述實際負載修正所選取的傳輸節(jié)點。
在本發(fā)明實施例中,調(diào)度節(jié)點通過比較傳輸節(jié)點的實際負載和該傳輸節(jié)點的負載性能參數(shù),判定是否需要修正所選取的傳輸節(jié)點,其中,負載性能參數(shù)是指描述傳輸節(jié)點最大負載能力的參數(shù),例如最大活動連接數(shù)、最大負載量、最大網(wǎng)絡帶寬等。具體而言,所選取的傳輸節(jié)點的實際負載超過了該傳輸節(jié)點的負載性能參數(shù),則調(diào)度節(jié)點為當前流數(shù)據(jù)選取其他沒有超過負載性能參數(shù)的傳輸節(jié)點。
一種修正所選取的傳輸節(jié)點的實現(xiàn)方式可以是,調(diào)度節(jié)點可以隨機或者按設定順序在其他傳輸節(jié)點中進行選取,通過比較新選取的傳輸節(jié)點的實際負載和最大負載,判定是否需要修正新選取的傳輸節(jié)點。
實際應用中,調(diào)度節(jié)點中維護有預先獲取的所選取傳輸節(jié)點的當前負載,調(diào)度節(jié)點每次選取該傳輸節(jié)點時,以預估的所述傳輸節(jié)點應對所述調(diào)度節(jié)點集群的實際負載更新當前負載,直到調(diào)度節(jié)點再次獲取到傳輸節(jié)點的當前負載,以最新獲取的當前負載更新調(diào)度節(jié)點中記錄的當前負載。
在本發(fā)明實施例中,優(yōu)選地,所述根據(jù)所述實際負載修正所選取的傳輸節(jié)點的一種實現(xiàn)方式可以是,若所述實際負載超出所述傳輸節(jié)點的負載性能參數(shù)的值,則將所述傳輸節(jié)點替換為所述傳輸節(jié)點負載性能的值超出實際負載的另一傳輸節(jié)點。
在本發(fā)明實施例中,如果調(diào)度節(jié)點估算的傳輸節(jié)點的實際負載超過該傳輸節(jié)點的負載性能參數(shù)的值,那么調(diào)度節(jié)點選擇所述傳輸節(jié)點負載性能的值超出實際負載的另一傳輸節(jié)點,具體而言,其中一種方式可以是選取負載區(qū)間中的下一個傳輸節(jié)點,估算出該傳輸節(jié)點的實際負載,如果估算出的下一個傳輸節(jié)點的實際負載超過該傳輸節(jié)點的負載性能參數(shù),則再選取負載區(qū)間中的下一個傳輸節(jié)點,直到尋找到實際負載未超出所述傳輸節(jié)點負載性能的傳輸節(jié)點。
步驟307,分別檢測所選取的各個候選傳輸節(jié)點的傳輸速度。
在本發(fā)明實施例中,傳輸速度是指移動客戶端與傳輸節(jié)點之間傳輸數(shù)據(jù)的速度,可以通過移動客戶端和傳輸節(jié)點相互發(fā)送數(shù)據(jù)包,并得到發(fā)送數(shù)據(jù)包所用的時間,由數(shù)據(jù)包的大小和發(fā)送用時,得到傳輸速度。各個候選傳輸節(jié)點為修正后所選取的傳輸節(jié)點。調(diào)度節(jié)點可以基于不同方式獲取到移動終端的多種所處位置的信息,基于不同方式的檢測精度的不同,不同所處位置的信息實際所指向的位置可能是相同的,也可能是不同的。因此,進一步根據(jù)不同的位置選取不同的多個候選傳輸節(jié)點。相比其他實施例步驟307為優(yōu)選的步驟。
具體而言,調(diào)度節(jié)點可以根據(jù)當前流數(shù)據(jù)的傳輸是上行傳輸還是下行傳輸,決定檢測移動客戶端到傳輸節(jié)點的上行傳輸速度還是下行傳輸速度,或者還可以根據(jù)實際需要同時檢測移動客戶端到傳輸節(jié)點的上行傳輸速度和下行傳輸速度。
在本發(fā)明實施例中,優(yōu)選地,所述分別檢測所選取的各個候選傳輸節(jié)點的傳輸速度的一種實現(xiàn)方式可以是,根據(jù)所述移動客戶端對當前流數(shù)據(jù)的傳輸資源的調(diào)度請求,確定對應的測速類型;向所述移動客戶端發(fā)送針對所述測速類型設置的測速策略,并接收反饋的傳輸速度。
具體而言,調(diào)度節(jié)點根據(jù)移動客戶端對當前流數(shù)據(jù)的傳輸資源的調(diào)度請求,確定當前需要的測速類型,例如上行測速、下行測速,將該測速類型發(fā)送給移動客戶端,移動客戶端根據(jù)測速類型進行測速,并將測速的測速結果反饋給調(diào)度節(jié)點,從而實現(xiàn)了依據(jù)當前流數(shù)據(jù)的傳輸需求,確定進行何種測速。
在本發(fā)明實施例中,優(yōu)選地,所述根據(jù)所述移動客戶端對當前流數(shù)據(jù)的傳輸資源的調(diào)度請求,確定對應的測速類型的一種實現(xiàn)方式可以是,若所述調(diào)度請求對應請求上行傳輸資源,則所述測速類型為上行測速。所述測速策略包括:向各個傳輸節(jié)點發(fā)送攜帶第一數(shù)據(jù)包的測速請求,根據(jù)所述傳輸節(jié)點針對所述第一數(shù)據(jù)包反饋的第二數(shù)據(jù)包進行測速,所述第一數(shù)據(jù)包大于第一設定數(shù)據(jù)量。
具體而言,第一設定數(shù)據(jù)量是指用于檢測傳輸速度所需的最小數(shù)據(jù)量,移動客戶端向各傳輸節(jié)點分別發(fā)送測速請求,測速請求中攜帶有第一數(shù)據(jù)包,傳輸節(jié)點在接收到測速請求后,開始接收第一數(shù)據(jù)包,第一數(shù)據(jù)包接收完畢后,傳輸節(jié)點向移動客戶端發(fā)送第二數(shù)據(jù)包,移動客戶端通過計算開始發(fā)送第一數(shù)據(jù)包和開始接收第二數(shù)據(jù)包之間的時間,得到傳輸?shù)谝粩?shù)據(jù)包的傳輸速度,也就是得到從移動客戶端到傳輸節(jié)點的上行速度。通常在檢測上行速度時,第二數(shù)據(jù)包小于第一數(shù)據(jù)包的數(shù)據(jù)量,減少了不必要的網(wǎng)絡傳輸,進一步第二數(shù)據(jù)包最好小于第二設定數(shù)據(jù)量,其中,第二設定數(shù)據(jù)量是指用于檢測網(wǎng)絡連通性的最小數(shù)據(jù)量。
在本發(fā)明實施例中,優(yōu)選地,所述根據(jù)所述移動客戶端對當前流數(shù)據(jù)的傳輸資源的調(diào)度請求,確定對應的測速類型的另一種實現(xiàn)方式可以是,若所述調(diào)度請求對應請求下行傳輸資源,則所述測速類型為下行測速。所述測速策略包括:向各個傳輸節(jié)點發(fā)送攜帶第一數(shù)據(jù)包的測速請求,根據(jù)所述傳輸節(jié)點針對所述第一數(shù)據(jù)包反饋的第二數(shù)據(jù)包進行測速,所述第二數(shù)據(jù)包大于第一設定數(shù)據(jù)量。
具體而言,第一設定數(shù)據(jù)量是指用于檢測傳輸速度所需的最小數(shù)據(jù)量,移動客戶端向各傳輸節(jié)點分別發(fā)送測速請求,測速請求中攜帶有第一數(shù)據(jù)包,傳輸節(jié)點在接收到測速請求后,開始接收第一數(shù)據(jù)包,第一數(shù)據(jù)包接收完畢后,傳輸節(jié)點向移動客戶端發(fā)送第二數(shù)據(jù)包,移動客戶端通過計算開始發(fā)送第一數(shù)據(jù)包和完成接收第二數(shù)據(jù)包之間的時間,得到傳輸?shù)诙?shù)據(jù)包的傳輸速度,也就是得到從移動客戶端到傳輸節(jié)點的下行速度。通常在檢測下行速度時,第一數(shù)據(jù)包小于第二數(shù)據(jù)包的數(shù)據(jù)量,減少了不必要的網(wǎng)絡傳輸,進一步第一數(shù)據(jù)包最好小于第二設定數(shù)據(jù)量,其中,第二設定數(shù)據(jù)量是指用于檢測網(wǎng)絡連通性的最小數(shù)據(jù)量。
在本發(fā)明實施例中,優(yōu)選地,所述根據(jù)所述移動客戶端對當前流數(shù)據(jù)的傳輸資源的調(diào)度請求,確定對應的測速類型的另一種實現(xiàn)方式可以是,若所述調(diào)度請求對應請求上下行傳輸資源,則所述測速類型為上行測速和下行測速。所述測速策略包括:向各個傳輸節(jié)點發(fā)送攜帶第一數(shù)據(jù)包的測速請求,根據(jù)所述傳輸節(jié)點針對所述第一數(shù)據(jù)包反饋的第二數(shù)據(jù)包進行測速,所述第一數(shù)據(jù)包和第二數(shù)據(jù)包均大于第一設定數(shù)據(jù)量。
具體而言,第一設定數(shù)據(jù)量是指用于檢測傳輸速度所需的最小數(shù)據(jù)量,移動客戶端向各傳輸節(jié)點分別發(fā)送測速請求,測速請求中攜帶有第一數(shù)據(jù)包,傳輸節(jié)點在接收到測速請求后,開始接收第一數(shù)據(jù)包,第一數(shù)據(jù)包接收完畢后,傳輸節(jié)點向移動客戶端發(fā)送第二數(shù)據(jù)包,移動客戶端通過計算開始發(fā)送第一數(shù)據(jù)包和傳輸節(jié)點完成接收第一數(shù)據(jù)包之間的時間,得到傳輸?shù)谝粩?shù)據(jù)包的傳輸速度,也就是得到從移動客戶端到傳輸節(jié)點的上行速度,再通過計算開始發(fā)送第二數(shù)據(jù)包和移動客戶端完成接收第二數(shù)據(jù)包之間的時間,得到傳輸?shù)诙?shù)據(jù)包的傳輸速度,也就是得到從移動客戶端到傳輸節(jié)點的下行速度。
在本發(fā)明實施例中,優(yōu)選地,所述根據(jù)所述移動客戶端對當前流數(shù)據(jù)的傳輸資源的調(diào)度請求,確定對應的測速類型的另一種實現(xiàn)方式可以是,若所述調(diào)度請求對應請求數(shù)據(jù)通信,則所述測速類型為網(wǎng)絡連通檢測。所述測速策略包括:向各個傳輸節(jié)點發(fā)送攜帶第一數(shù)據(jù)包的測速請求,根據(jù)所述傳輸節(jié)點針對所述第一數(shù)據(jù)包反饋的第二數(shù)據(jù)包進行測速,所述第一數(shù)據(jù)包和第二數(shù)據(jù)包均小于第二設定數(shù)據(jù)量。
具體而言,第二設定數(shù)據(jù)量是指用于檢測網(wǎng)絡連通性的最小數(shù)據(jù)量,移動客戶端向各傳輸節(jié)點分別發(fā)送測速請求,測速請求中攜帶有第一數(shù)據(jù)包,傳輸節(jié)點在接收到測速請求后,開始接收第一數(shù)據(jù)包,第一數(shù)據(jù)包接收完畢后,傳輸節(jié)點向移動客戶端發(fā)送第二數(shù)據(jù)包,從而完成了對網(wǎng)絡連通性的檢測。由于所述第一數(shù)據(jù)包和第二數(shù)據(jù)包均小于第二設定數(shù)據(jù)量,減少了不必要的網(wǎng)絡傳輸,使檢測網(wǎng)絡連通性更具及時性。
步驟308,從多個候選傳輸節(jié)點中選取傳輸速度符合設定要求的目標傳輸節(jié)點以用于傳輸所述流數(shù)據(jù)。
在本發(fā)明實施例中,傳輸速度符合設定要求是指可以滿足傳輸需要的傳輸速度要求,具體設定要求可以根據(jù)實際需要進行設定,本發(fā)明實施例對此不作限定,調(diào)度節(jié)點檢測到選取的多個候選傳輸節(jié)點的傳輸速度后,選取出其中符合設定要求的目標傳輸節(jié)點。
綜上所述,依據(jù)本發(fā)明實施例,通過接收移動客戶端對當前流數(shù)據(jù)的傳輸資源的調(diào)度請求,獲取所述移動客戶端所處位置信息,選取所述移動客戶端所處位置的信息的對應區(qū)域的傳輸資源,根據(jù)移動客戶端所述的位置選取傳輸資源,由于所處位置可以準確獲取,相比于根據(jù)網(wǎng)絡地址選取的方式,提高了選取傳輸資源的準確度,可以避免域名劫持導致的基于域名解析的傳輸資源調(diào)度不準確的問題,保障了傳輸?shù)乃俣群头€(wěn)定性。
其次,從各傳輸節(jié)點集群選取多個候選傳輸節(jié)點,根據(jù)預先獲取的所選取傳輸節(jié)點的當前負載,預估所述傳輸節(jié)點應對調(diào)度節(jié)點集群的實際負載,根據(jù)所述實際負載修正所選取的傳輸節(jié)點,由于當前負載不能反映傳輸節(jié)點實時的負載情況,而且存在多個調(diào)度節(jié)點可以同時為流數(shù)據(jù)的傳輸分配傳輸節(jié)點,各個調(diào)度節(jié)點可以預估傳輸節(jié)點的實際負載,將實際負載過大的傳輸節(jié)點修正為負載沒有過大的傳輸節(jié)點,避免了調(diào)度節(jié)點集群中的調(diào)度節(jié)點同時為流數(shù)據(jù)的傳輸選取傳輸節(jié)點導致的單個傳輸節(jié)點負載過大的問題。
最后,分別檢測所選取的各個候選傳輸節(jié)點的傳輸速度,從多個候選傳輸節(jié)點中選取傳輸速度符合設定要求的目標傳輸節(jié)點以用于傳輸所述流數(shù)據(jù),選取出不同的傳輸節(jié)點集群,再從中選取出多個傳輸節(jié)點,選取出傳輸速度滿足需要的傳輸節(jié)點,實現(xiàn)對上傳或下載速度相對較快的傳輸節(jié)點的優(yōu)先選擇。
參照圖4,示出了根據(jù)本發(fā)明實施例四的流數(shù)據(jù)的傳輸資源的選取裝置的結構框圖,具體可以包括如下模塊:
調(diào)度請求接收模塊401,用于接收移動客戶端對當前流數(shù)據(jù)的傳輸資源的調(diào)度請求;
位置獲取模塊402,用于獲取所述移動客戶端所處位置的信息;
傳輸資源選取模塊403,用于選取所述移動客戶端所處位置的信息的對應區(qū)域的傳輸資源。
優(yōu)選地,所述位置獲取模塊,具體用于根據(jù)所述移動客戶端的至少一種位置指示信息確定所述移動客戶端所處位置信息。
優(yōu)選地,所述位置指示信息包括所述移動客戶端的網(wǎng)絡地址信息,所述移動客戶端所處位置的信息包括所述移動客戶端所處地理區(qū)域的信息,所述位置獲取模塊包括:
網(wǎng)絡地址提取子模塊,用于從所述調(diào)度請求中提取所述移動客戶端的網(wǎng)絡地址信息;
地理區(qū)域查找子模塊,用于查找所述網(wǎng)絡地址信息對應指示的所述移動客戶端所處地理區(qū)域的信息。
優(yōu)選地,所述位置指示信息包括所述移動客戶端的定位信息,所述移動客戶端所處位置的信息包括所述移動客戶端所處地理區(qū)域的信息,所述位置獲取模塊包括:
定位信息接收子模塊,用于接收所述移動客戶端調(diào)用位置定位程序獲取的定位信息;
地理區(qū)域獲取子模塊,用于通過訪問操作系統(tǒng)的地理區(qū)域信息獲取接口獲得的所述定位信息指示的所述移動客戶端所處地理區(qū)域的信息。
優(yōu)選地,所述傳輸資源包括根據(jù)所述移動客戶端所處位置的信息選取的多個傳輸資源,每一傳輸資源包括傳輸節(jié)點集群,所述裝置還包括:
選取模塊,用于從各傳輸節(jié)點集群選取多個候選傳輸節(jié)點。
優(yōu)選地,所述裝置還包括:
傳輸速度檢測模塊,用于分別檢測所選取的各個候選傳輸節(jié)點的傳輸速度;
傳輸節(jié)點選取模塊,用于從多個候選傳輸節(jié)點中選取傳輸速度符合設定要求的目標傳輸節(jié)點以用于傳輸所述流數(shù)據(jù)。
優(yōu)選地,所述傳輸速度檢測模塊包括:
測速類型確定子模塊,用于根據(jù)所述移動客戶端對當前流數(shù)據(jù)的傳輸資源的調(diào)度請求,確定對應的測速類型;
傳輸速度接收子模塊,用于向所述移動客戶端發(fā)送針對所述測速類型設置的測速策略,并接收反饋的傳輸速度。
優(yōu)選地,所述測速類型確定子模塊,具體用于若所述調(diào)度請求對應請求上行傳輸資源,則所述測速類型為上行測速;
所述測速策略包括:
向各個傳輸節(jié)點發(fā)送攜帶第一數(shù)據(jù)包的測速請求,根據(jù)所述傳輸節(jié)點針對所述第一數(shù)據(jù)包反饋的第二數(shù)據(jù)包進行測速,所述第一數(shù)據(jù)包大于第一設定數(shù)據(jù)量。
優(yōu)選地,所述測速類型確定子模塊,具體用于若所述調(diào)度請求對應請求下行傳輸資源,則所述測速類型為下行測速;
所述測速策略包括:
向各個傳輸節(jié)點發(fā)送攜帶第一數(shù)據(jù)包的測速請求,根據(jù)所述傳輸節(jié)點針對所述第一數(shù)據(jù)包反饋的第二數(shù)據(jù)包進行測速,所述第二數(shù)據(jù)包大于第一設定數(shù)據(jù)量。
優(yōu)選地,所述測速類型確定子模塊,具體用于若所述調(diào)度請求對應請求數(shù)據(jù)通信,則所述測速類型為網(wǎng)絡連通檢測;
所述測速策略包括:
向各個傳輸節(jié)點發(fā)送攜帶第一數(shù)據(jù)包的測速請求,根據(jù)所述傳輸節(jié)點針對所述第一數(shù)據(jù)包反饋的第二數(shù)據(jù)包進行測速,所述第一數(shù)據(jù)包和第二數(shù)據(jù)包均小于第二設定數(shù)據(jù)量。
優(yōu)選地,所述裝置還包括:
負載預估模塊,用于根據(jù)預先獲取的所選取傳輸節(jié)點的當前負載,預估所述傳輸節(jié)點應對調(diào)度節(jié)點集群的實際負載;
傳輸節(jié)點修正模塊,用于根據(jù)所述實際負載修正所選取的傳輸節(jié)點。
優(yōu)選地,所述負載預估模塊包括:
第一負載增量預估子模塊,用于預估所述當前流數(shù)據(jù)被分配至所述傳輸節(jié)點后導致所述傳輸節(jié)點增加的第一負載增量;
第二負載增量預估子模塊,用于根據(jù)所述第一負載增量,預估所述調(diào)度節(jié)點集群調(diào)度所述傳輸節(jié)點后導致所述傳輸節(jié)點增加的第二負載增量;
實際負載子模塊,用于以所述調(diào)度節(jié)點集群導致所述傳輸節(jié)點增加的第二負載增量與所述當前負載之和,作為所述傳輸節(jié)點應對所述調(diào)度節(jié)點集群的實際負載。
優(yōu)選地,所述第二負載增量預估子模塊,具體用于以所述第一負載增量與設定負載倍數(shù)的乘積,作為所述調(diào)度節(jié)點集群調(diào)度所述傳輸節(jié)點后導致所述傳輸節(jié)點增加的第二負載增量,所述設定負載倍數(shù)表征所述調(diào)度節(jié)點集群對所述傳輸節(jié)點的調(diào)度次數(shù)。
優(yōu)選地,所述傳輸節(jié)點修正模塊,具體用于若所述實際負載超出所述傳輸節(jié)點的負載性能參數(shù)的值,則將所述傳輸節(jié)點替換為所述傳輸節(jié)點負載性能的值超出實際負載的另一傳輸節(jié)點。
優(yōu)選地,所述裝置還包括:
網(wǎng)絡運營商檢測模塊,用于檢測所述移動客戶端所連接網(wǎng)絡歸屬的網(wǎng)絡運營商。
優(yōu)選地,所述網(wǎng)絡運營商檢測模塊,具體用于根據(jù)從所述調(diào)度請求中提取的網(wǎng)絡地址,識別所述移動客戶端所連接網(wǎng)絡歸屬的網(wǎng)絡運營商。
優(yōu)選地,所述傳輸資源選取模塊,具體用于選取與所述移動客戶端所處位置的信息指示的地理區(qū)域?qū)儆谕粎^(qū)域且與所述移動客戶端所連接網(wǎng)絡屬于同一網(wǎng)絡運營商的傳輸資源。
綜上所述,依據(jù)本發(fā)明實施例,通過接收移動客戶端對當前流數(shù)據(jù)的傳輸資源的調(diào)度請求,獲取所述移動客戶端所處位置信息,選取與所述移動客戶端所處位置的信息對應區(qū)域的傳輸資源,根據(jù)移動客戶端的所處位置選取傳輸資源,由于所處位置可以準確獲取,相比于根據(jù)網(wǎng)絡地址選取的方式,提高了選取傳輸資源的準確度,可以避免域名劫持導致的基于域名解析的傳輸資源調(diào)度不準確的問題,保障了傳輸?shù)乃俣群头€(wěn)定性。
在此提供的算法和顯示不與任何特定計算機、虛擬系統(tǒng)或者其它設備固有相關。各種通用系統(tǒng)也可以與基于在此的示教一起使用。根據(jù)上面的描述,構造這類系統(tǒng)所要求的結構是顯而易見的。此外,本發(fā)明也不針對任何特定編程語言。應當明白,可以利用各種編程語言實現(xiàn)在此描述的本發(fā)明的內(nèi)容,并且上面對特定語言所做的描述是為了披露本發(fā)明的最佳實施方式。
在此處所提供的說明書中,說明了大量具體細節(jié)。然而,能夠理解,本發(fā)明的實施例可以在沒有這些具體細節(jié)的情況下實踐。在一些實例中,并未詳細示出公知的方法、結構和技術,以便不模糊對本說明書的理解。
類似地,應當理解,為了精簡本公開并幫助理解各個發(fā)明方面中的一個或多個,在上面對本發(fā)明的示例性實施例的描述中,本發(fā)明的各個特征有時被一起分組到單個實施例、圖、或者對其的描述中。然而,并不應將該公開的方法解釋成反映如下意圖:即所要求保護的本發(fā)明要求比在每個權利要求中所明確記載的特征更多的特征。更確切地說,如下面的權利要求書所反映的那樣,發(fā)明方面在于少于前面公開的單個實施例的所有特征。因此,遵循具體實施方式的權利要求書由此明確地并入該具體實施方式,其中每個權利要求本身都作為本發(fā)明的單獨實施例。
本領域那些技術人員可以理解,可以對實施例中的設備中的模塊進行自適應性地改變并且把它們設置在與該實施例不同的一個或多個設備中??梢园褜嵤├械哪K或單元或組件組合成一個模塊或單元或組件,以及此外可以把它們分成多個子模塊或子單元或子組件。除了這樣的特征和/或過程或者單元中的至少一些是相互排斥之外,可以采用任何組合對本說明書(包括伴隨的權利要求、摘要和附圖)中公開的所有特征以及如此公開的任何方法或者設備的所有過程或單元進行組合。除非另外明確陳述,本說明書(包括伴隨的權利要求、摘要和附圖)中公開的每個特征可以由提供相同、等同或相似目的的替代特征來代替。
此外,本領域的技術人員能夠理解,盡管在此所述的一些實施例包括其它實施例中所包括的某些特征而不是其它特征,但是不同實施例的特征的組合意味著處于本發(fā)明的范圍之內(nèi)并且形成不同的實施例。例如,在下面的權利要求書中,所要求保護的實施例的任意之一都可以以任意的組合方式來使用。
本發(fā)明的各個部件實施例可以以硬件實現(xiàn),或者以在一個或者多個處理器上運行的軟件模塊實現(xiàn),或者以它們的組合實現(xiàn)。本領域的技術人員應當理解,可以在實踐中使用微處理器或者數(shù)字信號處理器(DSP)來實現(xiàn)根據(jù)本發(fā)明實施例的一種流數(shù)據(jù)的傳輸資源的選取方法和裝置中的一些或者全部部件的一些或者全部功能。本發(fā)明還可以實現(xiàn)為用于執(zhí)行這里所描述的方法的一部分或者全部的設備或者裝置程序(例如,計算機程序和計算機程序產(chǎn)品)。這樣的實現(xiàn)本發(fā)明的程序可以存儲在計算機可讀介質(zhì)上,或者可以具有一個或者多個信號的形式。這樣的信號可以從因特網(wǎng)網(wǎng)站上下載得到,或者在載體信號上提供,或者以任何其他形式提供。
應該注意的是上述實施例對本發(fā)明進行說明而不是對本發(fā)明進行限制,并且本領域技術人員在不脫離所附權利要求的范圍的情況下可設計出替換實施例。在權利要求中,不應將位于括號之間的任何參考符號構造成對權利要求的限制。單詞“包含”不排除存在未列在權利要求中的元件或步驟。位于元件之前的單詞“一”或“一個”不排除存在多個這樣的元件。本發(fā)明可以借助于包括有若干不同元件的硬件以及借助于適當編程的計算機來實現(xiàn)。在列舉了若干裝置的單元權利要求中,這些裝置中的若干個可以是通過同一個硬件項來具體體現(xiàn)。單詞第一、第二、以及第三等的使用不表示任何順序??蓪⑦@些單詞解釋為名稱。
本發(fā)明公開了A1、一種流數(shù)據(jù)的傳輸資源的選取方法,包括:
接收移動客戶端對當前流數(shù)據(jù)的傳輸資源的調(diào)度請求;
獲取所述移動客戶端所處位置的信息;
選取所述移動客戶端所處位置的信息的對應區(qū)域的傳輸資源。
A2、根據(jù)A1所述的方法,其中,所述獲取所述移動客戶端所處位置的信息包括:
根據(jù)所述移動客戶端的至少一種位置指示信息確定所述移動客戶端所處位置的信息。
A3、根據(jù)A2所述的方法,其中,所述位置指示信息包括所述移動客戶端的網(wǎng)絡地址信息,所述移動客戶端所處位置的信息包括所述移動客戶端所處地理區(qū)域的信息,所述根據(jù)所述移動客戶端的至少一種位置指示信息確定所述移動客戶端所處位置的信息包括:
從所述調(diào)度請求中提取所述移動客戶端的網(wǎng)絡地址信息;
查找所述網(wǎng)絡地址信息對應指示的所述移動客戶端所處地理區(qū)域的信息。
A4、根據(jù)A2所述的方法,其中,所述位置指示信息包括所述移動客戶端的定位信息,所述移動客戶端所處位置的信息包括所述移動客戶端所處地理區(qū)域的信息,所述根據(jù)所述移動客戶端的至少一種位置指示信息確定所述移動客戶端所處位置的信息包括:
接收所述移動客戶端調(diào)用位置定位程序獲取的定位信息;
通過訪問操作系統(tǒng)的地理區(qū)域信息獲取接口獲得的所述定位信息指示的所述移動客戶端所處地理區(qū)域的信息。
A5、根據(jù)A1所述的方法,其中,所述傳輸資源包括根據(jù)所述移動客戶端所處位置的信息選取的多個傳輸資源,每一傳輸資源包括傳輸節(jié)點集群,所述方法還包括:
從各傳輸節(jié)點集群選取多個候選傳輸節(jié)點。
A6、根據(jù)A5所述的方法,其中,所述方法還包括:
分別檢測所選取的各個候選傳輸節(jié)點的傳輸速度;
從多個候選傳輸節(jié)點中選取傳輸速度符合設定要求的目標傳輸節(jié)點以用于傳輸所述流數(shù)據(jù)。
A7、根據(jù)A6所述的方法,其中,所述分別檢測所選取的各個候選傳輸節(jié)點的傳輸速度包括:
根據(jù)所述移動客戶端對當前流數(shù)據(jù)的傳輸資源的調(diào)度請求,確定對應的測速類型;
向所述移動客戶端發(fā)送針對所述測速類型設置的測速策略,并接收反饋的傳輸速度。
A8、根據(jù)A7所述的方法,其中,所述根據(jù)所述移動客戶端對當前流數(shù)據(jù)的傳輸資源的調(diào)度請求,確定對應的測速類型包括:
若所述調(diào)度請求對應請求上行傳輸資源,則所述測速類型為上行測速;
所述測速策略包括:
向各個傳輸節(jié)點發(fā)送攜帶第一數(shù)據(jù)包的測速請求,根據(jù)所述傳輸節(jié)點針對所述第一數(shù)據(jù)包反饋的第二數(shù)據(jù)包進行測速,所述第一數(shù)據(jù)包大于第一設定數(shù)據(jù)量。
A9、根據(jù)A7所述的方法,其中,所述根據(jù)所述移動客戶端對當前流數(shù)據(jù)的傳輸資源的調(diào)度請求,確定對應的測速類型包括:
若所述調(diào)度請求對應請求下行傳輸資源,則所述測速類型為下行測速;
所述測速策略包括:
向各個傳輸節(jié)點發(fā)送攜帶第一數(shù)據(jù)包的測速請求,根據(jù)所述傳輸節(jié)點針對所述第一數(shù)據(jù)包反饋的第二數(shù)據(jù)包進行測速,所述第二數(shù)據(jù)包大于第一設定數(shù)據(jù)量。
A10、根據(jù)A7所述的方法,其中,所述根據(jù)所述移動客戶端對當前流數(shù)據(jù)的傳輸資源的調(diào)度請求,確定對應的測速類型包括:
若所述調(diào)度請求對應請求數(shù)據(jù)通信,則所述測速類型為網(wǎng)絡連通檢測;
所述測速策略包括:
向各個傳輸節(jié)點發(fā)送攜帶第一數(shù)據(jù)包的測速請求,根據(jù)所述傳輸節(jié)點針對所述第一數(shù)據(jù)包反饋的第二數(shù)據(jù)包進行測速,所述第一數(shù)據(jù)包和第二數(shù)據(jù)包均小于第二設定數(shù)據(jù)量。
A11、根據(jù)A5所述的方法,其中,所述方法還包括:
根據(jù)預先獲取的所選取傳輸節(jié)點的當前負載,預估所述傳輸節(jié)點應對調(diào)度節(jié)點集群的實際負載;
根據(jù)所述實際負載修正所選取的傳輸節(jié)點。
A12、根據(jù)A11所述的方法,其中,所述根據(jù)預先獲取的所選取傳輸節(jié)點的當前負載,預估所述傳輸節(jié)點應對調(diào)度節(jié)點集群的實際負載包括:
預估所述當前流數(shù)據(jù)被分配至所述傳輸節(jié)點后導致所述傳輸節(jié)點增加的第一負載增量;
根據(jù)所述第一負載增量,預估所述調(diào)度節(jié)點集群調(diào)度所述傳輸節(jié)點后導致所述傳輸節(jié)點增加的第二負載增量;
以所述調(diào)度節(jié)點集群導致所述傳輸節(jié)點增加的第二負載增量與所述當前負載之和,作為所述傳輸節(jié)點應對所述調(diào)度節(jié)點集群的實際負載。
A13、根據(jù)A12所述的方法,其中,所述根據(jù)所述第一負載增量,預估所述調(diào)度節(jié)點集群調(diào)度所述傳輸節(jié)點后導致所述傳輸節(jié)點增加的第二負載增量包括:
以所述第一負載增量與設定負載倍數(shù)的乘積,作為所述調(diào)度節(jié)點集群調(diào)度所述傳輸節(jié)點后導致所述傳輸節(jié)點增加的第二負載增量,所述設定負載倍數(shù)表征所述調(diào)度節(jié)點集群對所述傳輸節(jié)點的調(diào)度次數(shù)。
A14、根據(jù)A11所述的方法,其中,所述根據(jù)所述實際負載修正所選取的傳輸節(jié)點包括:
若所述實際負載超出所述傳輸節(jié)點的負載性能參數(shù)的值,則將所述傳輸節(jié)點替換為所述傳輸節(jié)點負載性能的值超出實際負載的另一傳輸節(jié)點。
A15、根據(jù)A1-14中任一項所述的方法,其中,所述方法還包括:
檢測所述移動客戶端所連接網(wǎng)絡歸屬的網(wǎng)絡運營商。
A16、根據(jù)A15所述的方法,其中,所述檢測所述移動客戶端所連接網(wǎng)絡歸屬的網(wǎng)絡運營商包括:
根據(jù)從所述調(diào)度請求中提取的網(wǎng)絡地址,識別所述移動客戶端所連接網(wǎng)絡歸屬的網(wǎng)絡運營商。
A17、根據(jù)A15所述的方法,其中,所述選取所述移動客戶端所處位置的信息的對應區(qū)域的傳輸資源包括:
選取與所述移動客戶端所處位置的信息指示的地理區(qū)域?qū)儆谕粎^(qū)域且與所述移動客戶端所連接網(wǎng)絡屬于同一網(wǎng)絡運營商的傳輸資源。
本發(fā)明還公開了B18、一種流數(shù)據(jù)的傳輸資源的選取裝置,包括:
調(diào)度請求接收模塊,用于接收移動客戶端對當前流數(shù)據(jù)的傳輸資源的調(diào)度請求;
位置獲取模塊,用于獲取所述移動客戶端所處位置的信息;
傳輸資源選取模塊,用于選取所述移動客戶端所處位置的信息的對應區(qū)域的傳輸資源。
B19、根據(jù)B18所述的裝置,其中,所述位置獲取模塊,具體用于根據(jù)所述移動客戶端的至少一種位置指示信息確定所述移動客戶端所處位置信息。
B20、根據(jù)B19所述的裝置,其中,所述位置指示信息包括所述移動客戶端的網(wǎng)絡地址信息,所述移動客戶端所處位置的信息包括所述移動客戶端所處地理區(qū)域的信息,所述位置獲取模塊包括:
網(wǎng)絡地址提取子模塊,用于從所述調(diào)度請求中提取所述移動客戶端的網(wǎng)絡地址信息;
地理區(qū)域查找子模塊,用于查找所述網(wǎng)絡地址信息對應指示的所述移動客戶端所處地理區(qū)域的信息。
B21、根據(jù)B19所述的裝置,其中,所述位置指示信息包括所述移動客戶端的定位信息,所述移動客戶端所處位置的信息包括所述移動客戶端所處地理區(qū)域的信息,所述位置獲取模塊包括:
定位信息接收子模塊,用于接收所述移動客戶端調(diào)用位置定位程序獲取的定位信息;
地理區(qū)域獲取子模塊,用于通過訪問操作系統(tǒng)的地理區(qū)域信息獲取接口獲得的所述定位信息指示的所述移動客戶端所處地理區(qū)域的信息。
B22、根據(jù)B18所述的裝置,其中,所述傳輸資源包括根據(jù)所述移動客戶端所處位置的信息選取的多個傳輸資源,每一傳輸資源包括傳輸節(jié)點集群,所述裝置還包括:
選取模塊,用于從各傳輸節(jié)點集群選取多個候選傳輸節(jié)點。
B23、根據(jù)B22所述的裝置,其中,所述裝置還包括:
傳輸速度檢測模塊,用于分別檢測所選取的各個候選傳輸節(jié)點的傳輸速度;
傳輸節(jié)點選取模塊,用于從多個候選傳輸節(jié)點中選取傳輸速度符合設定要求的目標傳輸節(jié)點以用于傳輸所述流數(shù)據(jù)。
B24、根據(jù)B23所述的裝置,其中,所述傳輸速度檢測模塊包括:
測速類型確定子模塊,用于根據(jù)所述移動客戶端對當前流數(shù)據(jù)的傳輸資源的調(diào)度請求,確定對應的測速類型;
傳輸速度接收子模塊,用于向所述移動客戶端發(fā)送針對所述測速類型設置的測速策略,并接收反饋的傳輸速度。
B25、根據(jù)B24所述的裝置,其中,所述測速類型確定子模塊,具體用于若所述調(diào)度請求對應請求上行傳輸資源,則所述測速類型為上行測速;
所述測速策略包括:
向各個傳輸節(jié)點發(fā)送攜帶第一數(shù)據(jù)包的測速請求,根據(jù)所述傳輸節(jié)點針對所述第一數(shù)據(jù)包反饋的第二數(shù)據(jù)包進行測速,所述第一數(shù)據(jù)包大于第一設定數(shù)據(jù)量。
B26、根據(jù)B24所述的裝置,其中,所述測速類型確定子模塊,具體用于若所述調(diào)度請求對應請求下行傳輸資源,則所述測速類型為下行測速;
所述測速策略包括:
向各個傳輸節(jié)點發(fā)送攜帶第一數(shù)據(jù)包的測速請求,根據(jù)所述傳輸節(jié)點針對所述第一數(shù)據(jù)包反饋的第二數(shù)據(jù)包進行測速,所述第二數(shù)據(jù)包大于第一設定數(shù)據(jù)量。
B27、根據(jù)B24所述的裝置,其中,所述測速類型確定子模塊,具體用于若所述調(diào)度請求對應請求數(shù)據(jù)通信,則所述測速類型為網(wǎng)絡連通檢測;
所述測速策略包括:
向各個傳輸節(jié)點發(fā)送攜帶第一數(shù)據(jù)包的測速請求,根據(jù)所述傳輸節(jié)點針對所述第一數(shù)據(jù)包反饋的第二數(shù)據(jù)包進行測速,所述第一數(shù)據(jù)包和第二數(shù)據(jù)包均小于第二設定數(shù)據(jù)量。
B28、根據(jù)B22所述的裝置,其中,所述裝置還包括:
負載預估模塊,用于根據(jù)預先獲取的所選取傳輸節(jié)點的當前負載,預估所述傳輸節(jié)點應對調(diào)度節(jié)點集群的實際負載;
傳輸節(jié)點修正模塊,用于根據(jù)所述實際負載修正所選取的傳輸節(jié)點。
B29、根據(jù)B28所述的裝置,其中,所述負載預估模塊包括:
第一負載增量預估子模塊,用于預估所述當前流數(shù)據(jù)被分配至所述傳輸節(jié)點后導致所述傳輸節(jié)點增加的第一負載增量;
第二負載增量預估子模塊,用于根據(jù)所述第一負載增量,預估所述調(diào)度節(jié)點集群調(diào)度所述傳輸節(jié)點后導致所述傳輸節(jié)點增加的第二負載增量;
實際負載子模塊,用于以所述調(diào)度節(jié)點集群導致所述傳輸節(jié)點增加的第二負載增量與所述當前負載之和,作為所述傳輸節(jié)點應對所述調(diào)度節(jié)點集群的實際負載。
B30、根據(jù)B29所述的裝置,其中,所述第二負載增量預估子模塊,具體用于以所述第一負載增量與設定負載倍數(shù)的乘積,作為所述調(diào)度節(jié)點集群調(diào)度所述傳輸節(jié)點后導致所述傳輸節(jié)點增加的第二負載增量,所述設定負載倍數(shù)表征所述調(diào)度節(jié)點集群對所述傳輸節(jié)點的調(diào)度次數(shù)。
B31、根據(jù)B28所述的裝置,其中,所述傳輸節(jié)點修正模塊,具體用于若所述實際負載超出所述傳輸節(jié)點的負載性能參數(shù)的值,則將所述傳輸節(jié)點替換為所述傳輸節(jié)點負載性能的值超出實際負載的另一傳輸節(jié)點。
B32、根據(jù)B18-31中任一項所述的裝置,其中,所述裝置還包括:
網(wǎng)絡運營商檢測模塊,用于檢測所述移動客戶端所連接網(wǎng)絡歸屬的網(wǎng)絡運營商。
B33、根據(jù)B32所述的裝置,其中,所述網(wǎng)絡運營商檢測模塊,具體用于根據(jù)從所述調(diào)度請求中提取的網(wǎng)絡地址,識別所述移動客戶端所連接網(wǎng)絡歸屬的網(wǎng)絡運營商。
B34、根據(jù)B32所述的裝置,其中,所述傳輸資源選取模塊,具體用于選取與所述移動客戶端所處位置的信息指示的地理區(qū)域?qū)儆谕粎^(qū)域且與所述移動客戶端所連接網(wǎng)絡屬于同一網(wǎng)絡運營商的傳輸資源。