【Dubbo+Zookeeper】——SpringBoot+Dubbo+Zookeeper知識整合

🎼個人主頁:【Y小夜】

😎作者簡介:一位雙非學校的大二學生,編程愛好者,

專注于基礎和實戰分享,歡迎私信咨詢!

🎆入門專欄:🎇【MySQL,Java基礎,Rust】

🎈熱門專欄:🎊【Python,Javaweb,Vue框架】

感謝您的點贊、關注、評論、收藏、是對我最大的認可和支持!??

目錄

🎯分布式理論

🎃分布式系統

🎃Dubbo框架

🎃單一應用架構

🎃垂直應用架構

🎃分布式服務架構

🎃流動計算架構

🎯什么是RPC?

🎃RPC基本原理

🎯Dubbo

🎃什么是dubbo?

?dubbo基本概念

?調用關系說明

🎃window下安裝zookeeper

🎯SpringBoot + Dubbo + zookeeper

🎃框架搭建

🎃服務提供者

🎃消費者

5. 測試類編寫;


🎯分布式理論

🎃分布式系統

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

????????分布式系統(distributed system)是建立在網絡之上的軟件系統。

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

🎃Dubbo框架

????????隨著互聯網的發展,網站應用的規模不斷擴大,常規的垂直應用架構已無法應對,分布式服務架構以及 流動計算架構勢在必行,急需一個治理系統確保架構有條不紊的演進。

🎃單一應用架構

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

????????適用于小型網站,小型管理系統,將所有功能都部署到一個功能里,簡單易用。?

缺點:

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

🎃垂直應用架構

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

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

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

🎃分布式服務架構

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

🎃流動計算架構

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

🎯什么是RPC?

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

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

🎃RPC基本原理

🎯Dubbo

🎃什么是dubbo?

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

?dubbo基本概念

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

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

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

監控中心**(Monitor)**:服務消費者和提供者,在內存中累計調用次數和調用時間,定時每分鐘發 送一次統計數據到監控中

?調用關系說明

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

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

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

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

l 服務消費者和提供者,在內存中累計調用次數和調用時間,定時每分鐘發送一次統計數據到監控中心。

🎃window下安裝zookeeper

1、下載zookeeper ;

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

可能遇到問題:閃退 !

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

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

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

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

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

create –e /kuangshen 123:創建一個kuangshen節點,值為123

get /kuangshen:獲取/kuangshen節點的值

再來查看一下節點

🎯SpringBoot + Dubbo + zookeeper

🎃框架搭建

1. 啟動zookeeper !

2. IDEA創建一個空項目;

3.創建一個模塊,實現服務提供者:provider-server , 選擇web依賴即可

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

5.創建一個模塊,實現服務消費者:consumer-server , 選擇web依賴即可

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

🎃服務提供者

1、將服務提供者注冊到注冊中心,我們需要整合Dubbo和zookeeper,所以需要導包 我們從dubbo官網進入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的實現類中配置服務注解,發布服務!注意導包問題

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

🎃消費者

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

配置參數

#當前應用名字
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)@SpringBootTestpublic class ConsumerServerApplicationTests {@AutowiredUserService userService;@Testpublic void contextLoads() {userService.bugTicket();}}

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/bicheng/71498.shtml
繁體地址,請注明出處:http://hk.pswp.cn/bicheng/71498.shtml
英文地址,請注明出處:http://en.pswp.cn/bicheng/71498.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

【OS安裝與使用】part5-ubuntu22.04基于conda安裝pytorch+tensorflow

文章目錄 一、待解決問題1.1 問題描述1.2 解決方法 二、方法詳述2.1 必要說明2.2 應用步驟2.2.1 明確pytorch安裝依賴2.2.2 conda創建虛擬環境2.2.3 安裝pytorch2.2.4 驗證pytorch安裝2.2.5 安裝Tensorflow2.2.6 驗證Tensorflow安裝 三、疑問四、總結 一、待解決問題 1.1 問題…

馬拉車算法

Manacher算法 ,用于處理最長回文字符串的問題&#xff0c;可以在O&#xff08;n&#xff09;的情況下&#xff0c;求出一個字符串的最長回文字符串 回文串的基礎解法&#xff1a; 以每個點為中心對稱點&#xff0c;看左右兩邊的點是否相同。這種算法的時間復雜度為O&#xff0…

氣象學中的CDO插值(多方法+多分辨率)

文章目錄 說明CDO代碼 說明 需要新建.sh腳本文件&#xff0c;將下面的CDO代碼復制到.sh腳本中&#xff0c;然后運行插值程序。 CDO代碼 #!/bin/bash # # 用戶配置區&#xff08;按實際需求修改&#xff09; # input_directory"2m_temperature" # 自定義路徑 gr…

計算機網絡:應用層 —— 動態主機配置協議 DHCP

文章目錄 什么是 DHCP&#xff1f;DHCP 的產生背景DHCP 的工作過程工作流程地址分配機制 DHCP 中繼代理總結 什么是 DHCP&#xff1f; 動態主機配置協議&#xff08;DHCP&#xff0c;Dynamic Host Configuration Protocol&#xff09;是一種網絡管理協議&#xff0c;用于自動分…

【OS安裝與使用】part3-ubuntu安裝Nvidia顯卡驅動+CUDA 12.4

文章目錄 一、待解決問題1.1 問題描述1.2 解決方法 二、方法詳述2.1 必要說明2.2 應用步驟2.2.1 更改鏡像源2.2.2 安裝NVIDIA顯卡驅動&#xff1a;nvidia-550&#xff08;1&#xff09;查詢顯卡ID&#xff08;2&#xff09;PCI ID Repository查詢顯卡型號&#xff08;3&#xf…

數據導入AI訓練步驟——人工智能訓練

一、人工操作轉化 數據導入過程 整理excel表格&#xff0c;通過數據庫管理工具導入數據&#xff0c;補充數據格式&#xff0c;調整sql語句 復制數據到目標數據 二、整理表格 三、導入數據 通過數據庫導入數據 四、合并 五、驗證更新數據 六、 更新數據 update temp_cus_hmz…

我國首條大型無人機城際低空物流航線成功首航

首航震撼開場&#xff1a;羊肉 “飛” 越 540 公里 在夜色的籠罩下&#xff0c;榆陽馬合通用機場的跑道上&#xff0c;一架大型固定翼無人機蓄勢待發&#xff0c;機身被燈光照亮&#xff0c;宛如一只即將展翅翱翔的鋼鐵巨鳥。它的貨艙里&#xff0c;滿滿裝載著新鮮的榆林羊肉&a…

《跟李沐學 AI》AlexNet論文逐段精讀學習心得 | PyTorch 深度學習實戰

前一篇文章&#xff0c;使用 AlexNet 實現圖片分類 | PyTorch 深度學習實戰 本系列文章 GitHub Repo: https://github.com/hailiang-wang/pytorch-get-started 本篇文章內容來自于學習 9年后重讀深度學習奠基作之一&#xff1a;AlexNet【下】【論文精讀】】的心得。 《跟李沐…

微軟Win11新動態:官方“換機助手”曝光,PC數據遷移或迎全新體驗

目錄 微軟入局數據遷移領域,第三方工具或面臨挑戰 無縫遷移體驗:近距離傳輸與OTP驗證 模擬圖僅為概念設計,最終功能或存變數 發布時間未定,Insider用戶或率先體驗 總結 微軟在近期發布了Windows 11 Insider Beta頻道的最新版本Build 22635.4945。盡管此次更新并未引入重…

Could not initialize class io.netty.util.internal.Platfor...

異常信息&#xff1a; Exception in thread "main" java.lang.NoClassDefFoundError: Could not initialize class io.netty.util.internal.PlatformDependent0 Caused by: java.lang.ExceptionInInitializerError: Exception java.lang.reflect.InaccessibleObjec…

java練習(34)

ps:題目來自力扣 尋找兩個正序數組的中位數 給定兩個大小分別為 m 和 n 的正序&#xff08;從小到大&#xff09;數組 nums1 和 nums2。請你找出并返回這兩個正序數組的 中位數 。 算法的時間復雜度應該為 O(log (mn)) 。 class Solution {public double findMedianSortedA…

用Java創建一個驗證碼的工具類

在Java中創建一個驗證碼工具類&#xff0c;可以通過以下代碼實現。該工具類支持生成包含字母和數字的隨機驗證碼圖片&#xff0c;并添加干擾線和噪點以提高安全性。以下是詳細實現&#xff1a; 完整代碼實現 import javax.imageio.ImageIO; import java.awt.*; import java.aw…

提升信息檢索準確性和效率的搜索技巧

一、基礎技巧 精準關鍵詞 避免長句子&#xff0c;提取核心關鍵詞&#xff08;如用“光合作用 步驟”代替“請告訴我光合作用的具體過程”&#xff09;。 同義詞替換&#xff1a;嘗試不同表達&#xff08;如“AI 發展史” vs “人工智能 歷史”&#xff09;。 排除干擾詞 使用…

設計模式 之 工廠模式(簡單工廠模式、工廠方法模式、抽象工廠模式)(C++)

文章目錄 C 工廠模式引言一、簡單工廠模式概念實現步驟示例代碼優缺點 二、工廠方法模式概念實現步驟示例代碼優缺點 三、抽象工廠模式概念實現步驟示例代碼優缺點 C 工廠模式 引言 在 C 編程中&#xff0c;對象的創建是一個常見且基礎的操作。然而&#xff0c;當項目規模逐漸…

DAY12 Tensorflow 六步法搭建神經網絡

六步法&#xff1a; 一.import 導入各種庫&#xff0c;比如&#xff1a; import tensorflow as tf from tensorflow.keras.layers import Dense, Flatten from tensorflow.keras import Model import numpy as np import pandas as pd # 可能還會根據需求導入其他庫&…

Zookeeper分布式鎖實現

zookeeper最初設計的初衷就是為了保證分布式系統的一致性。本文將講解如何利用zookeeper的臨時順序結點&#xff0c;實現分布式鎖。 目錄 1. 理論分析 1.1 結點類型 1.2 監聽器 1.3 實現原理 2. 手寫實現簡易zookeeper分布式鎖 1.1 依賴 1.2 常量定義 1.3 實現zookeeper分布式…

Git是什么

簡單介紹&#xff1a; Git是一個分布式版本控制系統&#xff0c;用于跟蹤文件的更改&#xff0c;特別是在多人協作開發的環境中。 Key: 分布式 版本控制 系統 最常用于軟件開發&#xff0c;但也可以用于管理任何類型的文件和文件夾。 Git幫助團隊跟蹤和管理文件的歷史版本&a…

Pycharm 2024在解釋器提供的python控制臺中運行py文件

2024版的界面發生了變化, run with python console搬到了這里:

【分布式理論12】事務協調者高可用:分布式選舉算法

文章目錄 一、分布式系統中事務協調的問題二、分布式選舉算法1. Bully算法2. Raft算法3. ZAB算法 三、小結與比較 一、分布式系統中事務協調的問題 在分布式系統中&#xff0c;常常有多個節點&#xff08;應用&#xff09;共同處理不同的事務和資源。前文 【分布式理論9】分布式…

免費deepseek的API獲取教程及將API接入word或WPS中

免費deepseek的API獲取教程: 1 https://cloud.siliconflow.cn/中注冊時填寫邀請碼&#xff1a;GAejkK6X即可獲取2000 萬 Tokens; 2 按照圖中步驟進行操作 將API接入word或WPS中 1 打開一個word&#xff0c;文件-選項-自定義功能區-勾選開發工具-左側的信任中心-信任中心設置…