在一些大型的生產管理系統中,往往都會應用到人工錄入歷史數據功能,從而對生產數據進行系統的管理,這部分的數據不能夠在儀表中采集到,只能通過人為的填寫,這部分數據不但要存儲到客戶端,還要上傳到服務器端進行顯示,這樣就會引發一個關鍵問題:如何做到服務器端與客戶端的數據同步?下面提供三種解決方案。
第一種:服務器端直接調取客戶端數據。
這種方案制作過程比較簡單,只需要在服務器端針對于相應的客戶端建立一個數據源,選擇遠程節點,并將IP指向客戶端即可。如下圖所示。
其中:主機名/地址為客戶端的IP地址。當這一切配置好之后,只需在自由報表中調用GetHisDataEx()函數,在運行的情況下就可以調取到客戶端的歷史數據。GetHisDataEx()函數的聲明如下:
GetHisDataEx(string DataSource,string VarName,int StartTime,int MilliSecond)。
其中:DataSource要填寫相應客戶端的數據源名稱,VarName要填寫該數據源下的數據庫變量名稱。這樣當系統運行時,在服務器端就可以調取到客戶端的數據了。但這中方案存在一個弊端,即當客戶端停止運行或著客戶端與服務器端通訊終端時,那么在服務器端則看不到客戶端的任何數據。
第二種:客戶端直接向服務器端插入歷史數據。
這種方案與第一種方案基本類似,需要在客戶端建立一個數據源,并指向服務器端,客戶端在保存歷史數據時調用InsertHisDataEx()函數,該函數的聲明如下:
InsertHisDataEx(string DataSource,string VarName,real Data,int StartTime,int MilliSec)。
其中,DataSource要填寫相應服務器端的數據源名稱,VarName要填寫該數據源下的數據庫變量名稱。這樣在客戶端與服務器端通訊正常的狀態下,保存動作執行時,客戶端就會直接向服務器端插入歷史數據。服務器端在報表中調用GetHisDataEx()函數就可以調取到本地相應的數據。這種方案的弊端則是增大了客戶端的負荷,會導致客戶端運行速度變慢。優點則是在服務器端和客戶端都存有數據,相當于做了一次數據備份。
第三種:客戶端觸發服務器端自行保存歷史數據。
這種方案制作過程相對于前兩種要復雜一些,首先要在服務器端建立一個數據源指向客戶端,并在服務器端建立相應的點關聯到客戶端的點上。其次,在服務器端數據庫全局腳本中編寫一段存儲這些點PV值的歷史數據的腳本,通過一個標志位觸發存儲動作。客戶端在保存歷史數據時要把相應點的PV值也做修改,這樣服務器上做了相應關聯的點的PV值也會跟著做改變。在通過客戶端觸發服務器端的保存標志位,服務器端就會自行的將這部分數據存儲下來,在運行的狀態下通過報表調用GetHisDataEx()把歷史數據調取出來即可。還可以在數據源高級選項中把數據故障恢復勾選上,如下圖所示。即使因通訊中斷,客戶端無法觸發服務器端的保存標志而導致兩端數據不同步,在通訊恢復時,客戶端也會自動的把這部分數據長傳到服務器中,這樣就更加全面的保證了兩端數據的同步性。
第三種方案完全的解決了第二種方案中增加了客戶端負荷的弊端,也解決了第一種方案中通訊中斷時服務器端看不到之前歷史數據的弊端,同時還具備了前兩種方案中不具備的優勢:故障數據恢復,因此在類似這種的案例中,推薦使用第三種方案。