本發(fā)明涉及數(shù)據(jù)請(qǐng)求處理技術(shù)領(lǐng)域,尤其涉及一種數(shù)據(jù)請(qǐng)求處理裝置及方法。
背景技術(shù):
首先,當(dāng)客戶端發(fā)送數(shù)據(jù)請(qǐng)求,服務(wù)器接收請(qǐng)求后會(huì)進(jìn)行數(shù)據(jù)處理,當(dāng)服務(wù)器處理完畢是向客戶端發(fā)送數(shù)據(jù)請(qǐng)求對(duì)應(yīng)的結(jié)果反饋。而實(shí)際應(yīng)用中,服務(wù)器在同一時(shí)刻需要接收大量的用戶訪問,隨著用戶訪問數(shù)量的加大服務(wù)器響應(yīng)用戶的數(shù)據(jù)請(qǐng)求時(shí)間也會(huì)加長。
因此,現(xiàn)有技術(shù)中的用戶請(qǐng)求往往需要在服務(wù)器執(zhí)行很長時(shí)間才會(huì)返回結(jié)果時(shí),而在此期間用戶和服務(wù)器之間是一直需要保持這個(gè)連接的,如果連接中斷將會(huì)影響數(shù)據(jù)請(qǐng)求對(duì)應(yīng)的結(jié)果的反饋。
可見,現(xiàn)有技術(shù)中對(duì)于每一個(gè)用戶的請(qǐng)求,服務(wù)器一直要保持著這個(gè)連接,將十分浪費(fèi)連接數(shù),這樣會(huì)造成服務(wù)器的壓力過大;且一直保持連接也會(huì)浪費(fèi)服務(wù)器的資源。
技術(shù)實(shí)現(xiàn)要素:
本發(fā)明的主要目的在于提出一種數(shù)據(jù)請(qǐng)求處理裝置及方法,旨在解決現(xiàn)有技術(shù)中請(qǐng)求發(fā)送以后,客戶端會(huì)一直保持和服務(wù)器的連接,直至請(qǐng)求處理完畢,會(huì)造成服務(wù)器連接的用戶數(shù)量過大,造成服務(wù)器壓力大、且浪費(fèi)服務(wù)器資源的問題。
為實(shí)現(xiàn)上述目的,本發(fā)明提供了一種數(shù)據(jù)請(qǐng)求處理裝置,應(yīng)用于客戶端,所述裝置包括:
建立模塊,用于與服務(wù)器建立服務(wù)器發(fā)送事件SSE通道;
發(fā)送模塊,用于發(fā)送數(shù)據(jù)請(qǐng)求,并接收所述服務(wù)器發(fā)送的與所述數(shù)據(jù)請(qǐng)求對(duì)應(yīng)的識(shí)別標(biāo)志;
處理模塊,用于接收所述服務(wù)器通過所述SSE通道發(fā)送的與所述數(shù)據(jù)請(qǐng)求對(duì)應(yīng)的處理狀態(tài),并根據(jù)所述SSE通道以及所述識(shí)別標(biāo)志,從所述服務(wù)器獲取所述數(shù)據(jù)請(qǐng)求的對(duì)應(yīng)處理結(jié)果。
可選的,所述識(shí)別標(biāo)志為通用唯一識(shí)別碼。
可選的,所述處理模塊,包括:
第一接收子模塊,用于接收所述服務(wù)器通過所述SSE通道發(fā)送的所述數(shù)據(jù)請(qǐng)求對(duì)應(yīng)的處理狀態(tài);
發(fā)送子模塊,用于在接收到的所述處理狀態(tài)為完成時(shí),發(fā)送獲取處理結(jié)果的請(qǐng)求至所述服務(wù)器;
獲取子模塊,用于根據(jù)所述SSE通道以及所述識(shí)別標(biāo)志,從所述服務(wù)器獲取所述數(shù)據(jù)請(qǐng)求的對(duì)應(yīng)處理結(jié)果。
可選的,所述建立模塊,具體用于:
將建立服務(wù)器發(fā)送事件SSE通道的請(qǐng)求發(fā)送至代理服務(wù)器,與所述代理服務(wù)器分配的服務(wù)器建立所述服務(wù)器發(fā)送事件SSE通道;
所述處理處理模塊,包括:
第二接收子模塊,用于接收所述服務(wù)器通過所述SSE通道發(fā)送的與所述數(shù)據(jù)請(qǐng)求對(duì)應(yīng)的處理狀態(tài),其中,所述服務(wù)器將與所述數(shù)據(jù)請(qǐng)求對(duì)應(yīng)的處理狀態(tài)及處理結(jié)果發(fā)送至消息隊(duì)列;
第三接收子模塊,用于根據(jù)所述SSE通道以及所述識(shí)別標(biāo)志,接收所述服務(wù)器從所述消息隊(duì)列中獲取并發(fā)送的處理結(jié)果,其中,所述處理結(jié)果為與所述數(shù)據(jù)請(qǐng)求的對(duì)應(yīng)處理。
可選的,所述消息隊(duì)列為卡夫卡kafka隊(duì)列。
相較于現(xiàn)有技術(shù),本發(fā)明所提出的數(shù)據(jù)請(qǐng)求處理裝置,通過與服務(wù)器建立服務(wù)器發(fā)送事件SSE通道;然后發(fā)送數(shù)據(jù)請(qǐng)求,并接收所述服務(wù)器發(fā)送的與所述數(shù)據(jù)請(qǐng)求對(duì)應(yīng)的識(shí)別標(biāo)志;接收所述服務(wù)器通過所述SSE通道發(fā)送的與所述數(shù)據(jù)請(qǐng)求對(duì)應(yīng)的處理狀態(tài),并根據(jù)所述SSE通道以及所述識(shí)別標(biāo)志,從所述服務(wù)器獲取所述數(shù)據(jù)請(qǐng)求的對(duì)應(yīng)處理結(jié)果。這樣只要建立了SSE通道,客戶端即可通過SSE通道能夠在數(shù)據(jù)請(qǐng)求處理完成后獲取對(duì)應(yīng)的處理結(jié)果,而不用客戶端一直保持與服務(wù)器的連接,從而節(jié)省了服務(wù)器的資源。
此外,為實(shí)現(xiàn)上述目的,本發(fā)明還提出一種數(shù)據(jù)請(qǐng)求處理方法,應(yīng)用于客戶端,所述方法包括:
與服務(wù)器建立服務(wù)器發(fā)送事件SSE通道;
發(fā)送數(shù)據(jù)請(qǐng)求,并接收所述服務(wù)器發(fā)送的與所述數(shù)據(jù)請(qǐng)求對(duì)應(yīng)的識(shí)別標(biāo)志;
接收所述服務(wù)器通過所述SSE通道發(fā)送的與所述數(shù)據(jù)請(qǐng)求對(duì)應(yīng)的處理狀態(tài),并根據(jù)所述SSE通道以及所述識(shí)別標(biāo)志,從所述服務(wù)器獲取所述數(shù)據(jù)請(qǐng)求的對(duì)應(yīng)處理結(jié)果。
可選的,所述識(shí)別標(biāo)志為通用唯一識(shí)別碼。
可選的,所述接收所述服務(wù)器通過所述SSE通道發(fā)送的與所述數(shù)據(jù)請(qǐng)求對(duì)應(yīng)的處理狀態(tài),并根據(jù)所述SSE通道以及所述識(shí)別標(biāo)志,從所述服務(wù)器獲取所述數(shù)據(jù)請(qǐng)求的對(duì)應(yīng)處理結(jié)果,包括:
接收所述服務(wù)器通過所述SSE通道發(fā)送的所述數(shù)據(jù)請(qǐng)求對(duì)應(yīng)的處理狀態(tài);
在接收到的所述處理狀態(tài)為完成時(shí),發(fā)送獲取處理結(jié)果的請(qǐng)求至所述服務(wù)器;
根據(jù)所述SSE通道以及所述識(shí)別標(biāo)志,從所述服務(wù)器獲取所述數(shù)據(jù)請(qǐng)求的對(duì)應(yīng)處理結(jié)果。
可選的,所述與服務(wù)器建立服務(wù)器發(fā)送事件SSE通道,包括:
將建立服務(wù)器發(fā)送事件SSE通道的請(qǐng)求發(fā)送至代理服務(wù)器,與所述代理服務(wù)器分配的服務(wù)器建立所述服務(wù)器發(fā)送事件SSE通道;
所述接收所述服務(wù)器通過所述SSE通道發(fā)送的與所述數(shù)據(jù)請(qǐng)求對(duì)應(yīng)的處理狀態(tài),并根據(jù)所述SSE通道以及所述識(shí)別標(biāo)志,從所述服務(wù)器獲取所述數(shù)據(jù)請(qǐng)求的對(duì)應(yīng)處理結(jié)果,包括:
接收所述服務(wù)器通過所述SSE通道發(fā)送的與所述數(shù)據(jù)請(qǐng)求對(duì)應(yīng)的處理狀態(tài),其中,所述服務(wù)器將與所述數(shù)據(jù)請(qǐng)求對(duì)應(yīng)的處理狀態(tài)及處理結(jié)果發(fā)送至消息隊(duì)列;
根據(jù)所述SSE通道以及所述識(shí)別標(biāo)志,接收所述服務(wù)器從所述消息隊(duì)列中獲取并發(fā)送的處理結(jié)果,其中,所述處理結(jié)果為與所述數(shù)據(jù)請(qǐng)求的對(duì)應(yīng)處理。
可選的,所述消息隊(duì)列為卡夫卡kafka隊(duì)列。
相較于現(xiàn)有技術(shù),本發(fā)明所提出的數(shù)據(jù)請(qǐng)求處理方法,通過與服務(wù)器建立服務(wù)器發(fā)送事件SSE通道;然后發(fā)送數(shù)據(jù)請(qǐng)求,并接收所述服務(wù)器發(fā)送的與所述數(shù)據(jù)請(qǐng)求對(duì)應(yīng)的識(shí)別標(biāo)志;接收所述服務(wù)器通過所述SSE通道發(fā)送的與所述數(shù)據(jù)請(qǐng)求對(duì)應(yīng)的處理狀態(tài),并根據(jù)所述SSE通道以及所述識(shí)別標(biāo)志,從所述服務(wù)器獲取所述數(shù)據(jù)請(qǐng)求的對(duì)應(yīng)處理結(jié)果。這樣只要建立了SSE通道,客戶端即可通過SSE通道能夠在數(shù)據(jù)請(qǐng)求處理完成后獲取對(duì)應(yīng)的處理結(jié)果,而不用客戶端一直保持與服務(wù)器的連接,從而節(jié)省了服務(wù)器的資源。
附圖說明
圖1為實(shí)現(xiàn)本發(fā)明各個(gè)實(shí)施例中一可選的移動(dòng)終端的硬件結(jié)構(gòu)示意圖;
圖2為如圖1所示的移動(dòng)終端的無線通信系統(tǒng)示意圖;
圖3為本發(fā)明所述的數(shù)據(jù)請(qǐng)求處理裝置的一種功能模塊示意圖;
圖4為本發(fā)明所提供的異步處理流程圖;
圖5為本發(fā)明所述的數(shù)據(jù)請(qǐng)求處理裝置的另一種功能模塊示意圖;
圖6為本發(fā)明所述的數(shù)據(jù)請(qǐng)求處理裝置第一實(shí)施例的流程示意圖;
圖7為本發(fā)明所述的數(shù)據(jù)請(qǐng)求處理方法的一種流程示意圖;
圖8為本發(fā)明所述的數(shù)據(jù)請(qǐng)求處理方法的另一種流程示意圖。
附圖標(biāo)記:
本發(fā)明目的的實(shí)現(xiàn)、功能特點(diǎn)及優(yōu)點(diǎn)將結(jié)合實(shí)施例,參照附圖做進(jìn)一步說明。
具體實(shí)施方式
應(yīng)當(dāng)理解,此處所描述的具體實(shí)施例僅僅用以解釋本發(fā)明,并不用于限定本發(fā)明。
現(xiàn)在將參考附圖描述實(shí)現(xiàn)本發(fā)明各個(gè)實(shí)施例的移動(dòng)終端。在后續(xù)的描述中,使用用于表示元件的諸如“模塊”、“部件”或“單元”的后綴僅為了有利于本發(fā)明的說明,其本身并沒有特定的意義。因此,"模塊"與"部件"可以混合地使用。
移動(dòng)終端可以以各種形式來實(shí)施。例如,本發(fā)明中描述的終端可以包括諸如移動(dòng)電話、智能電話、筆記本電腦、數(shù)字廣播接收器、PDA(個(gè)人數(shù)字助理)、PAD(平板電腦)、PMP(便攜式多媒體播放器)、導(dǎo)航裝置等等的移動(dòng)終端以及諸如數(shù)字TV、臺(tái)式計(jì)算機(jī)等等的固定終端。下面,假設(shè)終端是移動(dòng)終端。然而,本領(lǐng)域技術(shù)人員將理解的是,除了特別用于移動(dòng)目的的元件之外,根據(jù)本發(fā)明的實(shí)施方式的構(gòu)造也能夠應(yīng)用于固定類型的終端。
圖1為實(shí)現(xiàn)本發(fā)明各個(gè)實(shí)施例的移動(dòng)終端的硬件結(jié)構(gòu)示意。
移動(dòng)終端100可以包括無線通信單元110、輸入單元120、用戶輸入單元130、感測單元140、輸出單元150、存儲(chǔ)器160、接口單元170、控制器180和電源單元190等等。圖1示出了具有各種組件的移動(dòng)終端,但是應(yīng)理解的是,并不要求實(shí)施所有示出的組件??梢蕴娲貙?shí)施更多或更少的組件。將在下面詳細(xì)描述移動(dòng)終端的元件。
無線通信單元110通常包括一個(gè)或多個(gè)組件,其允許移動(dòng)終端100與無線通信系統(tǒng)或網(wǎng)絡(luò)之間的無線電通信。例如,無線通信單元可以包括廣播接收模塊、移動(dòng)通信模塊、無線互聯(lián)網(wǎng)模塊、短程通信模塊和位置信息模塊中的至少一個(gè)。
廣播接收模塊經(jīng)由廣播信道從外部廣播管理服務(wù)器接收廣播信號(hào)和/或廣播相關(guān)信息。廣播信道可以包括衛(wèi)星信道和/或地面信道。廣播管理服務(wù)器可以是生成并發(fā)送廣播信號(hào)和/或廣播相關(guān)信息的服務(wù)器或者接收之前生成的廣播信號(hào)和/或廣播相關(guān)信息并且將其發(fā)送給終端的服務(wù)器。廣播信號(hào)可以包括TV廣播信號(hào)、無線電廣播信號(hào)、數(shù)據(jù)廣播信號(hào)等等。而且,廣播信號(hào)可以進(jìn)一步包括與TV或無線電廣播信號(hào)組合的廣播信號(hào)。廣播相關(guān)信息也可以經(jīng)由移動(dòng)通信網(wǎng)絡(luò)提供,并且在該情況下,廣播相關(guān)信息可以由移動(dòng)通信模塊來接收。廣播信號(hào)可以以各種形式存在,例如,其可以以數(shù)字多媒體廣播(DMB)的電子節(jié)目指南(EPG)、數(shù)字視頻廣播手持(DVB-H)的電子服務(wù)指南(ESG)等等的形式而存在。廣播接收模塊可以通過使用各種類型的廣播系統(tǒng)接收信號(hào)廣播。特別地,廣播接收模塊可以通過使用諸如多媒體廣播-地面(DMB-T)、數(shù)字多媒體廣播-衛(wèi)星(DMB-S)、數(shù)字視頻廣播-手持(DVB-H),前向鏈路媒體(MediaFLO@)的數(shù)據(jù)廣播系統(tǒng)、地面數(shù)字廣播綜合服務(wù)(ISDB-T)等等的數(shù)字廣播系統(tǒng)接收數(shù)字廣播。廣播接收模塊可以被構(gòu)造為適合提供廣播信號(hào)的各種廣播系統(tǒng)以及上述數(shù)字廣播系統(tǒng)。經(jīng)由廣播接收模塊接收的廣播信號(hào)和/或廣播相關(guān)信息可以存儲(chǔ)在存儲(chǔ)器160(或者其它類型的存儲(chǔ)介質(zhì))中。
移動(dòng)通信模塊將無線電信號(hào)發(fā)送到基站(例如,接入點(diǎn)、節(jié)點(diǎn)B等等)、外部終端以及服務(wù)器中的至少一個(gè)和/或從其接收無線電信號(hào)。這樣的無線電信號(hào)可以包括語音通話信號(hào)、視頻通話信號(hào)、或者根據(jù)文本和/或多媒體消息發(fā)送和/或接收的各種類型的數(shù)據(jù)。
無線互聯(lián)網(wǎng)模塊支持移動(dòng)終端的無線互聯(lián)網(wǎng)接入。該模塊可以內(nèi)部或外部地耦接到終端。該模塊所涉及的無線互聯(lián)網(wǎng)接入技術(shù)可以包括WLAN(無線LAN)(Wi-Fi)、Wibro(無線寬帶)、Wimax(全球微波互聯(lián)接入)、HSDPA(高速下行鏈路分組接入)等等。
短程通信模塊是用于支持短程通信的模塊。短程通信技術(shù)的一些示例包括藍(lán)牙TM、射頻識(shí)別(RFID)、紅外數(shù)據(jù)協(xié)會(huì)(IrDA)、超寬帶(UWB)、紫蜂TM等等。
位置信息模塊是用于檢查或獲取移動(dòng)終端的位置信息的模塊。位置信息模塊的典型示例是GPS(全球定位系統(tǒng))。根據(jù)當(dāng)前的技術(shù),GPS模塊計(jì)算來自三個(gè)或更多衛(wèi)星的距離信息和準(zhǔn)確的時(shí)間信息并且對(duì)于計(jì)算的信息應(yīng)用三角測量法,從而根據(jù)經(jīng)度、緯度和高度準(zhǔn)確地計(jì)算三維當(dāng)前位置信息。當(dāng)前,用于計(jì)算位置和時(shí)間信息的方法使用三顆衛(wèi)星并且通過使用另外的一顆衛(wèi)星校正計(jì)算出的位置和時(shí)間信息的誤差。此外,GPS模塊能夠通過實(shí)時(shí)地連續(xù)計(jì)算當(dāng)前位置信息來計(jì)算速度信息。
輸入單元120用于接收音頻或視頻信號(hào)。輸入單元120可以包括相機(jī)121和麥克風(fēng)122,相機(jī)121對(duì)在視頻捕獲模式或圖像捕獲模式中由圖像捕獲裝置獲得的靜態(tài)圖片或視頻的圖像數(shù)據(jù)進(jìn)行處理。處理后的圖像幀可以顯示在顯示單元151上。經(jīng)相機(jī)121處理后的圖像幀可以存儲(chǔ)在存儲(chǔ)器160(或其它存儲(chǔ)介質(zhì))中或者經(jīng)由無線通信單元110進(jìn)行發(fā)送,可以根據(jù)移動(dòng)終端的構(gòu)造提供兩個(gè)或更多相機(jī)121。麥克風(fēng)122可以在電話通話模式、記錄模式、語音識(shí)別模式等等運(yùn)行模式中經(jīng)由麥克風(fēng)接收聲音(音頻數(shù)據(jù)),并且能夠?qū)⑦@樣的聲音處理為音頻數(shù)據(jù)。處理后的音頻(語音)數(shù)據(jù)可以在電話通話模式的情況下轉(zhuǎn)換為可經(jīng)由移動(dòng)通信模塊發(fā)送到移動(dòng)通信基站的格式輸出。麥克風(fēng)122可以實(shí)施各種類型的噪聲消除(或抑制)算法以消除(或抑制)在接收和發(fā)送音頻信號(hào)的過程中產(chǎn)生的噪聲或者干擾。
用戶輸入單元130可以根據(jù)用戶輸入的命令生成鍵輸入數(shù)據(jù)以控制移動(dòng)終端的各種操作。用戶輸入單元130允許用戶輸入各種類型的信息,并且可以包括鍵盤、鍋?zhàn)衅⒂|摸板(例如,檢測由于被接觸而導(dǎo)致的電阻、壓力、電容等等的變化的觸敏組件)、滾輪、搖桿等等。特別地,當(dāng)觸摸板以層的形式疊加在顯示單元151上時(shí),可以形成觸摸屏。
感測單元140檢測移動(dòng)終端100的當(dāng)前狀態(tài),(例如,移動(dòng)終端100的打開或關(guān)閉狀態(tài))、移動(dòng)終端100的位置、用戶對(duì)于移動(dòng)終端100的接觸(即,觸摸輸入)的有無、移動(dòng)終端100的取向、移動(dòng)終端100的加速或減速移動(dòng)和方向等等,并且生成用于控制移動(dòng)終端100的操作的命令或信號(hào)。例如,當(dāng)移動(dòng)終端100實(shí)施為滑動(dòng)型移動(dòng)電話時(shí),感測單元140可以感測該滑動(dòng)型電話是打開還是關(guān)閉。另外,感測單元140能夠檢測電源單元190是否提供電力或者接口單元170是否與外部裝置耦接。感測單元140可以包括聲紋感測器,用于采集用戶的聲紋信息。
接口單元170用作至少一個(gè)外部裝置與移動(dòng)終端100連接可以通過的接口。例如,外部裝置可以包括有線或無線頭戴式耳機(jī)端口、外部電源(或電池充電器)端口、有線或無線數(shù)據(jù)端口、存儲(chǔ)卡端口、用于連接具有識(shí)別模塊的裝置的端口、音頻輸入/輸出(I/O)端口、視頻I/O端口、耳機(jī)端口等等。識(shí)別模塊可以是存儲(chǔ)用于驗(yàn)證用戶使用移動(dòng)終端100的各種信息并且可以包括用戶識(shí)別模塊(UIM)、客戶識(shí)別模塊(SIM)、通用客戶識(shí)別模塊(USIM)等等。另外,具有識(shí)別模塊的裝置(下面稱為"識(shí)別裝置")可以采取智能卡的形式,因此,識(shí)別裝置可以經(jīng)由端口或其它連接裝置與移動(dòng)終端100連接。接口單元170可以用于接收來自外部裝置的輸入(例如,數(shù)據(jù)信息、電力等等)并且將接收到的輸入傳輸?shù)揭苿?dòng)終端100內(nèi)的一個(gè)或多個(gè)元件或者可以用于在移動(dòng)終端和外部裝置之間傳輸數(shù)據(jù)。
另外,當(dāng)移動(dòng)終端100與外部底座連接時(shí),接口單元170可以用作允許通過其將電力從底座提供到移動(dòng)終端100的路徑或者可以用作允許從底座輸入的各種命令信號(hào)通過其傳輸?shù)揭苿?dòng)終端的路徑。從底座輸入的各種命令信號(hào)或電力可以用作用于識(shí)別移動(dòng)終端是否準(zhǔn)確地安裝在底座上的信號(hào)。輸出單元150被構(gòu)造為以視覺、音頻和/或觸覺方式提供輸出信號(hào)(例如,音頻信號(hào)、視頻信號(hào)、警報(bào)信號(hào)、振動(dòng)信號(hào)等等)。輸出單元150可以包括顯示單元151、音頻輸出模塊152、警報(bào)單元153等等。
顯示單元151可以顯示在移動(dòng)終端100中處理的信息。例如,當(dāng)移動(dòng)終端100處于電話通話模式時(shí),顯示單元151可以顯示與通話或其它通信(例如,文本消息收發(fā)、多媒體文件下載等等)相關(guān)的用戶界面(UI)或圖形用戶界面(GUI)。當(dāng)移動(dòng)終端100處于視頻通話模式或者圖像捕獲模式時(shí),顯示單元151可以顯示捕獲的圖像和/或接收的圖像、示出視頻或圖像以及相關(guān)功能的UI或GUI等等。
同時(shí),當(dāng)顯示單元151和觸摸板以層的形式彼此疊加以形成觸摸屏?xí)r,顯示單元151可以用作輸入裝置和輸出裝置。顯示單元151可以包括液晶顯示器(LCD)、薄膜晶體管LCD(TFT-LCD)、有機(jī)發(fā)光二極管(OLED)顯示器、柔性顯示器、三維(3D)顯示器等等中的至少一種。這些顯示器中的一些可以被構(gòu)造為透明狀以允許用戶從外部觀看,這可以稱為透明顯示器,典型的透明顯示器可以例如為TOLED(透明有機(jī)發(fā)光二極管)顯示器等等。根據(jù)特定想要的實(shí)施方式,移動(dòng)終端100可以包括兩個(gè)或更多顯示單元(或其它顯示裝置),例如,移動(dòng)終端可以包括外部顯示單元(未示出)和內(nèi)部顯示單元(未示出)。觸摸屏可用于檢測觸摸輸入壓力以及觸摸輸入位置和觸摸輸入面積。
音頻輸出模塊152可以在移動(dòng)終端處于呼叫信號(hào)接收模式、通話模式、記錄模式、語音識(shí)別模式、廣播接收模式等等模式下時(shí),將無線通信單元110接收的或者在存儲(chǔ)器160中存儲(chǔ)的音頻數(shù)據(jù)轉(zhuǎn)換音頻信號(hào)并且輸出為聲音。而且,音頻輸出模塊152可以提供與移動(dòng)終端100執(zhí)行的特定功能相關(guān)的音頻輸出(例如,呼叫信號(hào)接收聲音、消息接收聲音等等)。音頻輸出模塊152可以包括揚(yáng)聲器、蜂鳴器等等。
警報(bào)單元153可以提供輸出以將事件的發(fā)生通知給移動(dòng)終端100。典型的事件可以包括呼叫接收、消息接收、鍵信號(hào)輸入、觸摸輸入等等。除了音頻或視頻輸出之外,警報(bào)單元153可以以不同的方式提供輸出以通知事件的發(fā)生。例如,警報(bào)單元153可以以振動(dòng)的形式提供輸出,當(dāng)接收到呼叫、消息或一些其它進(jìn)入通信(incomingcommunication)時(shí),警報(bào)單元153可以提供觸覺輸出(即,振動(dòng))以將其通知給用戶。通過提供這樣的觸覺輸出,即使在用戶的移動(dòng)電話處于用戶的口袋中時(shí),用戶也能夠識(shí)別出各種事件的發(fā)生。警報(bào)單元153也可以經(jīng)由顯示單元151或音頻輸出模塊152提供通知事件的發(fā)生的輸出。
存儲(chǔ)器160可以存儲(chǔ)由控制器180執(zhí)行的處理和控制操作的軟件程序等等,或者可以暫時(shí)地存儲(chǔ)己經(jīng)輸出或?qū)⒁敵龅臄?shù)據(jù)(例如,電話簿、消息、靜態(tài)圖像、視頻等等)。而且,存儲(chǔ)器160可以存儲(chǔ)關(guān)于當(dāng)觸摸施加到觸摸屏?xí)r輸出的各種方式的振動(dòng)和音頻信號(hào)的數(shù)據(jù)。
存儲(chǔ)器160可以包括至少一種類型的存儲(chǔ)介質(zhì),所述存儲(chǔ)介質(zhì)包括閃存、硬盤、多媒體卡、卡型存儲(chǔ)器(例如,SD或DX存儲(chǔ)器等等)、隨機(jī)訪問存儲(chǔ)器(RAM)、靜態(tài)隨機(jī)訪問存儲(chǔ)器(SRAM)、只讀存儲(chǔ)器(ROM)、電可擦除可編程只讀存儲(chǔ)器(EEPROM)、可編程只讀存儲(chǔ)器(PROM)、磁性存儲(chǔ)器、磁盤、光盤等等。而且,移動(dòng)終端100可以與通過網(wǎng)絡(luò)連接執(zhí)行存儲(chǔ)器160的存儲(chǔ)功能的網(wǎng)絡(luò)存儲(chǔ)裝置協(xié)作。
控制器180通??刂埔苿?dòng)終端的總體操作。例如,控制器180執(zhí)行與語音通話、數(shù)據(jù)通信、視頻通話等等相關(guān)的控制和處理。另外,控制器180可以包括用于再現(xiàn)(或回放)多媒體數(shù)據(jù)的多媒體模塊181,多媒體模塊181可以構(gòu)造在控制器180內(nèi),或者可以構(gòu)造為與控制器180分離??刂破?80可以執(zhí)行模式識(shí)別處理,以將在觸摸屏上執(zhí)行的手寫輸入或者圖片繪制輸入識(shí)別為字符或圖像。
電源單元190在控制器180的控制下接收外部電力或內(nèi)部電力并且提供操作各元件和組件所需的適當(dāng)?shù)碾娏Α?/p>
這里描述的各種實(shí)施方式可以以使用例如計(jì)算機(jī)軟件、硬件或其任何組合的計(jì)算機(jī)可讀介質(zhì)來實(shí)施。對(duì)于硬件實(shí)施,這里描述的實(shí)施方式可以通過使用特定用途集成電路(ASIC)、數(shù)字信號(hào)處理器(DSP)、數(shù)字信號(hào)處理裝置(DSPD)、可編程邏輯裝置(PLD)、現(xiàn)場可編程門陣列(FPGA)、處理器、控制器、微控制器、微處理器、被設(shè)計(jì)為執(zhí)行這里描述的功能的電子單元中的至少一種來實(shí)施,在一些情況下,這樣的實(shí)施方式可以在控制器180中實(shí)施。對(duì)于軟件實(shí)施,諸如過程或功能的實(shí)施方式可以與允許執(zhí)行至少一種功能或操作的單獨(dú)的軟件模塊來實(shí)施。軟件代碼可以由以任何適當(dāng)?shù)木幊陶Z言編寫的軟件應(yīng)用程序(或程序)來實(shí)施,軟件代碼可以存儲(chǔ)在存儲(chǔ)器160中并且由控制器180執(zhí)行。
至此,己經(jīng)按照其功能描述了移動(dòng)終端。下面,結(jié)合本發(fā)明,所述移動(dòng)終端為一具有顯示功能的顯示終端,以下所描述的顯示終端即為該移動(dòng)終端100。本發(fā)明能夠應(yīng)用于任何類型的顯示終端,并且不限于移動(dòng)式顯示終端。
如圖1中所示的移動(dòng)終端100可以被構(gòu)造為利用經(jīng)由幀或分組發(fā)送數(shù)據(jù)的諸如有線和無線通信系統(tǒng)以及基于衛(wèi)星的通信系統(tǒng)來操作。
現(xiàn)在將參考圖2描述其中根據(jù)本發(fā)明的移動(dòng)終端能夠操作的通信系統(tǒng)。
這樣的通信系統(tǒng)可以使用不同的空中接口和/或物理層。例如,由通信系統(tǒng)使用的空中接口包括例如頻分多址(FDMA)、時(shí)分多址(TDMA)、碼分多址(CDMA)和通用移動(dòng)通信系統(tǒng)(UMTS)(特別地,長期演進(jìn)(LTE))、全球移動(dòng)通信系統(tǒng)(GSM)等等。作為非限制性示例,下面的描述涉及CDMA通信系統(tǒng),但是這樣的教導(dǎo)同樣適用于其它類型的系統(tǒng)。
參考圖2,CDMA無線通信系統(tǒng)可以包括多個(gè)移動(dòng)終端100、多個(gè)基站(BS)270、基站控制器(BSC)275和移動(dòng)交換中心(MSC)280。MSC280被構(gòu)造為與公共電話交換網(wǎng)絡(luò)(PSTN)290形成接口。MSC280還被構(gòu)造為與可以經(jīng)由回程線路耦接到基站270的BSC275形成接口?;爻叹€路可以根據(jù)若干己知的接口中的任一種來構(gòu)造,所述接口包括例如E1/T1、ATM,IP、PPP、幀中繼、HDSL、ADSL或xDSL。將理解的是,如圖2中所示的系統(tǒng)可以包括多個(gè)BSC2750。
每個(gè)BS270可以服務(wù)一個(gè)或多個(gè)分區(qū)(或區(qū)域),由多向天線或指向特定方向的天線覆蓋的每個(gè)分區(qū)放射狀地遠(yuǎn)離BS270?;蛘?,每個(gè)分區(qū)可以由用于分集接收的兩個(gè)或更多天線覆蓋。每個(gè)BS270可以被構(gòu)造為支持多個(gè)頻率分配,并且每個(gè)頻率分配具有特定頻譜(例如,1.25MHz,5MHz等等)。
分區(qū)與頻率分配的交叉可以被稱為CDMA信道。BS270也可以被稱為基站收發(fā)器子系統(tǒng)(BTS)或者其它等效術(shù)語。在這樣的情況下,術(shù)語"基站"可以用于籠統(tǒng)地表示單個(gè)BSC275和至少一個(gè)BS270?;疽部梢员环Q為"蜂窩站"。或者,特定BS270的各分區(qū)可以被稱為多個(gè)蜂窩站。
如圖2中所示,廣播發(fā)射器(BT)295將廣播信號(hào)發(fā)送給在系統(tǒng)內(nèi)操作的移動(dòng)終端100。如圖1中所示的廣播接收模塊111被設(shè)置在移動(dòng)終端100處以接收由BT295發(fā)送的廣播信號(hào)。在圖2中,示出了幾個(gè)全球定位系統(tǒng)(GPS)衛(wèi)星300。衛(wèi)星300幫助定位多個(gè)移動(dòng)終端100中的至少一個(gè)。
在圖2中,描繪了多個(gè)衛(wèi)星300,但是理解的是,可以利用任何數(shù)目的衛(wèi)星獲得有用的定位信息。如圖1中所示的GPS模塊115通常被構(gòu)造為與衛(wèi)星300配合以獲得想要的定位信息。替代GPS跟蹤技術(shù)或者在GPS跟蹤技術(shù)之外,可以使用可以跟蹤移動(dòng)終端的位置的其它技術(shù)。另外,至少一個(gè)GPS衛(wèi)星300可以選擇性地或者額外地處理衛(wèi)星DMB傳輸。
作為無線通信系統(tǒng)的一個(gè)典型操作,BS270接收來自各種移動(dòng)終端100的反向鏈路信號(hào)。移動(dòng)終端100通常參與通話、消息收發(fā)和其它類型的通信。特定基站270接收的每個(gè)反向鏈路信號(hào)被在特定BS270內(nèi)進(jìn)行處理。獲得的數(shù)據(jù)被轉(zhuǎn)發(fā)給相關(guān)的BSC275。BSC提供通話資源分配和包括BS270之間的軟切換過程的協(xié)調(diào)的移動(dòng)管理功能。BSC275還將接收到的數(shù)據(jù)路由到MSC280,其提供用于與PSTN290形成接口的額外的路由服務(wù)。類似地,PSTN290與MSC280形成接口,MSC與BSC275形成接口,并且BSC275相應(yīng)地控制BS270以將正向鏈路信號(hào)發(fā)送到移動(dòng)終端100。
基于上述移動(dòng)終端硬件結(jié)構(gòu)以及通信系統(tǒng),提出本發(fā)明系統(tǒng)各個(gè)實(shí)施例。
首先,本發(fā)明提出一種數(shù)據(jù)請(qǐng)求處理裝置400。
如圖3所示,本發(fā)明所述的數(shù)據(jù)請(qǐng)求處理裝置的功能模塊示意圖。在本實(shí)施例中,所述數(shù)據(jù)請(qǐng)求處理裝置400可以被分割成一個(gè)或多個(gè)模塊,所述一個(gè)或多個(gè)模塊被存儲(chǔ)于所述存儲(chǔ)器160中,并由一個(gè)或多個(gè)控制器(本實(shí)施例中的所述控制器180)所執(zhí)行,以完成本發(fā)明。例如,在圖3中,所述數(shù)據(jù)請(qǐng)求處理裝置400可以被分割成建立模塊401、發(fā)送模塊402、處理模塊403。本發(fā)明所稱的模塊是指一種能夠完成特定功能的一系列計(jì)算機(jī)程序指令段,以下將就上述各功能模塊401-403的具體功能進(jìn)行詳細(xì)描述。
所述建立模塊401,用于與服務(wù)器建立服務(wù)器發(fā)送事件SSE通道。
具體地,所述移動(dòng)終端100可以作為客戶端,用于服務(wù)器進(jìn)行通信。示例性的,通過客戶端安裝的APP,如瀏覽器,在網(wǎng)頁打開時(shí)通過某一命令向服務(wù)器發(fā)送連接請(qǐng)求,服務(wù)器接收該請(qǐng)求以后與該客戶端建立服務(wù)器發(fā)送事件SSE(Server-Sent Events,簡稱SSE)通道。示例性的,一個(gè)賬戶可以在一臺(tái)或者多臺(tái)終端上登陸,每一臺(tái)終端上登陸的賬戶都可以作為一個(gè)獨(dú)立的客戶端與服務(wù)器建立一個(gè)SSE通道,這樣將會(huì)在不同終端上發(fā)送的數(shù)據(jù)請(qǐng)求將會(huì)得到對(duì)應(yīng)的結(jié)果。
需要補(bǔ)充的是,本發(fā)明實(shí)施例的客戶端和服務(wù)器指的是BS模式(即Browser-Server),CS模式(Client-Server)需要使用輪詢或隊(duì)列推送的方案解決。
本領(lǐng)域技術(shù)人員可以理解的是,SSE推送,即Server-Send Event,用戶服務(wù)器向?yàn)g覽器推送數(shù)據(jù)。只要瀏覽器與服務(wù)器建立一條SSE通道,服務(wù)器就可以把需要的數(shù)據(jù)通過這個(gè)通道推送給瀏覽器,而不需要瀏覽器手動(dòng)去獲取。
所述發(fā)送模塊402,用于發(fā)送數(shù)據(jù)請(qǐng)求,并接收所述服務(wù)器發(fā)送的與所述數(shù)據(jù)請(qǐng)求對(duì)應(yīng)的識(shí)別標(biāo)志。
可以理解的是,采用異步執(zhí)行的方式訪問接口,所謂的異步執(zhí)行訪問模式為:客戶端發(fā)送請(qǐng)求后,能立馬收到服務(wù)器的確認(rèn)信息,如圖4所示。具體的,客戶端發(fā)送的請(qǐng)求可以為建立SSE通道的請(qǐng)求,服務(wù)器收到后反饋給客戶端的確認(rèn)信息為確認(rèn)建立SSE通道的確認(rèn)信息。另外,在服務(wù)器內(nèi)部啟動(dòng)另一個(gè)線程用于執(zhí)行這個(gè)任務(wù)。這樣,客戶端不用保持連接,等待任務(wù)執(zhí)行完畢再斷開連接。因此,不用時(shí)刻保持連接能夠節(jié)約服務(wù)器的資源,且能夠減輕服務(wù)器與客戶端保持眾多連接數(shù)的壓力。
示例性的,執(zhí)行數(shù)據(jù)庫查詢,獲取數(shù)據(jù)庫查詢執(zhí)行結(jié)果為例。首先,在打開客戶端頁面時(shí),與服務(wù)器建立SSE通道。這個(gè)通道,用于接收服務(wù)器推送過來的消息。當(dāng)通道異常斷開時(shí),SSE本身會(huì)進(jìn)行重連;然后執(zhí)行數(shù)據(jù)庫查詢語句,向服務(wù)器發(fā)送請(qǐng)求,并得到服務(wù)器返回的與所述數(shù)據(jù)請(qǐng)求對(duì)應(yīng)的識(shí)別標(biāo)志,該識(shí)別標(biāo)志與請(qǐng)求對(duì)應(yīng),所有服務(wù)器發(fā)送的與該請(qǐng)求有關(guān)的信息將會(huì)攜帶該識(shí)別標(biāo)志,從而達(dá)到使發(fā)送該請(qǐng)求的客戶端需要獲得的結(jié)果與服務(wù)器發(fā)送的信息一一對(duì)應(yīng)。
所述處理模塊403,用于接收所述服務(wù)器通過所述SSE通道發(fā)送的與所述數(shù)據(jù)請(qǐng)求對(duì)應(yīng)的處理狀態(tài),并根據(jù)所述SSE通道以及所述識(shí)別標(biāo)志,從所述服務(wù)器獲取所述數(shù)據(jù)請(qǐng)求的對(duì)應(yīng)處理結(jié)果。
本發(fā)明實(shí)施例中,服務(wù)器處理數(shù)據(jù)請(qǐng)求,為數(shù)據(jù)請(qǐng)求配置對(duì)應(yīng)的響應(yīng)數(shù)據(jù),即處理結(jié)果。具體的,服務(wù)器可以將數(shù)據(jù)請(qǐng)求的狀態(tài)通過SSE通道發(fā)送給客戶端。
示例性的,數(shù)據(jù)請(qǐng)求的處理狀態(tài)可以為數(shù)據(jù)請(qǐng)求處理完成,可以通過SSE通道告訴客戶端數(shù)據(jù)請(qǐng)求已經(jīng)完成,客戶端可以去獲取對(duì)應(yīng)的處理結(jié)果;或者,數(shù)據(jù)請(qǐng)求的處理狀態(tài)可以為數(shù)據(jù)請(qǐng)求處理失敗,服務(wù)器可以告訴客戶端此次請(qǐng)求未獲得結(jié)果,如此,客戶端能夠重新發(fā)送數(shù)據(jù)請(qǐng)求再次執(zhí)行數(shù)據(jù)請(qǐng)求。
具體的,所述識(shí)別標(biāo)志為通用唯一識(shí)別碼(Universally Unique Identifier,簡稱:UUID),數(shù)據(jù)請(qǐng)求執(zhí)行完畢后,可以通過這個(gè)UUID獲取結(jié)果。
應(yīng)用本發(fā)明圖3所示的實(shí)施例,相較于現(xiàn)有技術(shù),通過與服務(wù)器建立服務(wù)器發(fā)送事件SSE通道;然后發(fā)送數(shù)據(jù)請(qǐng)求,并接收所述服務(wù)器發(fā)送的與所述數(shù)據(jù)請(qǐng)求對(duì)應(yīng)的識(shí)別標(biāo)志;接收所述服務(wù)器通過所述SSE通道發(fā)送的與所述數(shù)據(jù)請(qǐng)求對(duì)應(yīng)的處理狀態(tài),并根據(jù)所述SSE通道以及所述識(shí)別標(biāo)志,從所述服務(wù)器獲取所述數(shù)據(jù)請(qǐng)求的對(duì)應(yīng)處理結(jié)果。這樣只要建立了SSE通道,客戶端即可通過SSE通道能夠在數(shù)據(jù)請(qǐng)求處理完成后獲取對(duì)應(yīng)的處理結(jié)果,而不用客戶端一直保持與服務(wù)器的連接,從而節(jié)省了服務(wù)器的資源。
參見圖5所示,在識(shí)別標(biāo)志為UUID時(shí),所述處理模塊403,可以包括:第一接收子模塊501、發(fā)送子模塊502、獲取子模塊503;具體的,
第一接收子模塊501,用于接收所述服務(wù)器通過所述SSE通道發(fā)送的所述數(shù)據(jù)請(qǐng)求對(duì)應(yīng)的處理狀態(tài);
發(fā)送子模塊502,用于在接收到的所述處理狀態(tài)為完成時(shí),發(fā)送獲取處理結(jié)果的請(qǐng)求至所述服務(wù)器;
獲取子模塊503,用于根據(jù)所述SSE通道以及所述識(shí)別標(biāo)志,從所述服務(wù)器獲取所述數(shù)據(jù)請(qǐng)求的對(duì)應(yīng)處理結(jié)果。
示例性的,數(shù)據(jù)請(qǐng)求處理完成后,服務(wù)器將包含“完成”的信息與UUID一并發(fā)送給客戶端,客戶端接收到以后,判斷該UUID與發(fā)送模塊402中的識(shí)別標(biāo)志是否相同,如果相同,判斷為與自身發(fā)送的數(shù)據(jù)請(qǐng)求對(duì)應(yīng)的處理狀態(tài),進(jìn)而客戶端向服務(wù)器發(fā)送對(duì)應(yīng)的處理結(jié)果的請(qǐng)求;否則,為一次失敗的狀態(tài)發(fā)送,客戶端不予處理。
當(dāng)客戶端與服務(wù)器之間建立了SSE通道,服務(wù)器就可以把消息通過通道推送給客戶端。但是,當(dāng)服務(wù)器部署了多臺(tái),例如,通過代理服務(wù)器nginx轉(zhuǎn)發(fā)時(shí),會(huì)出現(xiàn)消息丟失的現(xiàn)象。原因是客戶端通過nginx與其中的一臺(tái)服務(wù)器建立了SSE通道。當(dāng)nginx把執(zhí)行任務(wù)分發(fā)到另一臺(tái)服務(wù)器時(shí),這臺(tái)服務(wù)器上執(zhí)行的狀態(tài),將無處推送,因?yàn)檫@臺(tái)服務(wù)器沒有與客戶端建立SSE通道。本發(fā)明實(shí)施例提供了一種用于解決上述問題的技術(shù)方案,以下進(jìn)行詳細(xì)說明。
具體的,所述建立模塊401,可以用于:將建立服務(wù)器發(fā)送事件SSE通道的請(qǐng)求發(fā)送至代理服務(wù)器,與所述代理服務(wù)器分配的服務(wù)器建立所述服務(wù)器發(fā)送事件SSE通道。
需要說明的是,在包含代理服務(wù)器時(shí),代理服務(wù)器可以與多個(gè)服務(wù)器相連,代理服務(wù)器用來接收客戶端發(fā)送的請(qǐng)求,并將接收的請(qǐng)求發(fā)送給至少一個(gè)服務(wù)器。
所述處理處理模塊403,可以包括:
第二接收子模塊,用于接收所述服務(wù)器通過所述SSE通道發(fā)送的與所述數(shù)據(jù)請(qǐng)求對(duì)應(yīng)的處理狀態(tài),其中,所述服務(wù)器將與所述數(shù)據(jù)請(qǐng)求對(duì)應(yīng)的處理狀態(tài)及處理結(jié)果發(fā)送至消息隊(duì)列;
第三接收子模塊,用于根據(jù)所述SSE通道以及所述識(shí)別標(biāo)志,接收所述服務(wù)器從所述消息隊(duì)列中獲取并發(fā)送的處理結(jié)果,其中,所述處理結(jié)果為與所述數(shù)據(jù)請(qǐng)求的對(duì)應(yīng)處理。
示例性的,如圖6所示,圖6為本發(fā)明所述的數(shù)據(jù)請(qǐng)求處理裝置第一實(shí)施例的流程示意圖,對(duì)于服務(wù)器A來說,在客戶端通過代理服務(wù)器與服務(wù)器A建立SSE通道以后,客戶端發(fā)送的數(shù)據(jù)請(qǐng)求可以通過代理服務(wù)器發(fā)送至服務(wù)器,具體的,可以為服務(wù)器A、B、C??梢岳斫獾氖牵挥蟹?wù)器A與客戶端建立了SSE通道,如果數(shù)據(jù)請(qǐng)求發(fā)送至服務(wù)器B或者服務(wù)器C,那么無法通過SSE通道將對(duì)應(yīng)的結(jié)果反饋給客戶端。本發(fā)明實(shí)施例中,通過設(shè)置一消息隊(duì)列,將一個(gè)客戶端發(fā)送的請(qǐng)求對(duì)應(yīng)的所有結(jié)果均由執(zhí)行的服務(wù)器發(fā)送至消息隊(duì)列,然后經(jīng)由SSE通道將消息隊(duì)列中的數(shù)據(jù)請(qǐng)求對(duì)應(yīng)的處理結(jié)果發(fā)送給客戶端。
具體的,所述消息隊(duì)列為卡夫卡kafka隊(duì)列。
示例性的,客戶端的瀏覽器通過代理服務(wù)器與服務(wù)器A建立了SSE通道。瀏覽器發(fā)起執(zhí)行的請(qǐng)求。這個(gè)請(qǐng)求無論被nginx分發(fā)到服務(wù)器A、服務(wù)器B還是服務(wù)器C,都會(huì)把狀態(tài)塞到同一個(gè)kafka消息隊(duì)列里面。與瀏覽器建立了SSE通道的服務(wù)器A,在進(jìn)行消息推送時(shí),不是從本地獲取,而是從公共件kafka隊(duì)列獲取。這樣做到每臺(tái)服務(wù)器上產(chǎn)生的數(shù)據(jù)都能推送成功。
因此,應(yīng)用本發(fā)明圖6所示的實(shí)施例,能夠避免數(shù)據(jù)發(fā)送請(qǐng)求通過代理服務(wù)器進(jìn)行發(fā)送的時(shí)候被分配到不止一臺(tái)服務(wù)器進(jìn)行數(shù)據(jù)處理而產(chǎn)生的數(shù)據(jù)丟失,因此,能夠保證數(shù)據(jù)請(qǐng)求對(duì)應(yīng)處理結(jié)果的安全性和完整性。
另外,為了保證不把用戶A產(chǎn)生的消息推送到用戶B的SSE通道,可以使用一個(gè)用戶一個(gè)kafka隊(duì)列的方式解決以上問題。即這個(gè)隊(duì)列中只存放當(dāng)前用戶產(chǎn)生的數(shù)據(jù)。往往同一個(gè)用戶,同一時(shí)間會(huì)在多個(gè)設(shè)備上登陸。為了防止另一個(gè)設(shè)備上產(chǎn)生的數(shù)據(jù),會(huì)推送到當(dāng)前設(shè)備。需要對(duì)同一個(gè)用戶的一次請(qǐng)求建立鏈接。為了解決這個(gè)問題,隊(duì)列的命名方式改成用戶名+頁面唯一標(biāo)識(shí)。每次SSE重連,傳入的頁面唯一標(biāo)識(shí)一樣,保證同一個(gè)頁面消費(fèi)的是同一個(gè)消息隊(duì)列。
進(jìn)一步地,本發(fā)明還提供了一種數(shù)據(jù)請(qǐng)求處理方法,應(yīng)用于客戶端,如圖7所示,是本發(fā)明所述的數(shù)據(jù)請(qǐng)求處理方法流程示意圖。在本實(shí)施例中,所述數(shù)據(jù)請(qǐng)求處理方法可以分為以下步驟:
S701,與服務(wù)器建立服務(wù)器發(fā)送事件SSE通道。
S702,發(fā)送數(shù)據(jù)請(qǐng)求,并接收所述服務(wù)器發(fā)送的與所述數(shù)據(jù)請(qǐng)求對(duì)應(yīng)的識(shí)別標(biāo)志。
S703,接收所述服務(wù)器通過所述SSE通道發(fā)送的與所述數(shù)據(jù)請(qǐng)求對(duì)應(yīng)的處理狀態(tài),并根據(jù)所述SSE通道以及所述識(shí)別標(biāo)志,從所述服務(wù)器獲取所述數(shù)據(jù)請(qǐng)求的對(duì)應(yīng)處理結(jié)果。
具體的,所述識(shí)別標(biāo)志可以為通用唯一識(shí)別碼。
具體的,如圖8所示,所述接收所述服務(wù)器通過所述SSE通道發(fā)送的與所述數(shù)據(jù)請(qǐng)求對(duì)應(yīng)的處理狀態(tài),并根據(jù)所述SSE通道以及所述識(shí)別標(biāo)志,從所述服務(wù)器獲取所述數(shù)據(jù)請(qǐng)求的對(duì)應(yīng)處理結(jié)果,包括:
S801,接收所述服務(wù)器通過所述SSE通道發(fā)送的所述數(shù)據(jù)請(qǐng)求對(duì)應(yīng)的處理狀態(tài);
S802,在接收到的所述處理狀態(tài)為完成時(shí),發(fā)送獲取處理結(jié)果的請(qǐng)求至所述服務(wù)器;
S803,根據(jù)所述SSE通道以及所述識(shí)別標(biāo)志,從所述服務(wù)器獲取所述數(shù)據(jù)請(qǐng)求的對(duì)應(yīng)處理結(jié)果。
具體的,所述與服務(wù)器建立服務(wù)器發(fā)送事件SSE通道,包括:
將建立服務(wù)器發(fā)送事件SSE通道的請(qǐng)求發(fā)送至代理服務(wù)器,與所述代理服務(wù)器分配的服務(wù)器建立所述服務(wù)器發(fā)送事件SSE通道;
所述接收所述服務(wù)器通過所述SSE通道發(fā)送的與所述數(shù)據(jù)請(qǐng)求對(duì)應(yīng)的處理狀態(tài),并根據(jù)所述SSE通道以及所述識(shí)別標(biāo)志,從所述服務(wù)器獲取所述數(shù)據(jù)請(qǐng)求的對(duì)應(yīng)處理結(jié)果,包括:
接收所述服務(wù)器通過所述SSE通道發(fā)送的與所述數(shù)據(jù)請(qǐng)求對(duì)應(yīng)的處理狀態(tài),其中,所述服務(wù)器將與所述數(shù)據(jù)請(qǐng)求對(duì)應(yīng)的處理狀態(tài)及處理結(jié)果發(fā)送至消息隊(duì)列;
根據(jù)所述SSE通道以及所述識(shí)別標(biāo)志,接收所述服務(wù)器從所述消息隊(duì)列中獲取并發(fā)送的處理結(jié)果,其中,所述處理結(jié)果為與所述數(shù)據(jù)請(qǐng)求的對(duì)應(yīng)處理。
具體的,所述消息隊(duì)列為卡夫卡kafka隊(duì)列。
應(yīng)用本發(fā)明圖7所示的實(shí)施例,相較于現(xiàn)有技術(shù),本發(fā)明所提出的數(shù)據(jù)請(qǐng)求處理裝置,通過與客戶端建立服務(wù)器發(fā)送事件SSE通道;然后接收所述客戶端發(fā)送的數(shù)據(jù)請(qǐng)求,并發(fā)送與數(shù)據(jù)請(qǐng)求對(duì)應(yīng)的識(shí)別標(biāo)志至客戶端;處理所述數(shù)據(jù)請(qǐng)求,并將數(shù)據(jù)請(qǐng)求的處理狀態(tài)通過SSE通道發(fā)送至所述客戶端,以使所述客戶端根據(jù)所述識(shí)別標(biāo)志通過SSE通道獲取所述數(shù)據(jù)請(qǐng)求的對(duì)應(yīng)處理結(jié)果。這樣只要建立了SSE通道,即可通過SSE通道能夠在數(shù)據(jù)請(qǐng)求處理完成后獲取對(duì)應(yīng)的處理結(jié)果,而不用客戶端一直保持與服務(wù)器的連接,節(jié)省了服務(wù)器的資源。
上述本發(fā)明實(shí)施例序號(hào)僅僅為了描述,不代表實(shí)施例的優(yōu)劣。
通過以上的實(shí)施方式的描述,本領(lǐng)域的技術(shù)人員可以清楚地了解到上述實(shí)施例方法可借助軟件加必需的通用硬件平臺(tái)的方式來實(shí)現(xiàn),當(dāng)然也可以通過硬件,但很多情況下前者是更佳的實(shí)施方式。基于這樣的理解,本發(fā)明的技術(shù)方案本質(zhì)上或者說對(duì)現(xiàn)有技術(shù)做出貢獻(xiàn)的部分可以以軟件產(chǎn)品的形式體現(xiàn)出來,該計(jì)算機(jī)軟件產(chǎn)品存儲(chǔ)在一個(gè)存儲(chǔ)介質(zhì)(如ROM/RAM、磁碟、光盤)中,包括若干指令用以使得一臺(tái)終端設(shè)備(可以是手機(jī),計(jì)算機(jī),服務(wù)器,空調(diào)器,或者網(wǎng)絡(luò)設(shè)備,機(jī)器人等)執(zhí)行本發(fā)明各個(gè)實(shí)施例所述的方法。
以上僅為本發(fā)明的優(yōu)選實(shí)施例,并非因此限制本發(fā)明的專利范圍,凡是利用本發(fā)明說明書及附圖內(nèi)容所作的等效結(jié)構(gòu)或等效流程變換,或直接或間接運(yùn)用在其他相關(guān)的技術(shù)領(lǐng)域,均同理包括在本發(fā)明的專利保護(hù)范圍內(nèi)。