真实的国产乱ⅩXXX66竹夫人,五月香六月婷婷激情综合,亚洲日本VA一区二区三区,亚洲精品一区二区三区麻豆

成都創(chuàng)新互聯(lián)網(wǎng)站制作重慶分公司

Springboot集成Dubbox的方法示例

前言

成都創(chuàng)新互聯(lián)是一家專業(yè)提供福田企業(yè)網(wǎng)站建設(shè),專注與網(wǎng)站建設(shè)、做網(wǎng)站、H5技術(shù)、小程序制作等業(yè)務(wù)。10年已為福田眾多企業(yè)、政府機(jī)構(gòu)等服務(wù)。創(chuàng)新互聯(lián)專業(yè)網(wǎng)站設(shè)計(jì)公司優(yōu)惠進(jìn)行中。

因?yàn)楣ぷ髟?,需要在?xiàng)目中集成dubbo,所以去查詢dubbo相關(guān)文檔,發(fā)現(xiàn)dubbo目前已經(jīng)不更新了,所以把目光投向了dubbox,dubbox是當(dāng)當(dāng)網(wǎng)基于dubbo二次開(kāi)發(fā)的一個(gè)項(xiàng)目,dubbox,因?yàn)楣卷?xiàng)目中一個(gè)是基于spring mvc 3.0的,一個(gè)是基于spring boot的,而spring boot相對(duì)來(lái)說(shuō)文檔少一點(diǎn),所以此文記錄下spring boot下如何繼承dubbox

一、安裝zookeeper

1、zookeeper簡(jiǎn)介

ZooKeeper是一個(gè)分布式的,開(kāi)放源碼的分布式應(yīng)用程序協(xié)調(diào)服務(wù),是Google的Chubby一個(gè)開(kāi)源的實(shí)現(xiàn),是Hadoop和Hbase的重要組件。它是一個(gè)為分布式應(yīng)用提供一致性服務(wù)的軟件,提供的功能包括:配置維護(hù)、域名服務(wù)、分布式同步、組服務(wù)等。
ZooKeeper的目標(biāo)就是封裝好復(fù)雜易出錯(cuò)的關(guān)鍵服務(wù),將簡(jiǎn)單易用的接口和性能高效、功能穩(wěn)定的系統(tǒng)提供給用戶

而dubbo就是依賴zookeeper的一個(gè)分布式框架,當(dāng)然二次開(kāi)發(fā)的dubbox肯定也會(huì)依賴于zookeeper,所以我們需要先安裝zookeeper

2、下載zookeeper

zookeeper官網(wǎng)地址http://zookeeper.apache.org/

下載地址http://apache.fayea.com/zookeeper/

本地下載地址,更加方便:https://www.jb51.net/softs/578345.html

3、安裝zookeeper

因?yàn)槲沂窃赪indows環(huán)境配置的,所以就簡(jiǎn)單說(shuō)一下windows下面的配置吧,首先解壓壓縮包,然后進(jìn)入conf文件夾,復(fù)制一下zoosample.cfg創(chuàng)建副本,然后重命名為zoo.cfg,因?yàn)閦ookeeper只識(shí)別zoo.cfg,而默認(rèn)是沒(méi)有這個(gè)文件的,zoosample.cfg是默認(rèn)的配置文件,但是因?yàn)槲募脑?,所以zookeeper無(wú)法識(shí)別,當(dāng)然直接重命名zoo_sample.cfg也是可以的,只是看自己喜歡咯

4、啟動(dòng)zookeeper

Windows環(huán)境下直接運(yùn)行bin目錄下的zkServer.cmd就可以,如果是Linux環(huán)境,則在bin目錄下運(yùn)行

./zkServer.sh start

命令,就可以啟動(dòng)zookeeper

5、添加dubbox依賴 

  
   com.alibaba
   dubbo
   2.8.4
  
  
   com.101tec
   zkclient
   0.9
  
  
   org.apache.zookeeper
   zookeeper
   3.4.6
   
    
     org.slf4j
     slf4j-log4j12
    
    
     log4j
     log4j
    
   
  

注意,這里的dubbo的2.8.4版本是我自己編譯的,這個(gè)在maven倉(cāng)庫(kù)是沒(méi)有的,因?yàn)閐ubbo已經(jīng)不更新了,而2.8.4是當(dāng)當(dāng)網(wǎng)的dubbox,所以如果你要使用,要么就編譯dubbox,要么就使用舊版本的dubbo

6、添加服務(wù)提供者的接口 接口類:

package wang.raye.dubbo.interfaces;
public interface DubboInterface {
 public String hello(String name);
}

接口實(shí)現(xiàn)類:

package wang.raye.dubbodemo1;
import org.springframework.stereotype.Service;
import wang.raye.dubbo.DubboInterface; 
@Service
public class DubboImpl implements DubboInterface {
 public String hello(String name) {
  return "hello "+name+" this is dubbodemo1";
 }

}

7、添加dubbo配置xml xml文件放在sources文件夾,名字可以隨便命名,我這里是dubbo.xml

<?xml version="1.0" encoding="UTF-8"?> 

   
  
 
  
 
 
  
 

這里每個(gè)節(jié)點(diǎn)都有解釋了,相信不過(guò)過(guò)多解釋

8、配置消費(fèi)者

類中引用遠(yuǎn)程提供者

package wang.raye.dubbodemo3.controller;
import org.springframework.beans.factory.annotation.Autowired; 
import org.springframework.stereotype.Controller; 
import org.springframework.web.bind.annotation.RequestMapping; 
import org.springframework.web.bind.annotation.ResponseBody;
import wang.raye.dubbo.DubboInterface;
@Controller
public class DubboControll {

 @Autowired
 private DubboInterface interface1;
 @RequestMapping("/hello")
 @ResponseBody
 public String hello(String name){
  return interface1.hello(name);
 }
}

消費(fèi)者的xml配置

 
  
  
  
  
  
 

這里也是每個(gè)接點(diǎn)都有注釋,應(yīng)該不用多說(shuō),而且比較本文不是講究dubbo配置的,主要是講spring boot集成dubbox

9、引用dubbo配置xml 在Spring boot的Application類添加注解

@ImportResource({"classpath:dubbo.xml"})

因?yàn)槲业膞ml名字是dubbo.xml,所以當(dāng)你用的時(shí)候需要換成自己的xml名字,注意:消費(fèi)者項(xiàng)目和服務(wù)提供者的項(xiàng)目的Application類都需要配置此注解

結(jié)尾

至此,spring boot集成duubox就說(shuō)完了,當(dāng)然這樣說(shuō)肯定很空洞,所以我吧我測(cè)試的項(xiàng)目上傳到了github,大家可以參考看看,當(dāng)然要測(cè)試的話需要修改dubbo.xml的dubbo:registry 節(jié)點(diǎn)中的zookeeper地址。

demo地址,為了顯示出dubbo的優(yōu)勢(shì),所以我創(chuàng)建了2個(gè)服務(wù)提供者,頻繁調(diào)用的話,會(huì)自動(dòng)選擇這2個(gè)中的任何一個(gè),連負(fù)載均衡都免了,應(yīng)該是zookeeper自己做了,所以感覺(jué)還是挺不錯(cuò)的

以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持創(chuàng)新互聯(lián)。


文章名稱:Springboot集成Dubbox的方法示例
轉(zhuǎn)載來(lái)源:http://weahome.cn/article/godpec.html

其他資訊

在線咨詢

微信咨詢

電話咨詢

028-86922220(工作日)

18980820575(7×24)

提交需求

返回頂部