|
zaiyixiedaxingdeshengchanguanlixitongzhong,wangwangdouhuiyingyongdaorengonglurulishishujugongneng,congerduishengchanshujujinxingxitongdeguanli,zhebufendeshujubunenggouzaiyibiaozhongcaijidao,zhinengtongguorenweidetianxie,zhebufenshujubudanyaocunchudaokehuduan,haiyaoshangchuandaofuwuqiduanjinxingxianshi,zheyangjiuhuiyinfayigeguanjianwenti:如何做到服務器端與客戶端的數據同步?下麵提供三種解決方案。
第一種:服務器端直接調取客戶端數據。
這種方案製作過程比較簡單,隻需要在服務器端針對於相應的客戶端建立一個數據源,選擇遠程節點,並將IP指向客戶端即可。如下圖所示。

其中:主機名/地址為客戶端的IP地址。當這一切配置好之後,隻需在自由報表中調用GetHisDataEx()函數,在運行的情況下就可以調取到客戶端的曆史數據。GetHisDataEx()函數的聲明如下:
GetHisDataEx(string DataSource,string VarName,int StartTime,int MilliSecond)。
其中:DataSource要填寫相應客戶端的數據源名稱,VarName要yao填tian寫xie該gai數shu據ju源yuan下xia的de數shu據ju庫ku變bian量liang名ming稱cheng。這zhe樣yang當dang係xi統tong運yun行xing時shi,在zai服fu務wu器qi端duan就jiu可ke以yi調tiao取qu到dao客ke戶hu端duan的de數shu據ju了le。但dan這zhe中zhong方fang案an存cun在zai一yi個ge弊bi端duan,即ji當dang客ke戶hu端duan停ting止zhi運yun行xing或huo著zhe客ke戶hu端duan與yu服fu務wu器qi端duan通tong訊xun終zhong端duan時shi,那na麼me在zai服fu務wu器qi端duan則ze看kan不bu到dao客ke戶hu端duan的de任ren何he數shu據ju。
第二種:客戶端直接向服務器端插入曆史數據。
這種方案與第一種方案基本類似,需要在客戶端建立一個數據源,並指向服務器端,客戶端在保存曆史數據時調用InsertHisDataEx()函數,該函數的聲明如下:
InsertHisDataEx(string DataSource,string VarName,real Data,int StartTime,int MilliSec)。
其中,DataSource要填寫相應服務器端的數據源名稱,VarName要(yao)填(tian)寫(xie)該(gai)數(shu)據(ju)源(yuan)下(xia)的(de)數(shu)據(ju)庫(ku)變(bian)量(liang)名(ming)稱(cheng)。這(zhe)樣(yang)在(zai)客(ke)戶(hu)端(duan)與(yu)服(fu)務(wu)器(qi)端(duan)通(tong)訊(xun)正(zheng)常(chang)的(de)狀(zhuang)態(tai)下(xia),保(bao)存(cun)動(dong)作(zuo)執(zhi)行(xing)時(shi),客(ke)戶(hu)端(duan)就(jiu)會(hui)直(zhi)接(jie)向(xiang)服(fu)務(wu)器(qi)端(duan)插(cha)入(ru)曆(li)史(shi)數(shu)據(ju)。服(fu)務(wu)器(qi)端(duan)在(zai)報(bao)表(biao)中(zhong)調(tiao)用(yong)GetHisDataEx()hanshujiukeyitiaoqudaobendixiangyingdeshuju。zhezhongfangandebiduanzeshizengdalekehuduandefuhe,huidaozhikehuduanyunxingsudubianman。youdianzeshizaifuwuqiduanhekehuduandoucunyoushuju,xiangdangyuzuoleyicishujubeifen。
第三種:客戶端觸發服務器端自行保存曆史數據。
這(zhe)種(zhong)方(fang)案(an)製(zhi)作(zuo)過(guo)程(cheng)相(xiang)對(dui)於(yu)前(qian)兩(liang)種(zhong)要(yao)複(fu)雜(za)一(yi)些(xie),首(shou)先(xian)要(yao)在(zai)服(fu)務(wu)器(qi)端(duan)建(jian)立(li)一(yi)個(ge)數(shu)據(ju)源(yuan)指(zhi)向(xiang)客(ke)戶(hu)端(duan),並(bing)在(zai)服(fu)務(wu)器(qi)端(duan)建(jian)立(li)相(xiang)應(ying)的(de)點(dian)關(guan)聯(lian)到(dao)客(ke)戶(hu)端(duan)的(de)點(dian)上(shang)。其(qi)次(ci),在(zai)服(fu)務(wu)器(qi)端(duan)數(shu)據(ju)庫(ku)全(quan)局(ju)腳(jiao)本(ben)中(zhong)編(bian)寫(xie)一(yi)段(duan)存(cun)儲(chu)這(zhe)些(xie)點(dian)PV值的曆史數據的腳本,通過一個標誌位觸發存儲動作。客戶端在保存曆史數據時要把相應點的PV值也做修改,這樣服務器上做了相應關聯的點的PV值(zhi)也(ye)會(hui)跟(gen)著(zhe)做(zuo)改(gai)變(bian)。在(zai)通(tong)過(guo)客(ke)戶(hu)端(duan)觸(chu)發(fa)服(fu)務(wu)器(qi)端(duan)的(de)保(bao)存(cun)標(biao)誌(zhi)位(wei),服(fu)務(wu)器(qi)端(duan)就(jiu)會(hui)自(zi)行(xing)的(de)將(jiang)這(zhe)部(bu)分(fen)數(shu)據(ju)存(cun)儲(chu)下(xia)來(lai),在(zai)運(yun)行(xing)的(de)狀(zhuang)態(tai)下(xia)通(tong)過(guo)報(bao)表(biao)調(tiao)用(yong)GetHisDataEx()balishishujutiaoquchulaijike。haikeyizaishujuyuangaojixuanxiangzhongbashujuguzhanghuifugouxuanshang,ruxiatusuoshi。jishiyintongxunzhongduan,kehuduanwufachufafuwuqiduandebaocunbiaozhierdaozhiliangduanshujubutongbu,zaitongxunhuifushi,kehuduanyehuizidongdebazhebufenshujuchangchuandaofuwuqizhong,zheyangjiugengjiaquanmiandebaozhengleliangduanshujudetongbuxing。

第di三san種zhong方fang案an完wan全quan的de解jie決jue了le第di二er種zhong方fang案an中zhong增zeng加jia了le客ke戶hu端duan負fu荷he的de弊bi端duan,也ye解jie決jue了le第di一yi種zhong方fang案an中zhong通tong訊xun中zhong斷duan時shi服fu務wu器qi端duan看kan不bu到dao之zhi前qian曆li史shi數shu據ju的de弊bi端duan,同tong時shi還hai具ju備bei了le前qian兩liang種zhong方fang案an中zhong不bu具ju備bei的de優you勢shi:故障數據恢複,因此在類似這種的案例中,推薦使用第三種方案。
|