cuiyi's blog(崔毅 crazycy)

          記錄點(diǎn)滴 鑒往事之得失 以資于發(fā)展
          數(shù)據(jù)加載中……

          可移植性(側(cè)重Web Service)分析

          本系列文章目錄結(jié)構(gòu)

          ?????? 我對 SOA 的認(rèn)識(一)(結(jié)合平時(shí)累積的筆記,不排除有引用) ( 修改版 )

          ?????? 我對 SOA 的認(rèn)識(二)(結(jié)合平時(shí)累積的筆記,不排除有引用)

          ?????? 我對 SOA 的認(rèn)識(三): SOA WebService 戰(zhàn)略與戰(zhàn)術(shù)

          ?????? SOA 和目前業(yè)成熟應(yīng)用的 JavaEE 應(yīng)用方案的一點(diǎn)看法

          ?????? JavaEE 中的三層結(jié)構(gòu)和 MVC

          ?????? SOA 服務(wù)模型分析設(shè)計(jì)的一些概念

          ?????? SOA 涉及的組件和服務(wù)概念的整理(摘自水木) ?

          ? SOA 涉及的 想 & 產(chǎn)品 & 技術(shù)

          ? 可移植性(側(cè)重Web Service )分析

          10?? 任志宏關(guān)于 如何使用 IBM SOA 相關(guān)技術(shù)、產(chǎn)品和服務(wù)實(shí)現(xiàn)一個(gè)典型的業(yè)務(wù)場景 (轉(zhuǎn))

          非常感謝你的閱讀,如果你覺得好或者對你有幫助,請積極給一個(gè)留言反饋以示鼓勵(lì)。 ?

          提到這個(gè)話題,不免得提及Java設(shè)計(jì)理念,以及與Web Service可移植性密切相關(guān)的三個(gè)JSR規(guī)范:JSR1.9、JSR175、JSR181

          提到可移植性,我們又不免想到如下方式:
          ??? ①XML配置文件屏蔽差異,類似Facade Pattern的形式統(tǒng)一入口
          ??? ②注釋
          ??? ③類似JBoss提出的Micro-Container

          我們進(jìn)入正文:

          Java一個(gè)理念是:Write Once, Run AnyWhere。Java哲學(xué):Java追求平衡的哲學(xué)--即簡單和力量的共贏。
          ??? 從目標(biāo)可以看出可移植性是Java的一個(gè)設(shè)計(jì)理念。
          ??? 但Java世界的可移植性束縛苦惱著許多跨應(yīng)用服務(wù)器的開發(fā)者、部署者。

          JSR109
          ??? A. 目標(biāo):以一種可移植和互操作的方式為J2EE構(gòu)建和訪問Web服務(wù)(即Web Service在J2EE上的實(shí)現(xiàn))。它指定了下面的條目:
          ??????? a. 客戶端編程模型:無論客戶端如何訪問Web服務(wù),Web服務(wù)就像一個(gè)普通的遠(yuǎn)程對象一樣(即J2EE如何把Web Service作為傳統(tǒng)的遠(yuǎn)程對象來訪問);
          ??????? b. 服務(wù)器端編程模型:Web服務(wù)怎樣作為SLSB或JAX-RPC形式的Servlet實(shí)現(xiàn)(即怎樣用Servlet和SLSB來實(shí)現(xiàn)Web Service并使Web Service具有和它們一樣的生命周期)
          ??????? c. 部署模型:使用部署描述符來定義可以在所有符合J2EE規(guī)范的應(yīng)用服務(wù)器之間移植Web Service(即如何在應(yīng)用服務(wù)器上部署Web Service)
          ??? B. 個(gè)人觀點(diǎn):a、b兩點(diǎn)表現(xiàn)尚可,c著實(shí)不讓人滿意,因?yàn)閷?shí)現(xiàn)互操作的目標(biāo)沒有問題,但是可移植性著實(shí)難以讓人滿意,問題關(guān)鍵是:部署描述符:
          ??? C. 疑問:為何JSR109不明確規(guī)定部署描述符的明確XML Schema,尤其是文件名、文件的標(biāo)簽、以及部署的文件個(gè)數(shù)。

          JSR175(Java語言元數(shù)據(jù)工具)
          ??? A. 目標(biāo):用于 Java 編程語言的元數(shù)據(jù),就是使用注釋編程
          ??? B. 個(gè)人觀點(diǎn):①簡化了開發(fā)尤其是配置文件 ②可移植性成為可能 ③類似“靜態(tài)類”機(jī)制成為可能
          ?? 說明:只要加載了類,類中的注釋可以是運(yùn)行中的,加載類的時(shí)候完成了配置,而這個(gè)加載可以是入口函數(shù)的調(diào)用、可以是Servlet加載。
          ????????????我們知道只要加載了類,靜態(tài)類變量、靜態(tài)方法就自動(dòng)被初始化到內(nèi)存中;同理,要是有“靜態(tài)類”.......
          ??? C. 疑問:注釋能否像接口、類那樣進(jìn)行功能自定義化呢?!
          ??? D. 摘錄:
          ??? JSR175僅僅有少量的注釋類型變量,而這些有趣的注釋類型變量主要來自于其他的JSRs:
          ??????? ?JSR 250: Java平臺(tái)的公共注釋
          ??????? ?JSR 220: 企業(yè)級JavaBeans 3.0
          ??????? ?JSR 224: 基于XML的Java API Web Services (JAX-WS) 2.0
          ??????? ?JSR 181: Java平臺(tái)的Web Services Metadata

          JSR181(Java Web服務(wù)元數(shù)據(jù))
          ??? A. 目標(biāo):致力于Java Web Service。
          ??????? 基本理念:Java Web服務(wù)僅僅是帶有某些標(biāo)注的普通Java對象(POJO)。使用帶有Java標(biāo)注的Java語言編寫Web服務(wù),并且任何符合規(guī)范的處理器都能處理這些標(biāo)注,并生成適用于目標(biāo)運(yùn)行時(shí)環(huán)境的Web Service。
          ??????? 涉及范圍:
          ????? ?①定義用于進(jìn)行Web服務(wù)應(yīng)用程序編程的帶注釋的Java語法
          ?????? ②提供可促進(jìn)和加速開發(fā)的簡化Web服務(wù)開發(fā)模型
          ????? ?③提供可通過工具進(jìn)行操作的語法
          ?????? ④定義構(gòu)建和部署Web服務(wù)的標(biāo)準(zhǔn),而無須了解通用API和部署描述符的知識和使用相關(guān)實(shí)現(xiàn)
          ??? B. 個(gè)人觀點(diǎn):由于規(guī)范沒有指定web服務(wù)的運(yùn)行環(huán)境,只提供了一個(gè)處理帶注釋的java文件的模型,以及到Java EE運(yùn)行期間的環(huán)境的映射。這不免又存在不可移植性。

          本文主要談?wù)摽梢浦残裕覀兪紫确治鰹楹螘?huì)出現(xiàn)這個(gè)現(xiàn)象?

          首先我們知道J2EE中,部署后的應(yīng)用程序的入口是META-INF文件夾,而這個(gè)文件夾下的部署描述文件則帶有基本的描述信息。
          在Web Service中, META-INF下具有部署描述符:webservices.xml和jax-rpc-mapping.xml;以及服務(wù)描述文件.wsdl。
          ??? webservices.xml依然沒有逃脫出JSR109在可移植性不足的陰影,那我們可以知道,由于WSDL是國際規(guī)范,XML Schema明確加以描述,只要消除了部署描述符的差異,可移植性必然增強(qiáng)。
          ??? 那如果沒有部署描述符如何?
          ??? 首先,我們來分析webservices.xml的作用:Web服務(wù)入口下的webservices.xml告訴容器在何處查找WSDL,以及將什么接口和實(shí)現(xiàn)用作Web服務(wù)。
          ??? 同時(shí),我們知道這些信息的解析起到了一個(gè)注冊表的作用:map(uri-wso對象) wso對象包含:wsdl文件,jax-mapping文件,服務(wù)接口、實(shí)現(xiàn)類,等。
          ??? 那我們有兩種策略
            ①運(yùn)行中生成部署描述符-Java的注釋
            ②放棄部署描述符的概念-
          ???
          ??? 解釋第①中做法
          ??? JSR181處理器,一定要在運(yùn)行中生成符合J2EE規(guī)范的部署描述符,而不是部署前就已生成好。
          ??? 方式<一>:靜態(tài)類,部署時(shí)必然要部署java類,如果有靜態(tài)類(JVM增加功能)概念,則可以通過帶注釋的靜態(tài)類來完成。
          ??? 方式<二>:Servlet加載一個(gè)類,這個(gè)類中具備完善的注釋,Servlet的加載機(jī)制必然導(dǎo)致類的加載,利用運(yùn)行時(shí)注釋生成部署描述符。
          ???

          解釋第②中做法
          ??? 不兼容是因?yàn)闆]有嚴(yán)格的XML Schema來描述部署描述符,而入口卻是這些部署描述符的XML文件;
          ??? 如果有部署描述符(包含運(yùn)行中生成),無非是解析XML文件得到一個(gè)類似注冊表的作用;
          ??? 我們直接由java類來生成這些內(nèi)存注冊信息,而不是通過運(yùn)行時(shí)注釋。
          ??? 方式<一>:靜態(tài)類,部署時(shí)必然要部署java類,如果有靜態(tài)類(JVM增加功能)概念。
          ??? 方式<二>:Servlet加載一個(gè)類,這個(gè)類中具備完善的注釋,Servlet的加載機(jī)制必然導(dǎo)致類的加載,利用運(yùn)行時(shí)注釋生成內(nèi)存注冊信息。
          ??? 這兩種方式不由得想起是否可以在META-INF下放置一個(gè)類?
          ??? 是否可以類似Servlet機(jī)制,從Class-Loader入手?
          ??? 是否可以繼續(xù)改進(jìn)JVM,直接可認(rèn)出直接加載的類?

          ??? 考慮到各集團(tuán)的利益,可以看出JCP更多的致力于改良,而改革動(dòng)作很少,改良往往意味著不能更好的滿足新需求的呼喚,也埋下隱患.
          ???

          Thanks very much to visit blog,? welcome your feedback,? your feedback is the Driver && Power to me

          posted on 2006-11-24 22:20 crazycy 閱讀(1078) 評論(2)  編輯  收藏 所屬分類: JavaEE技術(shù)SOA、WebService、BPEL

          評論

          # re: JSR181規(guī)范的研究分析(JSR181 及 更深入化改進(jìn))  回復(fù)  更多評論   

          actually you can find the function of annotaion, it will help to understand jsr181's real function.
          2006-12-02 11:57 | fengtianxp[匿名]

          # re: 可移植性(側(cè)重Web Service)分析  回復(fù)  更多評論   

          hao crazycy da ge
          i want 2 learn
          2007-04-22 15:08 | 思寬
          主站蜘蛛池模板: 通河县| 酉阳| 南漳县| 扶风县| 甘孜县| 桐庐县| 桂林市| 涪陵区| 嘉黎县| 措勤县| 固原市| 昭通市| 崇信县| 麻栗坡县| 尉犁县| 揭阳市| 平顶山市| 集安市| 黔江区| 云南省| 双辽市| 伊吾县| 霍邱县| 芦山县| 赞皇县| 寻乌县| 万源市| 阿勒泰市| 安泽县| 汤阴县| 柳江县| 富源县| 江川县| 六盘水市| 安多县| 平塘县| 石门县| 南江县| 嘉祥县| 化州市| 九龙县|