經常使用協議 —— webservice://

基於 WebService 的遠程調用協議,基於 Apache CXF(Apache 開源的一個 RPC 框架)的 frontend-simple 和 transports-http 實現。web

能夠和原生 WebService 服務互操做,即:apache

  • 提供者用 Dubbo 的 WebService 協議暴露服務,消費者直接用標準 WebService 接口調用,
  • 或者提供方用標準 WebService 暴露服務,消費方用 Dubbo 的 WebService 協議調用。

依賴app

<dependency>
    <groupId>org.apache.cxf</groupId>
    <artifactId>cxf-rt-frontend-simple</artifactId>
    <version>2.6.1</version>
</dependency>
<dependency>
    <groupId>org.apache.cxf</groupId>
    <artifactId>cxf-rt-transports-http</artifactId>
    <version>2.6.1</version>
</dependency>

特性框架

  • 鏈接個數:多鏈接
  • 鏈接方式:短鏈接
  • 傳輸協議:HTTP
  • 傳輸方式:同步傳輸
  • 序列化:SOAP 文本序列化
  • 適用場景:系統集成,跨語言調用

約束frontend

  • 參數及返回值需實現 Serializable 接口
  • 參數儘可能使用基本類型和 POJO

配置ide

配置協議:url

<dubbo:protocol name="webservice" port="8080" server="jetty" />

配置默認協議:spa

<dubbo:provider protocol="webservice" />

配置服務協議:code

<dubbo:service protocol="webservice" />

多端口:server

<dubbo:protocol id="webservice1" name="webservice" port="8080" />
<dubbo:protocol id="webservice2" name="webservice" port="8081" />

直連:

<dubbo:reference id="helloService" interface="HelloWorld" url="webservice://10.20.153.10:8080/com.foo.HelloWorld" />

WSDL:

http://10.20.153.10:8080/com.foo.HelloWorld?wsdl

Jetty Server (默認):

<dubbo:protocol ... server="jetty" />

Servlet Bridge Server (推薦):

<dubbo:protocol ... server="servlet" />

配置 DispatcherServlet:

<servlet>
    <servlet-name>dubbo</servlet-name>
    <servlet-class>com.alibaba.dubbo.remoting.http.servlet.DispatcherServlet</servlet-class>
    <load-on-startup>1</load-on-startup>
</servlet>
<servlet-mapping>
    <servlet-name>dubbo</servlet-name>
    <url-pattern>/*</url-pattern>
</servlet-mapping>

注意,若是使用 servlet 派發請求:

  • 協議的端口 <dubbo:protocol port="8080" /> 必須與 servlet 容器的端口相同,
  • 協議的上下文路徑 <dubbo:protocol contextpath="foo" /> 必須與 servlet 應用的上下文路徑相同。
相關文章
相關標籤/搜索