1. 程式人生 > >dubbo學習筆記(一)

dubbo學習筆記(一)

獲取 linu pan 概念 規範 href 面向 打包 mon

學習之前先說明一下其他概念方便了解dubbo

RPC概念:

  是指遠程過程調用,是一種進程間的通信方式。這是一種思想,而不是規範。

  (允許程序調用遠程的過程或函數,並且讓程序員無論是調用本地還是遠程的函數,本質上調用代碼基本都相同)


Dubbo簡介:

概念:

  一款高性能,輕量級的開源RPC概念

三大核心能力:

  1、)面向接口的遠程方法調用

  2、)智能容錯和負載均衡

  3、)服務的自主註冊和發現

官網

http://dubbo.apache.org/


dubbo基本概念

技術分享圖片

  

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

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

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

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

  • 調用關系說明

服務容器負責啟動,加載,運行服務提供者。

服務提供者在啟動時,向註冊中心註冊自己提供的服務。

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

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

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

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


dubbo環境搭建:

說明一下:

(1)JDK必有哈

(2)Zookeeper分布式協調服務(這個不一定啊,官網提供了四種註冊中心,我選擇了zookeeper而已哈(主要是其他的註冊中心沒用過。。嘎嘎!!!))

  Zookeeper安裝步驟:

windows-安裝zookeeper

1、下載zookeeper

網址 https://archive.apache.org/dist/zookeeper/zookeeper-3.4.13/

2、解壓zookeeper

解壓運行zkServer.cmd 初次運行會報錯,沒有zoo.cfg配置文件

3修改zoo.cfg配置文件

conf下的zoo_sample.cfg復制一份改名為zoo.cfg即可。

註意幾個重要位置:

dataDir=./ 臨時數據存儲的目錄(可寫相對路徑)

clientPort=2181 zookeeper的端口號

修改完成後再次啟動zookeeper

4使用zkCli.cmd測試

ls /列出zookeeper根下保存的所有節點

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

get /atguigu獲取/atguigu節點的值

windows-安裝dubbo-admin管理控制臺

dubbo本身並不是一個服務軟件。它其實就是一個jar包能夠幫你的java程序連接到zookeeper,並利用zookeeper消費、提供服務。所以你不用在Linux上啟動什麽dubbo服務。

但是為了讓用戶更好的管理監控眾多的dubbo服務,官方提供了一個可視化的監控程序,不過這個監控即使不裝也不影響使用。

1、下載dubbo-admin

https://github.com/apache/incubator-dubbo-ops

2、進入目錄,修改dubbo-admin配置

修改 src\main\resources\application.properties 指定zookeeper地址

dubbo.registry.address=zookeeper://127.0.0.1:2181

3、打包dubbo-admin

mvn clean package -Dmaven.test.skip=true

4、運行dubbo-admin

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

註意:【有可能控制臺看著啟動了,但是網頁打不開,需要在控制臺按下ctrl+c即可】

默認使用root/root 登陸

dubbo學習筆記(一)