Dubbo是一個分佈式服務框架,致力於提供高性能和透明化的RPC遠程服務調用方案,以及SOA服務治理方案。java
我也不明白這是什麼意思,使用了以後大概就是提供一個將多個項目進行聯合的一種分佈式,使用的是一種長連接的方法,具體沒有深刻研究,只是試用了一下。git
其核心部分包含:github
另外dubbo進行了與spring的徹底融合,因此能夠直接經過spring的xml文件進行配置,至於怎麼與spring-boot整合,還不知道。spring
上實現:apache
1.首先須要一個zookeeper;具體用法請百度。緩存
2.啓動zookeeper,以這個服務做爲註冊中心服務器
3.生產者,首先引入zookeeper的jarapp
<!-- zookeeper --> <dependency> <groupId>com.github.sgroschupf</groupId> <artifactId>zkclient</artifactId> <version>0.1</version> <scope>provided</scope> </dependency> <dependency> <groupId>org.apache.zookeeper</groupId> <artifactId>zookeeper</artifactId> <version>3.4.6</version> <exclusions> <exclusion> <artifactId>jmxtools</artifactId> <groupId>com.sun.jdmk</groupId> </exclusion> <exclusion> <artifactId>jmxri</artifactId> <groupId>com.sun.jmx</groupId> </exclusion> <exclusion> <artifactId>jms</artifactId> <groupId>javax.jms</groupId> </exclusion> </exclusions> </dependency>
而後是dubbo負載均衡
<dependency> <groupId>com.alibaba</groupId> <artifactId>dubbo</artifactId> <version>2.4.9</version> <scope>compile</scope> <exclusions> <exclusion> <artifactId>spring</artifactId> <groupId>org.springframework</groupId> </exclusion> </exclusions> </dependency>
別忘了還有spring的,這裏就不貼了框架
3.1:
首先定義一個接口,用來發布的:
public interface ProvideService { public String sayHello(String name); }
進行實現:
@Service(value = "provideService") public class ProvideServiceImpl implements ProvideService { public String sayHello(String name){ System.out.println ("ProvideServiceImpl sayHello 走到了"); return name + " say Hello"; } }
而後是最關鍵的spring 配置dubbo
applicationContext.xml
<!-- 啓動spring註解掃描 --> <context:annotation-config /> <context:component-scan base-package="com.dubbo.*" /> <!-- 提供方應用信息,用於計算依賴關係 --> <dubbo:application name="lclc_provider" /> <!-- 使用zookeeper註冊中心暴露服務地址 --> <dubbo:registry address="zookeeper://127.0.0.1:2181" /> <!-- 用dubbo協議在20880端口暴露服務 --> <dubbo:protocol name="dubbo" port="20880" /> <!-- 聲明須要暴露的服務接口 --> <dubbo:service interface="com.dubbo.ProvideService" ref="provideService" />
啓動spring便可
public static void main(String[] args){ ClassPathXmlApplicationContext context = new ClassPathXmlApplicationContext ("applicationContext.xml"); context.start (); try { System.in.read (); } catch (IOException e) { // TODO Auto-generated catch block e.printStackTrace (); }// 按任意鍵退出 }
4.而後是消費者
引入的jar包與生產者同樣,可是須要多加一個,即生產者方提供的接口,由於是經過接口進行代理的
4.1:消費
public static void main(String[] args){ ClassPathXmlApplicationContext context = new ClassPathXmlApplicationContext ("applicationContext.xml"); context.start (); ProvideService demoService = (ProvideService) context.getBean ("ProvideService");// 獲取遠程服務代理 String hello = demoService.sayHello ("lclc");// 執行遠程方法 System.err.println (hello);// 顯示調用結果 }
application.xml
<!-- 啓動spring註解掃描 --> <context:annotation-config /> <context:component-scan base-package="com.dubbo.*" /> <!-- 提供方應用信息,用於計算依賴關係 --> <dubbo:application name="lclc_consumer" /> <!-- 使用zookeeper註冊中心暴露服務地址 --> <dubbo:registry address="zookeeper://127.0.0.1:2181" /> <!-- 用dubbo協議在20880端口暴露服務 --> <dubbo:protocol name="dubbo" port="20880" /> <dubbo:reference id="ProvideService" interface="com.dubbo.ProvideService" />
請注意:生產者與消費者是兩個項目,是部署在兩個服務器上的,經過dubbo進行連接起來,消費者調用生產者的接口就像調用本地同樣。