黃初龍,董思平,鄧 祥,胡衛(wèi)芬,耿 瓊,王占良
(1.尋甸回族彝族自治縣氣象局,云南尋甸 655200;2.昆明市氣象局,昆明 650000)
微信是當前我國公眾使用最為廣泛、普及率最高的一類社交通信軟件,利用微信可將氣象信息及時、準確地推送給用戶,顯著提升氣象服務(wù)信息的時效性和服務(wù)水平,因此利用微信開展縣級氣象服務(wù)是目前社會發(fā)展的大趨勢。國內(nèi)許多氣象工作者對此做了大量工作,金淼等[1]、田新芳等[2]、騫少禹等[3]、張偉強等[4]、何步江等[5]、劉豫等[6]、畢陟等[7]對微信開展氣象服務(wù)進行了研究,龍亞星等[8]、何林等[9]、劉名等[10]、陳科等[11]、馬鋒等[12]對基于自動站數(shù)據(jù)的接口進行了相關(guān)業(yè)務(wù)服務(wù)研究。
縣級氣象部門處于氣象服務(wù)一線,在服務(wù)地方經(jīng)濟社會發(fā)展、服務(wù)民生、服務(wù)各行各業(yè)等方面發(fā)揮著重要作用。隨著互聯(lián)網(wǎng)+、大數(shù)據(jù)、AI等新型技術(shù)的發(fā)展,公眾接收氣象信息的手段、方式和渠道越來越多,導(dǎo)致出現(xiàn)部分氣象信息和氣象部門提供的預(yù)報、預(yù)警和服務(wù)結(jié)論不一致、信息重疊等多種問題??h級氣象部門如何掌握氣象服務(wù)的主動權(quán)是值得思考的一個現(xiàn)實問題。云南省尋甸回族彝族自治縣氣象局設(shè)計開發(fā)了“尋甸氣象”微信公眾服務(wù)平臺,將縣級氣象數(shù)據(jù)圖形化,通過微信公眾服務(wù)平臺將氣象監(jiān)測、預(yù)報、預(yù)警和服務(wù)信息及時進行主動推送,解決縣級氣象服務(wù)存在的預(yù)報預(yù)警服務(wù)不及時、傳播渠道單一等難題。
縣級氣象微信公眾服務(wù)平臺對于整合氣象業(yè)務(wù)數(shù)據(jù)以及全面提升氣象服務(wù)能力具有十分重要的意義。系統(tǒng)結(jié)構(gòu)主要分為4個部分(圖1):氣象數(shù)據(jù)采集存儲系統(tǒng),接口服務(wù)系統(tǒng),前端展示系統(tǒng),后端發(fā)布系統(tǒng)。4個部分均采用成熟的架構(gòu)開發(fā)。
圖1 系統(tǒng)結(jié)構(gòu)及功能模塊圖
縣級氣象微信公眾服務(wù)平臺的服務(wù)都基于微信公眾號接口實現(xiàn)對接,用戶打開手機微信實現(xiàn)操作和查看,手機點擊微信公眾號的菜單查看前端展示系統(tǒng),前端展示系統(tǒng)根據(jù)用戶指令通過接口服務(wù)系統(tǒng)訪問氣象數(shù)據(jù)采集存儲系統(tǒng),氣象數(shù)據(jù)采集存儲系統(tǒng)從三大平臺實現(xiàn)數(shù)據(jù)采集。后端發(fā)布系統(tǒng)主要解決檢索和利用微信公眾號實現(xiàn)服務(wù)信息主動推送,如推送預(yù)警信息、天氣預(yù)報、超過閾值的實況信息等。
主要從綜合氣象信息共享平臺采集尋甸全縣觀測站地面逐小時資料、省級格點預(yù)報訂正產(chǎn)品、精細化預(yù)報產(chǎn)品、雷達單站PUP產(chǎn)品;從國家突發(fā)事件預(yù)警信息發(fā)布網(wǎng)采集預(yù)警信息;從縣級預(yù)報制作系統(tǒng)采集短期天氣預(yù)報、鄉(xiāng)鎮(zhèn)預(yù)報和各類氣象服務(wù)產(chǎn)品。并進行必要的解析、轉(zhuǎn)換,然后通過接口服務(wù)系統(tǒng)存儲到氣象數(shù)據(jù)采集存儲系統(tǒng)。
從國家突發(fā)事件預(yù)警信息發(fā)布網(wǎng)采集預(yù)警信息關(guān)鍵核心代碼如下。
stringmatchName = String.Format("{0}(氣象局|氣象臺|突發(fā)事件)", stationName);
Regex reg = new Regex(matchName);
string result = GetAlert ();
var json = DynamicJson.Parse(result);
foreach (var item in json.alertData){
string title = item.headline;
var match = reg.Match(title);
if (match.Success && match.Value.Length > 0){
string signaltype, signallevel;
bool bRet = GetAlert_Class_Level
(item.headline, out signaltype, out signallevel);
AlertData obj = new AlertData();
obj.issueTitle = item.headline;
obj.issueContent = item.description;
obj.areaName = title.Substring(0, nLen);
obj.signalType = signaltype;
obj.signalLevel = signallevel;
obj.issueTime = item.sendTime;
list.Add(obj); }}
接口服務(wù)系統(tǒng)用于向氣象微信公眾服務(wù)平臺提供基于HTTP請求與應(yīng)答服務(wù),實現(xiàn)所有模塊的動態(tài)升級,主要提供以下功能。①與數(shù)據(jù)庫相連,為氣象數(shù)據(jù)采集存儲系統(tǒng)提供數(shù)據(jù)同步服務(wù)。②與數(shù)據(jù)庫相連,為前端展示系統(tǒng)提供實況、預(yù)報、預(yù)警、氣象服務(wù)產(chǎn)品等各類定制化的氣象數(shù)據(jù)獲取服務(wù)。③與微信公眾平臺對接,為尋甸氣象微信菜單提供增加、刪除、改動和查詢服務(wù);為后端發(fā)布系統(tǒng)提供定制化預(yù)報、服務(wù)產(chǎn)品和實況告警信息的自動發(fā)送。④處理文件系統(tǒng)中雷達、網(wǎng)格預(yù)報等數(shù)據(jù)解析生成的前端展示產(chǎn)品。
操作微信公眾號接口關(guān)鍵核心代碼如下。
Encodingencoding = Encoding.UTF8;
string url = String.Format("https://api.weixin.qq.com/cgi-bin/menu/create?access_token={0}", accessToken);
byte[] data = encoding.GetBytes(menu);
HttpWebRequest request = (HttpWebRequest)WebRequest.Create(url);
request.Method = "POST";
request.ContentType = "application/x-www-form-urlencoded";
Stream writer =request.GetRequestStream();
writer.Write(data, 0, data.Length);
writer.Flush();
HttpWebResponse response = (HttpWebResponse)request.GetResponse();
StreamReader reader = new StreamReader(response.GetResponseStream(), Encoding.Default);
string retString = reader.ReadToEnd();
reader.Close();
展示系統(tǒng)基于Html5開發(fā),主要提供以下功能。①基于高德地圖顯示地面逐小時資料、雷達單站PUP產(chǎn)品、鄉(xiāng)鎮(zhèn)預(yù)報等資料。②基于位置定位顯示智能網(wǎng)格、臨近雨情、閃電定位、災(zāi)情上報等資料。③圖文列表方式顯示氣象數(shù)據(jù)統(tǒng)計查詢、天氣預(yù)警、氣象服務(wù)產(chǎn)品和氣象科普等資料。
在實際展示功能設(shè)計上,在滿足用戶實際需求的前提下,提供差異化和個性化的特色內(nèi)容。用戶可基于位置提供的功能有監(jiān)測實況、預(yù)報預(yù)警和氣象服務(wù)3大類功能,有效對接氣象部門相關(guān)業(yè)務(wù)系統(tǒng),利用接口服務(wù)系統(tǒng)展現(xiàn)系統(tǒng)所需數(shù)據(jù)的自動獲取、轉(zhuǎn)換和顯示。
前端展示系統(tǒng)定位關(guān)鍵核心代碼如下。
lbsMap.geolocation = new AMap.Geolocation({
enableHighAccuracy: true,timeout: 10000,maximumAge: 0,convert: true,showButton: false,showMarker: true,
showCircle: true,panToLocation: true,zoomToAccuracy: false});
lbsMap.mapObj.addControl(lbsMap.geolocation);
AMap.event.addListener(lbsMap.geolocation, ′complete′, lbsMap.geolocation_onComplete);
AMap.event.addListener(lbsMap.geolocation, ′error′, lbsMap.geolocation_onError);
lbsMap.geolocation.getCurrentPosition();});
前端展示系統(tǒng)插值處理關(guān)鍵核心代碼如下:
List
List
List
List
int bmpHeight = (int)(bmpWidth * (extent.YMax-extent.YMin) / (extent.XMax-extent.XMin));
Bitmap bmp = newBitmap(bmpWidth, bmpHeight);
GraphicsgData = Graphics.FromImage(bmp);
gData.Clear(bgColor);
Color[] mColors = new Color[newColDef. ColorList.Count];
for (int i = 0; i < newColDef.ColorList.Count; i++)
{
mColors[i] = newColDef.ColorList[i].Color;
}
后端發(fā)布系統(tǒng)主要提供以下功能。①定時檢索短期天氣預(yù)報、天氣預(yù)警以及氣象服務(wù)產(chǎn)品是否更新,如果有更新則調(diào)用接口服務(wù)系統(tǒng)發(fā)送。②定時檢查氣象站實況要素是否達到告警訂閱的閾值,并獲取訂閱的粉絲信息,調(diào)用接口服務(wù)系統(tǒng)發(fā)送。
后端發(fā)布系統(tǒng)關(guān)鍵核心代碼如下。
OpenIdResultJson list = wechatApi.Get(token.access_token, "");
if (list.data != null && list.data.openid != null)
{
foreach (string id in list.data.openid)
{
if (!String.IsNullOrEmpty(id))
wechatApi.SendTemplateMessage(token.access_token, id, req.templateid, req.url, data);
}
}
在系統(tǒng)設(shè)計與實現(xiàn)過程中要重點考慮并解決用戶增多所帶來的并發(fā)訪問題,系統(tǒng)通過圖片服務(wù)器分離技術(shù)、緩存技術(shù)、庫表散列技術(shù)確保用戶的訪問速度和后期升級。
對于Web服務(wù)器來說,圖片和視頻是最消耗資源的,將圖片與頁面進行分離,圖片使用獨立的圖片服務(wù)器。這樣的架構(gòu)可以降低提供頁面訪問請求服務(wù)器系統(tǒng)的壓力,并且可以保證系統(tǒng)不會因為圖片問題而崩潰。在應(yīng)用服務(wù)器和圖片服務(wù)器上,可以進行不同的配置優(yōu)化,比如配置ContentType的時候可以盡量少支持,盡可能少的LoadModule,保證更低的系統(tǒng)消耗和更高的執(zhí)行效率。
緩存就是在內(nèi)存中存儲的數(shù)據(jù)備份,當數(shù)據(jù)沒有發(fā)生本質(zhì)改變的時候,就不讓數(shù)據(jù)的查詢?nèi)?shù)據(jù)庫進行操作,而去內(nèi)存中讀取數(shù)據(jù),這樣就大大降低了數(shù)據(jù)庫的讀寫次數(shù),而且從內(nèi)存中讀取數(shù)據(jù)的速度比去數(shù)據(jù)庫查詢要快一些,這樣同時又提高了效率。
緩存技術(shù)關(guān)鍵核心代碼如下:
public static T Get
{
if ((Get(key) == null)) {
lock (_lockHelp){
if ((Get(key) == null)) {
Insert(key, getCacheFunc(args), expireTime); }
}
}
return (T)Get(key);
}
為解決數(shù)據(jù)庫的瓶頸,從應(yīng)用程序的角度來考慮改善系統(tǒng)架構(gòu),采用庫表散列解決方案。在應(yīng)用程序中按照業(yè)務(wù)和應(yīng)用或者功能模塊將數(shù)據(jù)庫進行分離,不同的模塊對應(yīng)不同的數(shù)據(jù)庫或者表,再按照一定的策略對某個頁面或者功能進行更小的數(shù)據(jù)庫散列,比如粉絲表,按照粉絲OpenID進行表散列,這樣就能夠以較低的成本提升系統(tǒng)的性能并且有很好的擴展性。
經(jīng)測試,縣級氣象微信公眾服務(wù)平臺——尋甸氣象可通過掃二維碼或者添加公眾號進行關(guān)注使用,適用于手機的任何操作系統(tǒng),推廣使用較為簡單方便。
平臺于2019年11月在尋甸縣進行測試使用,測試用戶可主動通過菜單、指令方式獲取實況、預(yù)報、預(yù)警信息。目前平臺提供每月4次最多20條圖文信息群發(fā);實時群發(fā)鄉(xiāng)鎮(zhèn)天氣預(yù)報、氣象災(zāi)害預(yù)警信息;提供發(fā)送路徑,規(guī)定WORD文檔文件名命名規(guī)則,后臺實時接收處理并群發(fā)氣象服務(wù)信息;用戶也可通過菜單、指令方式獲取實況、預(yù)報、預(yù)警信息。
平臺給用戶提供基于位置的天氣實況、氣象服務(wù)等監(jiān)測預(yù)報預(yù)警信息,實現(xiàn)了精細化、互動式、基于位置的智能氣象服務(wù),實現(xiàn)部門之間信息共享。該平臺的運行對于縣級氣象部門在服務(wù)地方經(jīng)濟社會發(fā)展中發(fā)揮著重要作用。
(1)縣級氣象部門利用微信開展氣象服務(wù),能降低設(shè)備和網(wǎng)絡(luò)費用、保障維護等技術(shù)問題,同時發(fā)揮微信用戶廣、服務(wù)高效、易于推廣的特點,有力拓展了縣級氣象服務(wù)渠道和提高服務(wù)質(zhì)量。
(2)在系統(tǒng)結(jié)構(gòu)設(shè)計上,考慮到后期正式推廣后用戶逐漸增長的趨勢情況,采用圖片服務(wù)器分離技術(shù)、緩存技術(shù)和庫表散列技術(shù)確保用戶增長后服務(wù)器可動態(tài)擴展,提高開發(fā)效率和用戶訪問速度。
(3)在功能設(shè)計上,基于用戶定位實現(xiàn)交互式、個性化服務(wù);對數(shù)據(jù)查詢提供數(shù)值、列表、圖形等多種簡單明了的服務(wù)內(nèi)容;便捷高效的提供實況、預(yù)警、預(yù)報和各類氣象服務(wù)信息,功能滿足大部分公眾用戶需求,實況訂閱、天氣快報等模塊又兼顧防災(zāi)減災(zāi)行業(yè)部門的需求,功能設(shè)計比較全面。
(4)平臺采用模塊化的設(shè)計思路,用戶操作簡單方便,后期完善和升級較為便捷。