亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

SpringBoot+Dubbo+Zookeeper知識整合過程詳解

 更新時間:2025年02月21日 11:23:30   作者:Y小夜  
本文首先介紹了分布式系統(tǒng)的基本概念和分類,包括單一應用架構、垂直應用架構、分布式服務架構和流動計算架構,通過一個完整的Spring Boot + Dubbo + Zookeeper框架搭建示例,展示了如何將這些技術整合到一個實際的項目中,感興趣的朋友一起看看吧

??分布式理論

??分布式系統(tǒng)

“分布式系統(tǒng)是若干獨立計算機的集合,這些計算機對 于用戶來說就像單個相關系統(tǒng)”

        分布式系統(tǒng)(distributed system)是建立在網(wǎng)絡之上的軟件系統(tǒng)。

        首先需要明確的是,只有當單個節(jié)點的處理能力無法滿足日益增長的計算、存儲任務的時候,且硬件的 提升(加內(nèi)存、加磁盤、使用更好的CPU)高昂到得不償失的時候,應用程序也不能進一步優(yōu)化的時 候,我們才需要考慮分布式系統(tǒng)。因為,分布式系統(tǒng)要解決的問題本身就是和單機系統(tǒng)一樣的,而由于 分布式系統(tǒng)多節(jié)點、通過網(wǎng)絡通信的拓撲結構,會引入很多單機系統(tǒng)沒有的問題,為了解決這些問題又 會引入更多的機制、協(xié)議,帶來更多的問題。

??Dubbo框架

        隨著互聯(lián)網(wǎng)的發(fā)展,網(wǎng)站應用的規(guī)模不斷擴大,常規(guī)的垂直應用架構已無法應對,分布式服務架構以及 流動計算架構勢在必行,急需一個治理系統(tǒng)確保架構有條不紊的演進。

??單一應用架構

        當網(wǎng)站流量很小時,只需一個應用,將所有功能都部署在一起,以減少部署節(jié)點和成本。此時,用于簡化增刪改查工作量的數(shù)據(jù)訪問框架(ORM)是關鍵。

        適用于小型網(wǎng)站,小型管理系統(tǒng),將所有功能都部署到一個功能里,簡單易用。 

缺點:

  • 1、性能擴展比較難
  • 2、協(xié)同開發(fā)問題
  • 3、不利于升級維護

??垂直應用架構

        當訪問量逐漸增大,單一應用增加機器帶來的加速度越來越小,將應用拆成互不相干的幾個應用,以提 升效率。此時,用于加速前端頁面開發(fā)的Web框架(MVC)是關鍵

        通過切分業(yè)務來實現(xiàn)各個模塊獨立部署,降低了維護和部署的難度,團隊各司其職更易管理,性能擴展 也更方便,更有針對性。

缺點: 公用模塊無法重復利用,開發(fā)性的浪費

??分布式服務架構

        當垂直應用越來越多,應用之間交互不可避免,將核心業(yè)務抽取出來,作為獨立的服務,逐漸形成穩(wěn)定 的服務中心,使前端應用能更快速的響應多變的市場需求。此時,用于提高業(yè)務復用及整合的分布式服務框架(RPC)是關鍵。

??流動計算架構

        當服務越來越多,容量的評估,小服務資源的浪費等問題逐漸顯現(xiàn),此時需增加一個調(diào)度中心基于訪問 壓力實時管理集群容量,提高集群利用率。此時,用于提高機器利用率的資源調(diào)度和治理中心**(SOA)[ Service Oriented Architecture]是關鍵**

??什么是RPC?

        RPC【Remote Procedure Call】是指遠程過程調(diào)用,是一種進程間通信方式,他是一種技術的思想,而 不是規(guī)范。它允許程序調(diào)用另一個地址空間(通常是共享網(wǎng)絡的另一臺機器上)的過程或函數(shù),而不用 程序員顯式編碼這個遠程調(diào)用的細節(jié)。即程序員無論是調(diào)用本地的還是遠程的函數(shù),本質(zhì)上編寫的調(diào)用 代碼基本相同。        

        也就是說兩臺服務器A,B,一個應用部署在A服務器上,想要調(diào)用B服務器上應用提供的函數(shù)/方法,由 于不在一個內(nèi)存空間,不能直接調(diào)用,需要通過網(wǎng)絡來表達調(diào)用的語義和傳達調(diào)用的數(shù)據(jù)。為什么要用 RPC呢?就是無法在一個進程內(nèi),甚至一個計算機內(nèi)通過本地調(diào)用的方式完成的需求,比如不同的系統(tǒng) 間的通訊,甚至不同的組織間的通訊,由于計算能力需要橫向擴展,需要在多臺機器組成的集群上部署 應用。RPC就是要像調(diào)用本地的函數(shù)一樣去調(diào)遠程函數(shù);

??RPC基本原理

??Dubbo

??什么是dubbo?

Apache Dubbo |?d?b??| 是一款高性能、輕量級的開源Java RPC框架,它提供了三大核心能力:面向 接口的遠程方法調(diào)用,智能容錯和負載均衡,以及服務自動注冊和發(fā)現(xiàn)

?dubbo基本概念

服務提供者**(Provider)**:暴露服務的服務提供方,服務提供者在啟動時,向注冊中心注冊自己提 供的服務。

服務消費者**(Consumer)**: 調(diào)用遠程服務的服務消費方,服務消費者在啟動時,向注冊中心訂閱自 己所需的服務,服務消費者,從提供者地址列表中,基于軟負載均衡算法,選一臺提供者進行調(diào)用,如 果調(diào)用失敗,再選另一臺調(diào)用。

注冊中心**(Registry)**:注冊中心返回服務提供者地址列表給消費者,如果有變更,注冊中心將基 于長連接推送變更數(shù)據(jù)給消費者

監(jiān)控中心**(Monitor)**:服務消費者和提供者,在內(nèi)存中累計調(diào)用次數(shù)和調(diào)用時間,定時每分鐘發(fā) 送一次統(tǒng)計數(shù)據(jù)到監(jiān)控中

?調(diào)用關系說明

l 服務容器負責啟動,加載,運行服務提供者。 l 服務提供者在啟動時,向注冊中心注冊自己提供的服務。

l 服務消費者在啟動時,向注冊中心訂閱自己所需的服務。

l 注冊中心返回服務提供者地址列表給消費者,如果有變更,注冊中心將基于長連接推送變更數(shù)據(jù)給消費 者。

l 服務消費者,從提供者地址列表中,基于軟負載均衡算法,選一臺提供者進行調(diào)用,如果調(diào)用失敗,再 選另一臺調(diào)用。

l 服務消費者和提供者,在內(nèi)存中累計調(diào)用次數(shù)和調(diào)用時間,定時每分鐘發(fā)送一次統(tǒng)計數(shù)據(jù)到監(jiān)控中心。

??window下安裝zookeeper

1、下載zookeeper ;

2、運行/bin/zkServer.cmd ,初次運行會報錯,沒有zoo.cfg配置文件;

可能遇到問題:閃退 !

解決方案:編輯zkServer.cmd文件末尾添加 pause 。這樣運行出錯就不會退出,會提示錯誤信息, 方便找到原因

3、修改zoo.cfg配置文件 將conf文件夾下面的zoo_sample.cfg復制一份改名為zoo.cfg即可

注意幾個重要位置: dataDir=./ 臨時數(shù)據(jù)存儲的目錄(可寫相對路徑) clientPort=2181 zookeeper的端口號 修改完成后再次啟動zookeeper

 4、使用zkCli.cmd測試 ls /:列出zookeeper根下保存的所有節(jié)點

[zk: 127.0.0.1:2181(CONNECTED) 4] ls /
 [zookeeper]

create –e /kuangshen 123:創(chuàng)建一個kuangshen節(jié)點,值為123

get /kuangshen:獲取/kuangshen節(jié)點的值

再來查看一下節(jié)點

??SpringBoot + Dubbo + zookeeper

??框架搭建

1. 啟動zookeeper !

2. IDEA創(chuàng)建一個空項目;

3.創(chuàng)建一個模塊,實現(xiàn)服務提供者:provider-server , 選擇web依賴即可

4.項目創(chuàng)建完畢,我們寫一個服務,比如賣票的服務;

5.創(chuàng)建一個模塊,實現(xiàn)服務消費者:consumer-server , 選擇web依賴即可

6.項目創(chuàng)建完畢,我們寫一個服務,比如用戶的服務;

??服務提供者

1、將服務提供者注冊到注冊中心,我們需要整合Dubbo和zookeeper,所以需要導包 我們從dubbo官網(wǎng)進入github,看下方的幫助文檔,找到dubbo-springboot,找到依賴包

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

2、在springboot配置文件中配置dubbo相關屬性

#當前應用名字
dubbo.application.name=provider-server
 #注冊中心地址
dubbo.registry.address=zookeeper://127.0.0.1:2181
 #掃描指定包下服務
dubbo.scan.base-packages=com.kuang.provider.service

3.在service的實現(xiàn)類中配置服務注解,發(fā)布服務!注意導包問題

import org.apache.dubbo.config.annotation.Service;
 import org.springframework.stereotype.Component;
 @Service //將服務發(fā)布出去
@Component //放在容器中
public class TicketServiceImpl implements TicketService {
    @Override
    public String getTicket() {
        return "aaqa";
    }
 }

??消費者

1、導入依賴,和之前的依賴一樣;

配置參數(shù)

#當前應用名字
dubbo.application.name=consumer-server
 #注冊中心地址
dubbo.registry.address=zookeeper://127.0.0.1:2181

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

4.完善消費者的服務類

package com.kuang.consumer.service;
 import com.kuang.provider.service.TicketService;
 import org.apache.dubbo.config.annotation.Reference;
 import org.springframework.stereotype.Service;
 @Service //注入到容器中
public class UserService {
    @Reference //遠程引用指定的服務,他會按照全類名進行匹配,看誰給注冊中心注冊了這個全
類名
    TicketService ticketService;
    public void bugTicket(){
        String ticket = ticketService.getTicket();
        System.out.println("在注冊中心買到"+ticket);
    }
 }

5. 測試類編寫;

@RunWith(SpringRunner.class)
 @SpringBootTest
 public class ConsumerServerApplicationTests {
    @Autowired
    UserService userService;
    @Test
    public void contextLoads() {
        userService.bugTicket();
    }
 }

到此這篇關于SpringBoot+Dubbo+Zookeeper知識整合的文章就介紹到這了,更多相關SpringBoot+Dubbo+Zookeeper知識整合內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!

相關文章

  • Mybatis plus邏輯刪除失敗的BUG操作

    Mybatis plus邏輯刪除失敗的BUG操作

    這篇文章主要介紹了Mybatis plus邏輯刪除失敗的BUG操作,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2020-11-11
  • 一文讀懂JavaWeb前后端數(shù)據(jù)交互

    一文讀懂JavaWeb前后端數(shù)據(jù)交互

    本文主要介紹了一文讀懂JavaWeb前后端數(shù)據(jù)交互,包括HTTP請求與響應、JSON數(shù)據(jù)格式以及常用的數(shù)據(jù)傳輸技術,具有一定的參考價值,感興趣的可以了解一下
    2024-01-01
  • spring?retry方法調(diào)用失敗重試機制示例解析

    spring?retry方法調(diào)用失敗重試機制示例解析

    這篇文章主要為大家介紹了spring?retry方法調(diào)用失敗重試機制的示例解析,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步
    2022-03-03
  • Netty分布式ByteBuf使用subPage級別內(nèi)存分配剖析

    Netty分布式ByteBuf使用subPage級別內(nèi)存分配剖析

    這篇文章主要為大家介紹了Netty分布式ByteBuf使用subPage級別內(nèi)存分配剖析,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2022-03-03
  • IntelliJ IDEA 2019.3激活破解的詳細方法(親測有效,可激活至 2089 年)

    IntelliJ IDEA 2019.3激活破解的詳細方法(親測有效,可激活至 2089&

    本教程適用于 JetBrains 全系列產(chǎn)品,包括 Pycharm、IDEA、WebStorm、Phpstorm、Datagrip、RubyMine、CLion、AppCode 等,本教程無需修改 hosts 文件,對IntelliJ IDEA 2019.3激活破解的詳細方法的相關知識感興趣的朋友一起看看吧
    2020-09-09
  • Java深入數(shù)據(jù)結構理解掌握抽象類與接口

    Java深入數(shù)據(jù)結構理解掌握抽象類與接口

    在類中沒有包含足夠的信息來描繪一個具體的對象,這樣的類稱為抽象類,接口是Java中最重要的概念之一,它可以被理解為一種特殊的類,不同的是接口的成員沒有執(zhí)行體,是由全局常量和公共的抽象方法所組成,本文給大家介紹Java抽象類和接口,感興趣的朋友一起看看吧
    2022-05-05
  • Java使用Sharding-JDBC分庫分表進行操作

    Java使用Sharding-JDBC分庫分表進行操作

    Sharding-JDBC 是無侵入式的 MySQL 分庫分表操作工具,本文主要介紹了Java使用Sharding-JDBC分庫分表進行操作,感興趣的可以了解一下
    2021-08-08
  • 使用maven整合Spring+SpringMVC+Mybatis框架詳細步驟(圖文)

    使用maven整合Spring+SpringMVC+Mybatis框架詳細步驟(圖文)

    這篇文章主要介紹了使用maven整合Spring+SpringMVC+Mybatis框架詳細步驟(圖文),小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2019-05-05
  • Spring boot實現(xiàn)上傳文件到本地服務器

    Spring boot實現(xiàn)上傳文件到本地服務器

    這篇文章主要為大家詳細介紹了Spring boot實現(xiàn)上傳文件到本地服務器,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2022-08-08
  • Java中的equsals和==

    Java中的equsals和==

    這篇文章主要介紹了Java中的equsals和==的相關內(nèi)容,感興趣的朋朋友可以參考下文
    2021-08-08

最新評論