dubbo學習筆記(一)
學習之前先說明一下其他概念方便了解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學習筆記(一)