Oracle SOA 套件最佳實踐
2024-08-29 13:53:57
供稿:網友
在 SOA 環境中管理流程和服務依賴關系
背景
您知道 BPEL 流程依賴哪些服務嗎?如果使用了不同版本的 BPEL 流程,二者之間的依賴關系很快就會變得更加復雜。如果我們將 BPEL 流程調用的企業服務總線 (ESB) 服務考慮在內,依賴性管理的復雜度將提升。復雜度使得部署和測試耗時、困難且易于出錯。
通常我們最后使用 Microsoft Visio 建模工具來手動描繪依賴關系,并在流程每次更改后忙于更新依賴關系。這是一個阻礙面向服務的體系結構 (SOA) 基礎架構敏捷性的主要羈絆,SOA 體系結構的設計旨在實現業務流程的敏捷更改。
在這一技術說明中,將向您介紹如何成功地改善構建流程,以及實現流程依賴關系圖的自動生成。
我們的挑戰是為客戶實施一個 Oracle SOA 套件示范項目,該項目包含許多 BPEL 流程,并引用眾多 BPEL 子流程和 ESB 服務。最后我們使用了十來個 BPEL 流程和 ESB 服務(它們定義為公共服務,在服務注冊表上共享)以及其他專有 BPEL 流程和 ESB 服務。
首先,我們決定為項目所有服務創建一個基于 Ant 的部署,將 BPEL 流程(包括執行它們的測試用例)部署到不同環境 (測試、集成、生產) ,并通過基于 Ant 的方式將 ESB 服務也部署到這些環境。計算機電子書籍免費下載
要求
完成首個項目版本后,我們有一些要求:
,
當一個 BPEL 流程或 ESB 服務更改后,我們不想部署項目的所有服務。所以我們需要將以項目為中心的部署轉變為以公共服務為中心的部署方法。
在部署 BPEL 流程時,所有依賴關系的 (專有) 子流程和 ESB 服務也將自動部署。
為防止覆蓋特定版本的流程,只有服務器未部署該版本的流程時才進行部署,覆蓋將導致所有實例流信息丟失。
在部署期間應自動創建所有流程和服務依賴關系的可視化圖形,不需另外維護這些信息??梢暬瘓D應該如下所示。
懸而未決的問題
針對這些新要求,我們提出了以下問題,并做出以下解答:
問題:來自流程和服務依賴關系的信息存儲在哪里?需要增加更多信息以創建完整的依賴關系圖嗎?
答案: BPEL 流程調用的所有服務都存儲在 partnerLinkBinding 標記的 bpel.xml 文件中。對于調用的 BPEL 流程、版本信息也以編碼編入 URL 中。例如: 計算機電子書籍免費下載
<PRoperty name="wsdlRuntimeLocation">
${domain_url}/CustomerAccount_BES/1.3/CustomerAccount_BES?wsdl
</property>
要部署的當前版本的 BPEL 流程可以在 build.properties 文件中找到。對于 BPEL 流程的版本維護,我們只需要更改 build.properties 文件中的 rev 屬性。
為區分公共和專有 BPEL 流程,bpel.xml 文件內客戶端的合作伙伴鏈接提供了一個新屬性“type”,其值為“public”或“private”,如此處所示:
<partnerLinkBinding name="client">
<property name="wsdlLocation">CustomerAccount_BES.wsdl</property>
<property name="type">public</property>
</partnerLinkBinding>
問題:有可以動態生成依賴關系圖的工具或框架嗎?
答案:有,一個開放源工具 Graphviz (www.graphviz.org) 可從文本格式的輸入文件生成圖形。
問題:引用其他 BPEL 流程的選項有哪些?
答案:選項有:
引用默認版本
引用具體版本
引用 UDDI 服務鍵 (帶或不帶經編碼的版本信息)
問題:如何能實現所有這些新的部署要求?
答案:使用自定義 Ant 任務可以最好地實現這些新部署要求。
開始工作
問題都得到了圓滿解答,下面我們著手創建一個自定義 Ant 任務。在 Ant 任務中將解析 bpel.xml 文件。對于找到的所有 partnerLinkBindings 標簽,將以遞歸方式開始解析對應的 bpel.xml 文件。除了解析,還將從每個找到的 BPEL 項目的 build.properties 文件中提取版本屬性(“ref”)的當前值。遞歸解析的挑戰之一是跳過循環的依賴關系。
我們在 bpel.xml 文件中新推出的“type”屬性和遞歸解析實現了我們以服務心中的部署的所有需求。
更棒的是,我們使用 Graphviz 解決了依賴關系圖的自動生成問題。為達到此目的,我們要將從遞歸 bpel.xml 解析中得到的所有依賴關系合并為一個 XML 文件,如下所示。 計算機電子書籍免費下載
<?xml version="1.0" encoding="UTF-8"?>
<BPELSuitcase>
<BPELProcess id="Resource_BAS_SetForAccount" src="http://www.oracle.com/technology/tech/soa/soa-suite-best-practices/Resource_BAS_SetForAccount.bpel">
<partnerLinkBindings>
<partnerLinkBinding name="client">
<property name="wsdlLocation">Resource_BAS_SetForAccount.wsdl</property>
<property name="type">public</property>
<property name="version">1.2</property>
</partnerLinkBinding>
<partnerLinkBinding name="RemoveFromAccount">
<property name="wsdlLocation">Resource_BAS_RemoveFromAccount.wsdl</property>
<property name="version">1.5</property>
</partnerLinkBinding>
...
</partnerLinkBindings>
</BPELProcess>
<BPELProcess id="Resource_BAS_RemoveFromAccount" src="http://www.oracle.com/technology/tech/soa/soa-suite-best-practices/Resource_BAS_RemoveFromAccount.bpel">
<partnerLinkBindings>
<partnerLinkBinding name="client">
<property name="wsdlLocation">Resource_BAS_RemoveFromAccount.wsdl</property>
<property name="type">public</property>
<property name="version">1.5</property>
</partnerLinkBinding>
<partnerLinkBinding name="CheckAvailability">
<property name="wsdlLocation">Resource_BES_CheckAvailability.wsdl</property>
<property name="version">1.1</property>
</partnerLinkBinding>
...
</partnerLinkBindings>
</BPELProcess>
<BPELProcess id="Resource_BES_CheckAvailability" src="http://www.oracle.com/technology/tech/soa/soa-suite-best-practices/Resource_BES_CheckAvailability.bpel">
<partnerLinkBindings>
<partnerLinkBinding name="client">
<property name="wsdlLocation">Resource_BES_CheckAvailability.wsdl</property>
<property name="type">public</property>
<property name="version">1.1</property>
</partnerLinkBinding>
...
</partnerLinkBindings>
</BPELProcess>
...
</BPELSuitcase>
使用 XSLT 將合并的 XML 文件轉換為目標格式 (.dot), 這一格式可作為 Graphviz 生成程序的輸入,以生成 PNG 圖像,如下所示:
digraph structs {
node [shape=record,fontname="Arial",fontsize="10"];
edge [fontname="Arial",fontsize="8"];
rankdir=LR;
labeljust=l;
"Resource_BAS_SetForAccount_1_2" [shape=record,label="{Resource_BAS_SetForAccount}|{1.2|public}",
fillcolor=yellowgreen,style=filled];
"Resource_BAS_RemoveFromAccount_1_5" [shape=record,label="{Resource_BAS_RemoveFromAccount}|{1.5|public}",
fillcolor=yellowgreen,style=filled];
"Resource_BES_CheckAvailability_1_1" [shape=record,label="{Resource_BES_CheckAvailability}|{1.1|public}",
fillcolor=yellowgreen,style=filled];
"Resource_BAS_SetForAccount_1_2" -> "Resource_BAS_RemoveFromAccount_1_5" [decorate=true,label=""];
"Resource_BAS_RemoveFromAccount_1_5" -> "Resource_BES_CheckAvailability_1_1" [decorate=true,label=""];
}
由以上 DOT 文件生成的依賴關系圖形如下所示:
在方框中顯示了服務名稱、版本和類型。方框顏色指明了服務類型。在該圖中,我們有三個公共(綠色)服務。本文開頭的圖中還顯示了 ESB 服務 (白色) 和 BPEL 服務 (桔黃色)。
為各個公共 BPEL 流程生成理想的圖之后,我們要實施相關流程的自動部署。對于這一以服務為中心的部署,我們使用了之前生成的流程列表。針對列表中的每一個流程調用標準部署目標。為防止覆蓋服務器上的現有流程版本,只有服務器上沒有當前版本的流程時才會調用部署目標。
可以通過打開到流程 WSDL URL 的 HTTP 連接,然后檢查返回的狀態代碼來確定是否有特定流程版本(HTTP 狀態 200 ? 已經部署, HTTP 狀態 404 ? 尚未部署)。 計算機電子書籍免費下載
我們自定義的 Ant 任務(包含遞歸解析)、PNG 圖像生成以及以服務為中心的部署的輸出如下所示:
...
[mkdir] Created dir: /MyProject/Resource_BAS_SetForAccount/doc
[bpeltask] ** STARTING DeployWithDependencesTask **
[bpeltask] Resource_BAS_SetForAccount-1.2
[bpeltask] ** PARAMETER **
[bpeltask] dotfilename: doc/bpel-recursiv-all.dot
[bpeltask] dotfilenamepublic: doc/bpel-recursiv-public.dot
[bpeltask] deploytarget: deploy
[bpeltask] deployment: true
[bpeltask] overwriting: false
[bpeltask] stoponalreadydeployed: false
[bpeltask] ** RESOVLING RECURSIVLY ALL bpel.xml FILES **
[bpeltask] [Resource_BAS_SetForAccount-1.2]
[bpeltask] [Resource_BAS_SetForAccount-1.2, Resource_BAS_RemoveFromAccount-1.5]
[bpeltask] [Resource_BAS_SetForAccount-1.2, Resource_BAS_RemoveFromAccount-1.5, Resource_BES_CheckAvailability-1.1]
[bpeltask] ** WRITING CENTRAL bpel.xml FILE **
[bpeltask] ** TRANSFORMING DOT FILE **
[bpeltask] ** SERVICE DEPLOYMENT **
[bpeltask] ========================================================================
[bpeltask] SERVICE ALREADY DEPLOYED (HTTP/1.1 200 OK) 'Resource_BES_CheckAvailability' in version '1.1' http://localhost:8888/orabpel/default/Resource_BES_CheckAvailability/1.1/ Resource_BES_CheckAvailability?wsdl
[bpeltask] ========================================================================
[bpeltask] ========================================================================
[bpeltask] SERVICE ALREADY DEPLOYED (HTTP/1.1 200 OK) 'Resource_BAS_RemoveFromAccount' in version '1.5' http://localhost:8888/orabpel/default/Resource_BAS_RemoveFromAccount/1.5/ Resource_BAS_RemoveFromAccount?wsdl
[bpeltask] ========================================================================
[bpeltask] ========================================================================
[bpeltask] SERVICE NOT YET DEPLOYED (HTTP/1.1 404 Not Found) http://localhost:8888/orabpel/default/Resource_BAS_SetForAccount/1.2/ Resource_BAS_SetForAccount?wsdl
[bpeltask] STARTING SERVICE DEPLOYMENT of Resource_BAS_SetForAccount in version 1.2
[bpeltask] ========================================================================
...
結論
可自動生成依賴關系圖的以服務為中心的部署實現了我們所有涉及 SOA 基礎架構透明性的需求。因為部署完全基于 Ant,我們也可以將它用于我們 Luntbuild 的晚間和生產構建工作(持續構建環境)。
為支持客戶的 SOA 治理,我們將在客戶的 wiki 中公開我們的公共流程及其文檔,以及生成的依賴關系圖,如此處所示:
在服務注冊表中查找檢索當前注冊的公共服務的版本時會動態生成 wiki 頁。wiki 頁中的圖提供了到源信息庫 (Subversion) 的鏈接,其中包含了文檔和我們公共服務的注冊版本的實際大小圖。點擊縮略圖可以通過 WebDAV 從 Subversion 中檢索對應的圖。