欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

SpringBoot+Dubbo+Zookeeper實(shí)現(xiàn)簡單分布式開發(fā)的應(yīng)用詳解

 更新時(shí)間:2021年12月29日 09:48:08   作者:落葉之楓?  
這篇文章主要介紹了SpringBoot+Dubbo+Zookeeper實(shí)現(xiàn)簡單分布式開發(fā)的應(yīng)用詳解,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧

開始接觸分布式概念,學(xué)習(xí)之前要準(zhǔn)備搭建Dubbo和Zookeeper環(huán)境的簡單搭建。

Window下安裝Zookeeper和Dubbo-admin

1、Apache官網(wǎng)下載Zookeeper

點(diǎn)擊官網(wǎng)地址下載最新版

下載完成后,打開apache-zookeeper-3.6.2-bin\bin下zkServer.cmd,正常第一次都會(huì)閃退的,因?yàn)闆]有配置好zoo.cfg配置文件。

將conf目錄下的zoo_sample.cfg文件,復(fù)制一份,重命名為zoo.cfg

在這里插入圖片描述

在apache-zookeeper-3.6.2-bin目錄下新建兩個(gè)文件夾data和log

在這里插入圖片描述

修改zoo.cfg配置文件

修改路徑和增加一個(gè)

(修改dataDir的路徑和增加dataLogDir分別對(duì)應(yīng)剛剛新建的data和log文件夾)

然后運(yùn)行bin下zkServer.cmd(不關(guān)閉)

再運(yùn)行zkCli.cmd

在這里插入圖片描述

證明zookeeper搭建成功(詳細(xì)的安裝步驟百度一大堆)

2、GitHub下載Dubbo-admin

去GitHub里面下載:點(diǎn)擊GitHub地址

下載完解壓到自己習(xí)慣的位置

打開到根目錄,本地地址前面加cmd 進(jìn)入控制臺(tái),運(yùn)行代碼,打包dubbo-admin

mvn clean package -Dmaven.test.skip=true

命令行運(yùn)行 dubbo-admin\target 下的dubbo-admin-0.0.1-SNAPSHOT.jar

java -jar dubbo-admin-0.0.1-SNAPSHOT.jar

執(zhí)行完畢,我們?nèi)ピL問一下 http://localhost:7001/ , 這時(shí)候我們需要輸入登錄賬戶和密碼,我們都是默認(rèn)的root-root;

登錄成功后,查看界面

在這里插入圖片描述

3、SpringBoot + Dubbo + Zookeeper

框架搭建

  • 啟動(dòng)zookeeper !
  • IDEA創(chuàng)建一個(gè)空項(xiàng)目,項(xiàng)目選擇最下面那個(gè)Empty Project;
  • 創(chuàng)建一個(gè)模塊,選擇Spring Initializr,實(shí)現(xiàn)服務(wù)提供者:provider-server ,選擇web依賴即可
  • 創(chuàng)建一個(gè)模塊,選擇Spring Initializr,實(shí)現(xiàn)服務(wù)消費(fèi)者:consumer-service,選擇web依賴即可

項(xiàng)目創(chuàng)建完畢;

在這里插入圖片描述

pom.xml配置文件引入Dubbo + zookeeper

<!-- Dubbo Spring Boot Starter -->
    <dependency>
      <groupId>org.apache.dubbo</groupId>
      <artifactId>dubbo-spring-boot-starter</artifactId>
      <version>2.7.3</version>
    </dependency>

    <!-- https://mvnrepository.com/artifact/com.github.sgroschupf/zkclient -->
    <dependency>
      <groupId>com.github.sgroschupf</groupId>
      <artifactId>zkclient</artifactId>
      <version>0.1</version>
    </dependency>

    <!-- 引入zookeeper -->
    <dependency>
      <groupId>org.apache.curator</groupId>
      <artifactId>curator-framework</artifactId>
      <version>2.12.0</version>
    </dependency>
    <dependency>
      <groupId>org.apache.curator</groupId>
      <artifactId>curator-recipes</artifactId>
      <version>2.12.0</version>
    </dependency>
    <dependency>
      <groupId>org.apache.zookeeper</groupId>
      <artifactId>zookeeper</artifactId>
      <version>3.4.14</version>
      <!--排除這個(gè)slf4j-log4j12-->
      <exclusions>
        <exclusion>
          <groupId>org.slf4j</groupId>
          <artifactId>slf4j-log4j12</artifactId>
        </exclusion>
      </exclusions>
    </dependency>

在provider-server項(xiàng)目下寫一個(gè)服務(wù)

在這里插入圖片描述

TicketService.java

public interface TicketService {

  public String getTicket();
}

TicketServiceImpl.java

import org.apache.dubbo.config.annotation.Service;
import org.springframework.stereotype.Component;

//zookeeper:服務(wù)注冊(cè)與實(shí)現(xiàn)

@Service  //可以被掃描到,在項(xiàng)目一啟動(dòng)就自動(dòng)注冊(cè)到注冊(cè)中心
@Component //使用了dubbo后,注意不要用到spring的service注解
public class TicketServiceImpl implements TicketService {
  @Override
  public String getTicket() {
    return "楓";
  }
}

在consumer-server項(xiàng)目下寫一個(gè)消費(fèi)者服務(wù)

在這里插入圖片描述

UserService.Java

import org.apache.dubbo.config.annotation.Reference;
import org.springframework.stereotype.Service;


@Service// 注入容器中,用spring的注解
public class UserService {

  //要拿到provider-service提供的票,要去注冊(cè)中心
  @Reference  //引用,導(dǎo)入dubbo的包。正常開發(fā)引用pom坐標(biāo),但是可以定義路徑相同的接口名
  TicketService ticketService;

  public void buyTicket(){
    String ticket = ticketService.getTicket();

    System.out.println("在注冊(cè)中心拿到=》"+ticket);
  }
}

在provider-service的配置文件中配置dubbo相關(guān)屬性!

在這里插入圖片描述

11. 在consumer-service的配置文件中配置dubbo相關(guān)屬性!

在這里插入圖片描述

12. 本來正常步驟是需要將服務(wù)提供者的接口打包,然后用pom文件導(dǎo)入,我們這里使用簡單的方式,直接將服務(wù)的接口拿過來,路徑必須保證正確,即和服務(wù)提供者相同;

在這里插入圖片描述

將provider-service的TicketService復(fù)制一份到consumer-service注意要相同目錄

啟動(dòng)兩個(gè)項(xiàng)目的啟動(dòng)類,注意配置文件中的端口號(hào)配置成不一樣的,然后打開http://localhost:7001登錄,服務(wù)治理-服務(wù)

在這里插入圖片描述

在這里插入圖片描述

在這里插入圖片描述

提供者和消費(fèi)者都有顯示,搭建成功,后臺(tái)一定要掛著zookeeper的服務(wù)。

總結(jié)

這就是SpingBoot + dubbo + zookeeper實(shí)現(xiàn)分布式開發(fā)的應(yīng)用,其實(shí)就是一個(gè)服務(wù)拆分的思想。只是一個(gè)小小的實(shí)現(xiàn),個(gè)人感覺還是挺容易理解的,主要是搭建zookeeper的環(huán)境要注意下細(xì)節(jié),還有項(xiàng)目中導(dǎo)包注解不要導(dǎo)錯(cuò),因?yàn)锧service有兩個(gè)選擇,一個(gè)是spring一個(gè)是dubbo的。還有就是正常開發(fā)是需要將服務(wù)提供者的接口打包,然后用pom文件導(dǎo)入,我們這里使用簡單的方式,直接將服務(wù)的接口拿過來,路徑必須保證正確,即和服務(wù)提供者相同,正常開發(fā)步驟還沒學(xué)到,后面持續(xù)學(xué)習(xí)中,有相關(guān)案例再分享吧0.0。

到此這篇關(guān)于SpingBoot+Dubbo+Zookeeper實(shí)現(xiàn)簡單分布式開發(fā)的應(yīng)用詳解的文章就介紹到這了,更多相關(guān)SpingBoot+Dubbo+Zookeeper分布式內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • 詳解Maven profile配置管理及激活profile的幾種方式

    詳解Maven profile配置管理及激活profile的幾種方式

    這篇文章主要介紹了詳解Maven profile配置管理及激活profile的幾種方式,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2021-01-01
  • 一起聊聊Java中13種鎖的實(shí)現(xiàn)方式

    一起聊聊Java中13種鎖的實(shí)現(xiàn)方式

    分布式系統(tǒng)時(shí)代,線程并發(fā),資源搶占,"鎖"?慢慢變得很重要。那么常見的鎖都有哪些?本文就來和大家聊聊Java中13種鎖的實(shí)現(xiàn)方式,感興趣的可以了解一下
    2022-08-08
  • Java實(shí)現(xiàn)在線聊天功能

    Java實(shí)現(xiàn)在線聊天功能

    這篇文章主要為大家詳細(xì)介紹了Java實(shí)現(xiàn)在線聊天功能,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2022-09-09
  • java 實(shí)現(xiàn)微信服務(wù)器下載圖片到自己服務(wù)器

    java 實(shí)現(xiàn)微信服務(wù)器下載圖片到自己服務(wù)器

    這篇文章主要介紹了 java 實(shí)現(xiàn)微信服務(wù)器下載圖片到自己服務(wù)器的相關(guān)資料,需要的朋友可以參考下
    2017-05-05
  • 深入理解Java中的Lambda表達(dá)式

    深入理解Java中的Lambda表達(dá)式

    這篇文章主要介紹了深入理解Java中的Lambda表達(dá)式,Lambda在各編程語言中都是非常重要的特性,而Java中則加入得有些太晚...需要的朋友可以參考下
    2015-07-07
  • SpringBoot項(xiàng)目實(shí)現(xiàn)MyBatis流式查詢的教程詳解

    SpringBoot項(xiàng)目實(shí)現(xiàn)MyBatis流式查詢的教程詳解

    這篇文章主要介紹了SpringBoot項(xiàng)目如何實(shí)現(xiàn)MyBatis的流式查詢,mybatis的流式查詢,有點(diǎn)冷門,實(shí)際用的場景比較少,但是在某些特殊場景下,卻是十分有效的一個(gè)方法,感興趣的同學(xué)可以參考一下
    2023-06-06
  • Java延時(shí)執(zhí)行的三種實(shí)現(xiàn)方式

    Java延時(shí)執(zhí)行的三種實(shí)現(xiàn)方式

    本文主要介紹了Java延時(shí)執(zhí)行的三種實(shí)現(xiàn)方式,主要包括了Thread.sleep()方法,.sleep()使用Timer類或使用ScheduledExecutorService接口,感興趣的可以了解一下
    2023-12-12
  • Java系統(tǒng)變量參數(shù)獲取設(shè)置System.getProperties()的方法

    Java系統(tǒng)變量參數(shù)獲取設(shè)置System.getProperties()的方法

    這篇文章主要介紹了Java系統(tǒng)變量參數(shù)System.getProperties()獲取設(shè)置方法,文末給大家提到了Systm.getenv()與System.getProperties()區(qū)別,需要的朋友可以參考下
    2022-01-01
  • Java8中方法引用的使用詳解

    Java8中方法引用的使用詳解

    這篇文章主要介紹了Java 8 中的方法引用使用,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2020-12-12
  • 詳解Mybatis攔截器安全加解密MySQL數(shù)據(jù)實(shí)戰(zhàn)

    詳解Mybatis攔截器安全加解密MySQL數(shù)據(jù)實(shí)戰(zhàn)

    本文主要介紹了Mybatis攔截器安全加解密MySQL數(shù)據(jù)實(shí)戰(zhàn),文中通過示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2022-01-01

最新評(píng)論