![基于多種通道的車輛監(jiān)控服務(wù)器設(shè)計_第1頁](http://file4.renrendoc.com/view/4259bd2fd46c1dd58ea23b1a8993ca6b/4259bd2fd46c1dd58ea23b1a8993ca6b1.gif)
![基于多種通道的車輛監(jiān)控服務(wù)器設(shè)計_第2頁](http://file4.renrendoc.com/view/4259bd2fd46c1dd58ea23b1a8993ca6b/4259bd2fd46c1dd58ea23b1a8993ca6b2.gif)
![基于多種通道的車輛監(jiān)控服務(wù)器設(shè)計_第3頁](http://file4.renrendoc.com/view/4259bd2fd46c1dd58ea23b1a8993ca6b/4259bd2fd46c1dd58ea23b1a8993ca6b3.gif)
![基于多種通道的車輛監(jiān)控服務(wù)器設(shè)計_第4頁](http://file4.renrendoc.com/view/4259bd2fd46c1dd58ea23b1a8993ca6b/4259bd2fd46c1dd58ea23b1a8993ca6b4.gif)
下載本文檔
版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請進行舉報或認領(lǐng)
文檔簡介
基于多種通道的車輛監(jiān)控服務(wù)器設(shè)計
隨著社會經(jīng)濟的發(fā)展,大型團隊的監(jiān)督需求不斷增加。這些監(jiān)控系統(tǒng)通常有幾個中央監(jiān)控中心,許多車輛載臺和監(jiān)控中心之間的通信任務(wù)仍然復(fù)雜且復(fù)雜??紤]到通信質(zhì)量、覆蓋范圍等因素,當(dāng)前車輛監(jiān)控系統(tǒng)的無線通信通常采用短消息服務(wù)(sms消息服務(wù))和通用無線服務(wù)(eprs,通用領(lǐng)域的無線服務(wù))。sms適用于車輛數(shù)據(jù)的存儲,存儲轉(zhuǎn)發(fā)方法只能由于負載變化而無法接收傳輸時間。二次計費模式也可以提高大型系統(tǒng)的運營成本。集群分布的帶寬非常高,并且基于ip協(xié)議傳輸?shù)臄?shù)據(jù)非常容易連接到網(wǎng)絡(luò)?;诹髁砍杀?,車輛監(jiān)控信息的傳輸需要成本。然而,由于發(fā)展時間短,eprs的覆蓋范圍遠低于sms。為了實現(xiàn)優(yōu)勢互補,需要車載臺同時支持SMS和GPRS并能自動切換.SMS/GPRS通信服務(wù)器的課題正是針對這一問題提出的,它主要研究車載臺與監(jiān)控中心之間的網(wǎng)絡(luò)互連、車輛定位信息向各監(jiān)控中心的及時分發(fā)、控制信息向車載臺的路由選擇(SMS或GPRS)等技術(shù).本文詳細論述了課題的關(guān)鍵部分SMS/GPRS通信服務(wù)器的設(shè)計思想和實現(xiàn)方法.1sms/gprs通信服務(wù)器設(shè)計SMS/GPRS通信服務(wù)器是車載臺和各監(jiān)控中心之間的信息交換樞紐.所有的車載臺和監(jiān)控中心均作為客戶端與通信服務(wù)器相連(圖1).通信服務(wù)器通過互聯(lián)網(wǎng)與GPRS網(wǎng)絡(luò)的GGSN(GPRS網(wǎng)關(guān)支持節(jié)點)連接,通過租用數(shù)據(jù)專線與SMS的SMSC(短消息服務(wù)中心)連接.各分監(jiān)控中心可視具體情況分別通過LAN(局域網(wǎng))、租用專線或互聯(lián)網(wǎng)與通信服務(wù)器相連.基于上述數(shù)據(jù)通信模型,設(shè)計SMS/GPRS通信服務(wù)器的具體功能如下:①同時提供與GPRS和SMS網(wǎng)絡(luò)相連的鏈路和接口,記錄每一車載臺發(fā)送數(shù)據(jù)的鏈路狀態(tài),監(jiān)控各鏈路的通信狀態(tài),出現(xiàn)異常時自動重連或者報警;②實時將收到的車載臺信息分發(fā)到各監(jiān)控中心,并對信息進行數(shù)據(jù)存貯備份,當(dāng)監(jiān)控中心需要時可以提供相應(yīng)的歷史數(shù)據(jù);③提供面向各監(jiān)控中心的Socket通信接口,在連接時驗證監(jiān)控中心的身份,維護每一監(jiān)控中心所監(jiān)控的車載臺號碼表;④對各監(jiān)控中心的控制命令數(shù)據(jù)包按車載臺的當(dāng)前通信鏈路進行實時轉(zhuǎn)發(fā),緩存暫時無法送達的控制命令數(shù)據(jù)包,待車載臺連通時再進行轉(zhuǎn)發(fā);⑤管理車載臺號碼和監(jiān)控中心用戶.2項目設(shè)計2.1通信服務(wù)器模塊從上述通信模型可以看出,整個系統(tǒng)的通信跨越了GPRS、SMS和各監(jiān)控中心等多個通信網(wǎng)絡(luò).為了解決網(wǎng)間網(wǎng)通信的無共享緩存、異步等問題,SMS/GPRS通信服務(wù)器與各網(wǎng)絡(luò)的通信采用客戶/服務(wù)器模式.根據(jù)通信服務(wù)器的網(wǎng)絡(luò)連接結(jié)構(gòu)、功能以及客戶/服務(wù)器模式的特點,采用分段式模塊化的軟件結(jié)構(gòu).主要包括5個模塊:GPRS通信模塊、SMS通信模塊、用戶管理模塊、報文處理轉(zhuǎn)發(fā)模塊、監(jiān)控中心通信模塊.各模塊之間的關(guān)系如圖2所示.2.2用戶管理模塊整個通信服務(wù)器的數(shù)據(jù)處理模型見圖3.GPRS通信模塊通過GPRS網(wǎng)絡(luò)與車載臺實現(xiàn)數(shù)據(jù)鏈接.它接受并管理所有車載臺通過GPRS網(wǎng)絡(luò)與通信服務(wù)器建立的TCP連接;接收車載數(shù)據(jù)將其轉(zhuǎn)換為監(jiān)控接口協(xié)議數(shù)據(jù)格式后盡快轉(zhuǎn)發(fā)到報文處理轉(zhuǎn)發(fā)模塊,在必要時可以進行數(shù)據(jù)緩存;接收報文處理轉(zhuǎn)發(fā)模塊送來的監(jiān)控中心控制命令,根據(jù)目的車載臺號碼查到對應(yīng)的TCP連接號后提交發(fā)送.SMS通信模塊的功能與GPRS通信模塊類似,但因為SMSC的對外接口協(xié)議類型繁雜,所以協(xié)議轉(zhuǎn)換是本模塊的主要任務(wù)之一.SMS與GPRS通信模塊在協(xié)議轉(zhuǎn)換的過程中,能夠識別出報警、急救等特殊信息,這些信息在加入報文處理轉(zhuǎn)發(fā)模塊的發(fā)送隊列時直接插入隊列的頭部,避免與其他信息排隊而延緩轉(zhuǎn)發(fā).用戶管理模塊所指的用戶包括車載臺用戶和監(jiān)控中心用戶.每個車載臺在投入使用前應(yīng)通過本模塊進行登記,內(nèi)容包括編號、所屬監(jiān)控中心代號(一輛車可同時屬于多個監(jiān)控中心)等.監(jiān)控中心用戶的內(nèi)容包括用戶名、密碼、代號、IP地址等信息,用于監(jiān)控中心向通信服務(wù)器登錄時的注冊認證.報文處理轉(zhuǎn)發(fā)模塊是通信服務(wù)器的核心.它緩存GPRS和SMS兩通信模塊發(fā)來的數(shù)據(jù)包,根據(jù)來源模塊記錄每一數(shù)據(jù)包的源地址(車載臺)的當(dāng)前通信狀態(tài)(GPRS或SMS),根據(jù)源地址查找目的地址(監(jiān)控中心代號)并按監(jiān)控接口協(xié)議格式將其加入數(shù)據(jù)包(如有多個目的地址則相應(yīng)復(fù)制多份).同時,本模塊還對各監(jiān)控中心發(fā)來的數(shù)據(jù)包按類進行處理,需要轉(zhuǎn)發(fā)的按目的地址(車載臺編號)當(dāng)前的鏈路狀態(tài)發(fā)送到相應(yīng)的通信模塊,對于請求改變監(jiān)控車輛的數(shù)據(jù)包則解釋其內(nèi)容并相應(yīng)地修改車載臺的所屬監(jiān)控中心.另外,該模塊對其處理過的數(shù)據(jù)包均作歷史備份.監(jiān)控中心通信模塊負責(zé)維護監(jiān)控中心與通信服務(wù)器的通信鏈路,完成監(jiān)控中心的登錄認證工作,將報文處理轉(zhuǎn)發(fā)模塊發(fā)來的數(shù)據(jù)包發(fā)往監(jiān)控中心,對監(jiān)控中心傳來的數(shù)據(jù)包根據(jù)監(jiān)控接口協(xié)議進行解釋,需要轉(zhuǎn)發(fā)的則送往報文處理轉(zhuǎn)發(fā)模塊.2.3車載臺之間的通信協(xié)議由于通信服務(wù)器連接3種類型的網(wǎng)絡(luò)(SMS、GPRS、監(jiān)控中心),與每個網(wǎng)絡(luò)的通信協(xié)議也互不相同.這就需要通信服務(wù)器完成必要的協(xié)議轉(zhuǎn)換來實現(xiàn)網(wǎng)絡(luò)互通.各模塊的通信協(xié)議如圖4所示.GPRS通信模塊與車載臺之間采用基于TCP/IP的通信協(xié)議.SMS通信模塊與SMSC之間的通信協(xié)議較多,常見的有SMPP、EMI、CIMD、TAP等.為了使通信服務(wù)器能夠與不同接口的SMSC實現(xiàn)互聯(lián),需要一個協(xié)議轉(zhuǎn)換器將它們轉(zhuǎn)換為一種統(tǒng)一協(xié)議.各監(jiān)控中心與通信服務(wù)器之間采用自行設(shè)計的監(jiān)控接口協(xié)議.考慮到車輛監(jiān)控系統(tǒng)傳送的數(shù)據(jù)與SMS的短消息類似,監(jiān)控接口協(xié)議以SMSC的對外接口SMPP協(xié)議為參考協(xié)議,并對原有的命令進行了一些必要的擴充,添加了有關(guān)監(jiān)控中心修改其監(jiān)控車輛號碼等命令,在回執(zhí)上采用了類似TCP/IP批量回應(yīng)的思想,大大減少不必要的網(wǎng)絡(luò)流量.3實現(xiàn)3.1ws提供的soceti線程是具有最小開銷的程序?qū)嶓w,一個線程可以與其他線程并行執(zhí)行.合理地使用多線程可以改善程序結(jié)構(gòu),提高系統(tǒng)的響應(yīng)速度,增強系統(tǒng)的穩(wěn)定性.Winsock是Windows提供的最低層的SocketAPI,它的使用分同步和異步兩種模式.異步模式采用無阻塞調(diào)用,能夠在接收和發(fā)送信息時處理界面和其他事件,適合在單線程的程序中使用,程序結(jié)構(gòu)比較復(fù)雜.在多線程的環(huán)境中,如果使用Winsock的線程專為通信設(shè)計,則無須使用異步模式,而選用實現(xiàn)簡單的同步模式為好.一般主線程執(zhí)行用戶界面,而阻塞Winsock調(diào)用則在其他工作線程中實現(xiàn).系統(tǒng)實現(xiàn)時采用了MFC提供的CAsyncSocket和第三方提供的CBlockingSocket分別支持上述兩種模式.3.2監(jiān)控通信及監(jiān)控通信比較根據(jù)各模塊的功能和組成特點,采用具有圖形界面的主線程實現(xiàn)用戶管理模塊和報文處理轉(zhuǎn)發(fā)模塊,其他3個通信模塊分別由GPRS、SMS和監(jiān)控通信線程實現(xiàn).各線程的關(guān)系及簡要流程圖如圖5所示.用戶管理模塊需要用戶界面,且所管理的數(shù)據(jù)主要由報文處理轉(zhuǎn)發(fā)模塊使用,報文處理轉(zhuǎn)發(fā)模塊又是本通信服務(wù)器的核心模塊,所以將二者結(jié)合起來設(shè)計在主線程內(nèi)較為合理.GPRS和SMS因通信協(xié)議不同,所以需要分開設(shè)立兩個線程.每個線程與外部網(wǎng)絡(luò)都有多條鏈路相聯(lián),且每條鏈路的通信流量不大,所以適合采用消息形式的CAsyncSocket類.監(jiān)控通信模塊與監(jiān)控中心的連接數(shù)不會太大,且各連接的數(shù)據(jù)流量大,協(xié)議統(tǒng)一,所以每個連接適合采用獨立線程(阻塞Winsock)方式實現(xiàn).主線程啟動CBlockingSocket的連接偵聽和第一個監(jiān)控通信線程.監(jiān)控通信線程阻塞等候接收連接,當(dāng)收到連接后馬上啟動第2個監(jiān)控通信線程在Accept調(diào)用阻塞,等候下一個連接.依此類推,在任何時候總有一個監(jiān)控通信線程在等候新的連接.采用這種實現(xiàn)方法,可以支持多個監(jiān)控中心并發(fā)操作,并具有良好的請求響應(yīng)能力.除監(jiān)控通信線程外,其他各線程均采用事件驅(qū)動的結(jié)構(gòu).采用消息觸發(fā)不僅可以使程序具有良好的性能,而且在沒有消息到達時,線程可被掛起,不占用CPU資源,有助于提高整個系統(tǒng)的效率.監(jiān)控線程因為通信流量較大,且其主要工作集中在Socket的讀寫操作上,采用阻塞調(diào)用不會明顯增加CPU的負擔(dān),但卻可以大幅度降低程序?qū)崿F(xiàn)時的復(fù)雜性,提高協(xié)議運行的可靠性.3.3cqueue類下標(biāo)設(shè)計通信服務(wù)器在通信的過程中需要頻繁地查詢和讀寫其中的數(shù)據(jù)信息.為了加快訪問速度,多處數(shù)據(jù)結(jié)構(gòu)采用了以空間換時間的設(shè)計思想.車載臺的通信狀態(tài)表以及所屬監(jiān)控中心表分別以數(shù)組和結(jié)構(gòu)數(shù)組的形式實現(xiàn).每個車載臺擁有自己的編號.按照編號規(guī)則,可以將這些編號映射到0~n的連續(xù)自然數(shù)范圍.以此整數(shù)作為前述兩表的數(shù)組下標(biāo),就可以快速定位所需信息.因為每輛車有可能同時被多個監(jiān)控中心監(jiān)控,所以車載臺所屬監(jiān)控中心表的結(jié)構(gòu)要復(fù)雜一些.考慮到實際使用中每輛車通常只同時被兩個以下的監(jiān)控中心監(jiān)控,設(shè)計了一個帶有指針的含有兩個中心ID的結(jié)構(gòu)(如圖6所示).當(dāng)所屬監(jiān)控中心不多于兩個時,其指針指向NULL.而當(dāng)所屬監(jiān)控中心多于兩個時,可動態(tài)申請一個同樣的結(jié)構(gòu),前一結(jié)構(gòu)的指針則指向新的結(jié)構(gòu),新結(jié)構(gòu)的指針指向NULL,-1表示該存儲單元為空.各線程的緩存隊列是線程交換數(shù)據(jù)的場所.考慮到車輛定位和控制信息的數(shù)據(jù)包的大小比較統(tǒng)一,以結(jié)構(gòu)數(shù)組為基礎(chǔ)設(shè)計了CQueue類.該類在創(chuàng)建時動態(tài)申請指定大小的結(jié)構(gòu)數(shù)組,以便能夠在多線程之間實現(xiàn)數(shù)據(jù)共享.用數(shù)組作為隊列較動態(tài)實時申請的鏈表在內(nèi)存占用方面有些不利,但可加快訪問速度,減少內(nèi)
溫馨提示
- 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請下載最新的WinRAR軟件解壓。
- 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
- 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁內(nèi)容里面會有圖紙預(yù)覽,若沒有圖紙預(yù)覽就沒有圖紙。
- 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
- 5. 人人文庫網(wǎng)僅提供信息存儲空間,僅對用戶上傳內(nèi)容的表現(xiàn)方式做保護處理,對用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對任何下載內(nèi)容負責(zé)。
- 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請與我們聯(lián)系,我們立即糾正。
- 7. 本站不保證下載資源的準確性、安全性和完整性, 同時也不承擔(dān)用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。
最新文檔
- 2025年度戶外廣告牌施工及品牌推廣服務(wù)合同
- 亮化工程管理服務(wù)合同
- 瑜伽館合作合同協(xié)議書
- 地產(chǎn)項目居間協(xié)議書房產(chǎn)轉(zhuǎn)讓全文
- 第三方公司擔(dān)保合同
- 采購商品代理合同
- 2025年博爾塔拉貨車上崗證理論模擬考試題庫
- 2025年南通下載貨運從業(yè)資格證模擬考試
- 2025年青海運輸從業(yè)資格證考試試題庫
- 2025年合肥道路運輸從業(yè)資格證考試題和答案
- GB/T 4365-2024電工術(shù)語電磁兼容
- 高校體育課程中水上運動的安全保障措施研究
- 油氣勘探風(fēng)險控制-洞察分析
- GB 12710-2024焦化安全規(guī)范
- 2022年中考化學(xué)模擬卷1(南京專用)
- 醫(yī)療機構(gòu)質(zhì)量管理指南
- 2024-2025銀行對公業(yè)務(wù)場景金融創(chuàng)新報告
- 《醫(yī)療機構(gòu)老年綜合評估規(guī)范(征求意見稿)》
- 2025屆鄭州市高三一診考試英語試卷含解析
- 新《安全生產(chǎn)法》安全培訓(xùn)
- GB∕T 41097-2021 非公路用旅游觀光車輛使用管理
評論
0/150
提交評論