在邯鋼SAP R3與MES集成項(xiàng)目中,根據(jù)各個(gè)業(yè)務(wù)模塊的需求,確定通過xI接口交換的數(shù)據(jù)信息主要包括以下幾類。
(1)從四級(jí)R3下傳到MES的數(shù)據(jù),包括物料主數(shù)據(jù)、客戶主數(shù)據(jù)、撿配清單、生產(chǎn)訂單等。
(2)從MES上傳到R3的數(shù)據(jù),包括質(zhì)檢判定、生產(chǎn)收貨、物料移動(dòng)類型記賬等。
(3)三級(jí)之間傳輸?shù)臄?shù)據(jù),包括工廠到工廠采購訂單,三級(jí)之間的物料轉(zhuǎn)儲(chǔ)單等。
針對(duì)邯鋼的業(yè)務(wù)流程及xI技術(shù)特點(diǎn),該項(xiàng)目的實(shí)施流程包括以下幾個(gè)步驟。
(1)業(yè)務(wù)情景分析。描述要實(shí)施的業(yè)務(wù)情景及該業(yè)務(wù)涉及到的后端系統(tǒng),確定接口策略(新建接口或改造原有接口),設(shè)計(jì)業(yè)務(wù)的技術(shù)架構(gòu)、功能架構(gòu)以及xI架構(gòu),并在SLD(System LandscapeDirectory)中創(chuàng)建系統(tǒng)實(shí)體模型。
針對(duì)邯鋼ERP與MES集成項(xiàng)目中各個(gè)業(yè)務(wù)模塊的需求,其業(yè)務(wù)情景可描述為:1)在SAP系統(tǒng)內(nèi)創(chuàng)建銷售訂單;2)進(jìn)行可用性檢查;3)生成計(jì)劃訂單;4)轉(zhuǎn)換為生產(chǎn)訂單;5)在MES中創(chuàng)建相應(yīng)數(shù)據(jù);6)生產(chǎn)完成后創(chuàng)建相應(yīng)的收貨單。以上情景的數(shù)據(jù)傳輸都在xI數(shù)據(jù)平臺(tái)上實(shí)現(xiàn),由100多個(gè)接口管理數(shù)據(jù)的接收。
(2)接口分析。確定接口的以下特性及參數(shù):接口的實(shí)時(shí)性(同步或異步),接口是否需要技術(shù)的或者應(yīng)用層次回應(yīng)方式的確認(rèn)(閉環(huán)與否),每個(gè)接口的導(dǎo)入和導(dǎo)出消息類型,每個(gè)消息類型的數(shù)據(jù)結(jié)構(gòu),文本文件的格式,數(shù)據(jù)庫的結(jié)構(gòu),IDoc(Intermediate Document),RFC(Request for Comments),BAPI(Business Application Programming Interface)的結(jié)構(gòu)以及XML的數(shù)據(jù)結(jié)構(gòu),為每個(gè)消息類型提供數(shù)據(jù)樣本,并在集成知識(shí)庫里創(chuàng)建消息對(duì)象實(shí)體。
以生產(chǎn)訂單管理流程為例,其接口如圖2所示。
(3)映射定義。基于接口分析的結(jié)果確定接口的映射規(guī)則,選擇實(shí)現(xiàn)映射的技術(shù)(圖像工具、JAVA、XSLT)并根據(jù)定義的樣本規(guī)則實(shí)施映射。
(4)環(huán)境準(zhǔn)備。包括測(cè)試環(huán)境定義和測(cè)試環(huán)境準(zhǔn)備。測(cè)試環(huán)境定義,包括代理服務(wù)器的配置和網(wǎng)絡(luò)硬件設(shè)備連接性的定義;測(cè)試環(huán)境準(zhǔn)備,包括完成系統(tǒng)的安裝并在安裝后檢查xI服務(wù),創(chuàng)建用戶,分配用戶權(quán)限等;如果是為上線做準(zhǔn)備,還必須定義上線切換策略,并將切換策略按照開發(fā)機(jī)一測(cè)試機(jī)一生產(chǎn)機(jī)的順序執(zhí)行上傳。
?
(5)系統(tǒng)配置。配置后端系統(tǒng),保證系統(tǒng)能夠產(chǎn)生和接收與樣本數(shù)據(jù)一樣的數(shù)據(jù),根據(jù)步驟(1)~ (4)的結(jié)果在集成目錄中配置xI對(duì)象和xI集成目錄。
(6)系統(tǒng)測(cè)試。用不同的數(shù)據(jù)集進(jìn)行點(diǎn)到點(diǎn)的業(yè)務(wù)情景測(cè)試和上線切換測(cè)試。
完成上述步驟并收集各種數(shù)據(jù)后,進(jìn)行系統(tǒng)環(huán)境配置并完成以下工作:設(shè)定集成情景、建立消息類型、確定業(yè)務(wù)系統(tǒng)、確定邏輯路由規(guī)則、確定技術(shù)路由規(guī)則、進(jìn)行ABAP Proxy的調(diào)用以及JavaServer Proxy的使用。
3 關(guān)鍵問題及解決方案
xI作為新興技術(shù)在國內(nèi)的應(yīng)用還是首次,它的成功運(yùn)行很好地支持了邯鋼ERP項(xiàng)目的進(jìn)行,對(duì)國內(nèi)信息化建設(shè)中的數(shù)據(jù)集成、數(shù)據(jù)通信有很大的借鑒和推動(dòng)作用。以下將對(duì)系統(tǒng)在實(shí)施過程中遇到的多系統(tǒng)通信和數(shù)據(jù)擁堵問題及其解決方案進(jìn)行描述。
3.1 多系統(tǒng)通信問題
邯鄲鋼鐵集團(tuán)信息化項(xiàng)目中包括多個(gè)三級(jí)系統(tǒng),其中三級(jí)的通信通過DB To DB和Web Servers(如Tomcat)兩種方式實(shí)現(xiàn)。如何將xI的通信方式與其他的Web Server集成,是系統(tǒng)實(shí)施中要解決的一個(gè)重要問題。
由于xI本身具有Web Application Server機(jī)制,因此在與其他Web Server通信的方式上采用目前通用的SOAP協(xié)議,即由Tomcat組織XML數(shù)據(jù)通過SOAP協(xié)議組織數(shù)據(jù)到xI,具體實(shí)施過程如下:
建立XML Schema,連接XML文檔事例到XML Schema,SOAP把XML的使用代碼轉(zhuǎn)化為請(qǐng)求和響應(yīng)參數(shù)編碼模式,并采用HTYP傳輸[3]。一個(gè)SOAP方法可以簡(jiǎn)單地看作遵循SOAP編碼規(guī)則的HTYP請(qǐng)求和響應(yīng)。一個(gè)SOAP終端則可以看作一個(gè)基于HTYP的URL,用來識(shí)別方法調(diào)用的目標(biāo)。和Corba/IIOP一樣,SOAP不需要具體的對(duì)象被綁定到一個(gè)給定的終端,而是由具體實(shí)現(xiàn)程序來決定如何把對(duì)象終端標(biāo)識(shí)符映射到服務(wù)器端的對(duì)象。SOAP請(qǐng)求是一個(gè)HTYP POST請(qǐng)求,它的類型必須為text/xml,且必須包含一個(gè)請(qǐng)求.URI。服務(wù)器解釋這個(gè)請(qǐng)求.URI的方式與該請(qǐng)求的實(shí)現(xiàn)方法相關(guān)。
3.2 數(shù)據(jù)擁堵問題
由于xI與三級(jí)系統(tǒng)的連接是一對(duì)多的關(guān)系,由xI系統(tǒng)對(duì)應(yīng)多個(gè)系統(tǒng),而數(shù)據(jù)下傳采用排隊(duì)機(jī)制,因此在數(shù)據(jù)沒有設(shè)定優(yōu)先級(jí)的情況下,下傳的順序?yàn)橄热讼瘸觥.?dāng)下傳通信失敗時(shí),xI會(huì)自動(dòng)重新調(diào)度通信,直到調(diào)度達(dá)到一定次數(shù)(可配置),才認(rèn)定該通信失敗,調(diào)度下一接口,該數(shù)據(jù)保存在數(shù)據(jù)庫中準(zhǔn)備手動(dòng)調(diào)度。在正常情況下,xI的隊(duì)列可并發(fā)處理多條數(shù)據(jù),但一旦下傳數(shù)據(jù)的任一接收方出現(xiàn)異常,如發(fā)生網(wǎng)絡(luò)中斷、數(shù)據(jù)庫死鎖等情況,由單點(diǎn)故障重復(fù)調(diào)度數(shù)據(jù)就會(huì)造成數(shù)據(jù)隊(duì)列過長(zhǎng),系統(tǒng)開銷大規(guī)模增加,進(jìn)而出現(xiàn)單點(diǎn)故障引起數(shù)據(jù)擁堵的狀況。
針對(duì)單點(diǎn)故障引起的數(shù)據(jù)擁堵問題,項(xiàng)目在實(shí)施過程中將XI的數(shù)據(jù)分發(fā)機(jī)制與現(xiàn)有設(shè)備想結(jié)合,建立分布式體系結(jié)構(gòu),將易發(fā)生數(shù)據(jù)異常的接口配置到分流機(jī),如圖3所示。
由于項(xiàng)目中分流系統(tǒng)選用惠普的小型機(jī)HP4640,操作系統(tǒng)為HP-ux,數(shù)據(jù)為為Oracle,而OS/400的數(shù)據(jù)為為DB2,兩種系統(tǒng)的JVM機(jī)制有很大的區(qū)別。因此,分流系統(tǒng)的數(shù)據(jù)主要保存在Oracle中,數(shù)據(jù)調(diào)度時(shí)直接從Orale中調(diào)度,而不從DB2中調(diào)度,當(dāng)某個(gè)接收點(diǎn)出現(xiàn)問題時(shí)可以把有問題的數(shù)據(jù)拋給Oracle,等該接收點(diǎn)恢復(fù)正常時(shí)再手工觸發(fā)數(shù)據(jù)下傳,這種方式將不會(huì)影響其他隊(duì)列數(shù)據(jù)正常下傳。
3.3 實(shí)施效果
邯鄲鋼鐵集團(tuán)信息化項(xiàng)目的數(shù)據(jù)通信不但設(shè)計(jì)復(fù)雜,而且數(shù)據(jù)流量大、業(yè)務(wù)高峰數(shù)據(jù)壓力大,這些都給硬件以及軟件帶來很大的考驗(yàn)。XI技術(shù)的有效實(shí)施,保證了數(shù)據(jù)的有效傳輸對(duì)異常事件的響應(yīng)速度也得到了顯著提高。目前數(shù)據(jù)業(yè)務(wù)量平均保持在同步數(shù)據(jù)每天10000-15000條,異步數(shù)據(jù)8000-12000條左右。當(dāng)前的系統(tǒng)配置在滿足業(yè)務(wù)需要的甚而上優(yōu)化了系統(tǒng)性能,實(shí)現(xiàn)了業(yè)務(wù)系統(tǒng)的集成與優(yōu)化。
評(píng)論
查看更多