SpringBoot+Dubbo+Zookeeper實(shí)現(xiàn)簡單分布式開發(fā)的應(yīng)用詳解
開始接觸分布式概念,學(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,正常第一次都會閃退的,因?yàn)闆]有配置好zoo.cfg配置文件。
將conf目錄下的zoo_sample.cfg文件,復(fù)制一份,重命名為zoo.cfg

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

修改zoo.cfg配置文件

(修改dataDir的路徑和增加dataLogDir分別對應(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)入控制臺,運(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/ , 這時候我們需要輸入登錄賬戶和密碼,我們都是默認(rèn)的root-root;
登錄成功后,查看界面

3、SpringBoot + Dubbo + Zookeeper
框架搭建
- 啟動zookeeper !
- IDEA創(chuàng)建一個空項(xiàng)目,項(xiàng)目選擇最下面那個Empty Project;
- 創(chuàng)建一個模塊,選擇Spring Initializr,實(shí)現(xiàn)服務(wù)提供者:provider-server ,選擇web依賴即可
- 創(chuàng)建一個模塊,選擇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>
<!--排除這個slf4j-log4j12-->
<exclusions>
<exclusion>
<groupId>org.slf4j</groupId>
<artifactId>slf4j-log4j12</artifactId>
</exclusion>
</exclusions>
</dependency>
在provider-server項(xiàng)目下寫一個服務(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ù)注冊與實(shí)現(xiàn)
@Service //可以被掃描到,在項(xiàng)目一啟動就自動注冊到注冊中心
@Component //使用了dubbo后,注意不要用到spring的service注解
public class TicketServiceImpl implements TicketService {
@Override
public String getTicket() {
return "楓";
}
}
在consumer-server項(xiàng)目下寫一個消費(fèi)者服務(wù)

UserService.Java
import org.apache.dubbo.config.annotation.Reference;
import org.springframework.stereotype.Service;
@Service// 注入容器中,用spring的注解
public class UserService {
//要拿到provider-service提供的票,要去注冊中心
@Reference //引用,導(dǎo)入dubbo的包。正常開發(fā)引用pom坐標(biāo),但是可以定義路徑相同的接口名
TicketService ticketService;
public void buyTicket(){
String ticket = ticketService.getTicket();
System.out.println("在注冊中心拿到=》"+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注意要相同目錄
啟動兩個項(xiàng)目的啟動類,注意配置文件中的端口號配置成不一樣的,然后打開http://localhost:7001登錄,服務(wù)治理-服務(wù)



提供者和消費(fèi)者都有顯示,搭建成功,后臺一定要掛著zookeeper的服務(wù)。
總結(jié)
這就是SpingBoot + dubbo + zookeeper實(shí)現(xiàn)分布式開發(fā)的應(yīng)用,其實(shí)就是一個服務(wù)拆分的思想。只是一個小小的實(shí)現(xiàn),個人感覺還是挺容易理解的,主要是搭建zookeeper的環(huán)境要注意下細(xì)節(jié),還有項(xiàng)目中導(dǎo)包注解不要導(dǎo)錯,因?yàn)锧service有兩個選擇,一個是spring一個是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)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
- Springboot 整合 Dubbo/ZooKeeper 實(shí)現(xiàn) SOA 案例解析
- SpringBoot整合Dubbo+Zookeeper實(shí)現(xiàn)RPC調(diào)用
- springBoot+dubbo+zookeeper實(shí)現(xiàn)分布式開發(fā)應(yīng)用的項(xiàng)目實(shí)踐
- springboot+dubbo+zookeeper的簡單實(shí)例詳解
- IDEA整合Dubbo+Zookeeper+SpringBoot實(shí)現(xiàn)
- SpringBoot中dubbo+zookeeper實(shí)現(xiàn)分布式開發(fā)的應(yīng)用詳解
- SpringBoot+Dubbo+Zookeeper知識整合過程詳解
相關(guān)文章
IDEA中實(shí)現(xiàn)springboot熱部署方式
在IDEA中實(shí)現(xiàn)SpringBoot的熱部署可以通過修改設(shè)置來完成,首先在設(shè)置中搜索Compiler,并勾選Build project automatically,然后進(jìn)入Advanced Settings,勾選Allow auto-make to start even if developed application is currently running2024-09-09
Java實(shí)現(xiàn)調(diào)用MySQL存儲過程詳解
相信大家都知道存儲過程是在大型數(shù)據(jù)庫系統(tǒng)中,一組為了完成特定功能的SQL語句集。存儲過程是數(shù)據(jù)庫中的一個重要對象,任何一個設(shè)計良好的數(shù)據(jù)庫應(yīng)用程序都應(yīng)該用到存儲過程。Java調(diào)用mysql存儲過程,實(shí)現(xiàn)如下,有需要的朋友們可以參考借鑒,下面來一起看看吧。2016-11-11
Springboot如何設(shè)置過濾器及重復(fù)讀取request里的body
這篇文章主要介紹了Springboot如何設(shè)置過濾器及重復(fù)讀取request里的body,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2022-03-03
實(shí)戰(zhàn)分布式醫(yī)療掛號系統(tǒng)之整合Swagger2到通用模塊
這篇文章主要為大家介紹了實(shí)戰(zhàn)分布式醫(yī)療掛號系統(tǒng)之整合Swagger2到通用模塊,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2022-04-04
Java 反射獲取類詳細(xì)信息的常用方法總結(jié)
Java 反射獲取類詳細(xì)信息的常用方法總結(jié),需要的朋友可以參考一下2013-03-03

