国产精品电影_久久视频免费_欧美日韩国产激情_成年人视频免费在线播放_日本久久亚洲电影_久久都是精品_66av99_九色精品美女在线_蜜臀a∨国产成人精品_冲田杏梨av在线_欧美精品在线一区二区三区_麻豆mv在线看

如何快速開發一個 Dubbo 應用?

開發 開發工具
在分布式系統中,遠程調用是最基礎也是最重要的基石。歷史上,曾經先后出現過 CORBA、RMI、EJB、WebService 等技術和規范,在服務化以及微服務日趨流行的今天,更多的被廣泛使用的是包括 gRPC、Finagle、以及國內的 Dubbo 為代表的輕量級框架。

在分布式系統中,遠程調用是最基礎也是最重要的基石。歷史上,曾經先后出現過 CORBA、RMI、EJB、WebService 等技術和規范,在服務化以及微服務日趨流行的今天,更多的被廣泛使用的是包括 gRPC、Finagle、以及國內的 Dubbo 為代表的輕量級框架。

由于這些框架多半與服務注冊中心、配置中心等配套設施結合使用,用來作為系統分布式服務化的場景,因此這類框架又被統稱為服務框架。本文將以 Dubbo 為例,介紹如何快速開發一個 Dubbo 應用。

背景

本文將以 Dubbo 為例,介紹如何快速開發一個 Dubbo 應用。為了便于讀者理解:

  • 首先會介紹一下傳統的 RMI 的基本概念
  • 然后比較下現代的 RPC 框架與 RMI 的區別
  • 再基于 Dubbo 提供的 API 展示最基本的 Dubbo 應用如何開發
  • 最后介紹如何通過 start.dubbo.io 快速搭建 Dubbo 的腳手架工程

Java RMI 簡介

Java RMI (Remote Method Invocation) 遠程方法調用,能夠讓客戶端像使用本地調用一樣調用服務端 Java 虛擬機中的對象方法。RMI 是面向對象語言領域對 RPC (Remote Procedure Call)的完善,用戶無需依靠 IDL 的幫助來完成分布式調用,而是通過依賴接口這種更簡單自然的方式。

Java RMI 工作原理

一個典型的 RMI 調用如下圖所示:

  • 服務端向 RMI 注冊服務綁定自己的地址;
  • 客戶端通過 RMI 注冊服務獲取目標地址;
  • 客戶端調用本地的 Stub 對象上的方法,和調用本地對象上的方法一致;
  • 本地存根對象將調用信息打包,通過網絡發送到服務端;
  • 服務端的 Skeleton 對象收到網絡請求之后,將調用信息解包;
  • 然后找到真正的服務對象發起調用,并將返回結果打包通過網絡發送回客戶端。

??

??

(來源:https://www.cs.rutgers.edu/~pxk/417/notes/images/rpc-rmi_flow.png)

Java RMI 基本概念

Java RMI 是 Java 領域創建分布式應用的技術基石。后續的 EJB 技術,以及現代的分布式服務框架,其中的基本理念依舊是 Java RMI 的延續。在 RMI 調用中,有以下幾個核心的概念:

  1. 通過接口進行遠程調用
  2. 通過客戶端的 Stub 對象和服務端的 Skeleton 對象的幫助將遠程調用偽裝成本地調用
  3. 通過 RMI 注冊服務完成服務的注冊和發現

對于第一點,客戶端需要依賴接口,而服務端需要提供該接口的實現。對于第二點,在 J2SE 1.5 版本之前需要通過 rmic 預先編譯好客戶端的 Stub 對象和服務端的 Skeleton 對象。在之后的版本中,不再需要事先生成 Stub 和 Skeleton 對象。

下面通過示例代碼簡單的展示 RMI 中的服務注冊和發現:

服務端的服務注冊

??

??

說明:

  1. 初始化服務對象實例;
  2. 通過 UnicastRemoteObject.exportObject 生成可以與服務端通訊的 Stub 對象;
  3. 創建一個本地的 RMI 注冊服務,監聽端口為 1099。該注冊服務運行在服務端,也可以單獨啟動一個注冊服務的進程;
  4. 將 Stub 對象綁定到注冊服務上,這樣,客戶端可以通過 Hello 這個名字查找到該遠程對象。

客戶端的服務發現

??

??

說明:

  1. 獲取注冊服務實例,在本例中,由于沒有傳入任何參數,假定要獲取的注冊服務實例部署在本機,并監聽在 1099 端口上;
  2. 從注冊服務中查找服務名為 Hello 的遠程對象;
  3. 通過獲取的 Stub 對象發起一次 RMI 調用并獲得結果。

理解 RMI 的工作原理和基本概念,對掌握現代分布式服務框架很有幫助,建議進一步的閱讀 RMI 官方教材 [1]。

Dubbo 基本概念

現代的分布式服務框架的基本概念與 RMI 是類似的,同樣是使用 Java 的 Interface 作為服務契約,通過注冊中心來完成服務的注冊和發現,遠程通訊的細節也是通過代理類來屏蔽。具體來說,Dubbo 在工作時有以下四個角色參與:

  1. 服務提供者:啟動時在指定端口上暴露服務,并將服務地址和端口注冊到注冊中心上。
  2. 服務消費者:啟動時向注冊中心訂閱自己感興趣的服務,以便獲得服務提供方的地址列表。
  3. 注冊中心 :負責服務的注冊和發現,負責保存服務提供方上報的地址信息,并向服務消費方推送。
  4. 監控中心:負責收集服務提供方和消費方的運行狀態,比如服務調用次數、延遲等,用于監控。
  5. 運行容器:負責服務提供方的初始化、加載以及運行的生命周期管理。

??

??

部署階段

  • 服務提供者在指定端口暴露服務,并向注冊中心注冊服務信息。
  • 服務消費者向注冊中心發起服務地址列表的訂閱。

運行階段

  • 注冊中心向服務消費者推送地址列表信息。
  • 服務消費者收到地址列表后,從其中選取一個向目標服務發起調用。
  • 調用過程服務消費者和服務提供者的運行狀態上報給監控中心。

基于 API 的 Dubbo 應用

Dubbo 的應用一般都是通過 Spring 來組裝的。為了快速獲得一個可以工作的 Dubbo 應用,這里的示例摒棄了復雜的配置,而改用面向 Dubbo API 的方式來構建服務提供者和消費者,另外,注冊中心和監控中心在本示例中也不需要安裝和配置。

在生產環境,Dubbo 的服務需要一個分布式的服務注冊中心與之配合,比如,ZooKeeper。為了方便開發,Dubbo 提供了直連[2]以及組播[3]兩種方式,從而避免額外搭建注冊中心的工作。在本例中,將使用組播的方式來完成服務的注冊和發現。

定義服務契約

??

??

說明:

定義了一個簡單的服務契約 GreetingsService,其中只有一個方法 sayHi 可供調用,入參是 String 類型,返回值也是 String 類型。

提供契約的實現

??

??

說明:

  1. 服務提供者需要實現服務契約 GreetingsService 接口。
  2. 該實現簡單的返回一個歡迎信息,如果入參是 dubbo,則返回 hi, dubbo。

實現 Dubbo 服務提供方

??

??

說明:

  1. 創建一個 ServiceConfig 的實例,泛型參數信息是服務接口類型,即 GreetingsService。
  2. 生成一個 AplicatonConfig 的實例,并將其裝配進 ServiceConfig。
  3. 生成一個 RegistryConfig 實例,并將其裝配進 ServiceConfig,這里使用的是組播方式,參數是 multicast://224.5.6.7:1234。合法的組播地址范圍為:224.0.0.0 - 239.255.255.255
  4. 將服務契約 GreetingsService 裝配進 ServiceConfig。
  5. 將服務提供者提供的實現 GreetingsServiceImpl 的實例裝配進 ServiceConfig。
  6. ServiceConfig 已經具備足夠的信息,開始對外暴露服務,默認監聽端口是 20880。
  7. 為了防止服務端退出,按任意鍵或者 ctrl-c 退出。

實現 Dubbo 服務調用方

??

??

說明:

  1. 創建一個 ReferenceConfig 的實例,同樣,泛型參數信息是服務接口類型,即 GreetingService。
  2. 生成一個 AplicatonConfig 的實例,并將其裝配進 ReferenceConfig。
  3. 生成一個 RegistryConfig 實例,并將其裝配進 ReferenceConfig,注意這里的組播地址信息需要與服務提供方的相同。
  4. 將服務契約 GreetingsService 裝配進 ReferenceConfig。
  5. 從 ReferenceConfig 中獲取到 GreetingService 的代理。
  6. 通過 GreetingService 的代理發起遠程調用,傳入的參數為 dubbo。
  7. 打印返回結果 hi, dubbo。

運行

完整的示例:

??https://github.com/dubbo/dubbo-samples/tree/master/dubbo-samples-api ??

在完整的示例中,由于配置了 exec-maven-plugin,可以很方便的在命令行下通過 maven 的方式執行。當然,您也可以在 IDE 里直接執行,但是需要注意的是,由于使用了組播的方式來發現服務,運行時需要指定:

 -Djava.net.preferIPv4Stack=true。

  • 構建示例

通過以下的命令來同步示例代碼并完成構建:

  • 同步代碼:git clone https://github.com/dubbo/dubbo-samples.git
  • 構建:mvn clean package

??

??

當看到 BUILD SUCCESS 的時候表明構建完成,下面就可以開始進入運行階段了。

  • 運行服務端

通過運行以下的 maven 命令來啟動服務提供者:

??

??

當 first-dubbo-provider is running. 出現時,代表服務提供者已經啟動就緒,等待客戶端的調用。

  • 運行客戶端

通過運行以下的 maven 命令來調用服務:

??

??

可以看到, hi, dubbo 是從服務提供者返回的執行結果。

快速生成 Dubbo 應用

Dubbo 還提供了一個公共服務快速搭建基于 Spring Boot 的 Dubbo 應用。訪問 http://start.dubbo.io 并按照下圖所示來生成示例工程:

??

??

說明:

  1. 在 Group 中提供 maven groupId,默認值是 com.example。
  2. 在 Artifact 中提供 maven artifactId,默認值是 demo。
  3. 在 DubboServiceName 中提供服務名,默認值是 com.example.HelloService。
  4. 在 DubboServiceVersion 中提供服務的版本,默認值是 1.0.0。
  5. 在 Client/Server 中選取本次構建的工程是服務提供者 (Server) 還是服務消費者 (Client),默認值是 server。
  6. 使用 embeddedZookeeper 作為服務注冊發現,默認為勾選。
  7. 是否激活 qos 端口,默認為不勾選,如果勾選可以通過 22222 端口訪問。
  8. 點擊 Generate Project 即可下載生成好的工程。

在本例中展示的是服務提供者,同樣的,通過在生成界面選取 client 來生成對應的服務消費者。

  • 運行

用 IDE 打開生成好的工程,可以發現應用是一個典型的 Spring Boot 應用。程序的入口如下所示:

??

??

說明:

  1. 在 2181 端口上啟動嵌入式 ZooKeeper。
  2. 啟動 Spring Boot 上下文。

可以直接在 IDE 中運行,輸出結果如下:

2018-05-28 16:59:38.072  INFO 59943 --- [           main] a.b.d.c.e.WelcomeLogoApplicationListener :  

:: Dubbo Spring Boot (v0.1.0) : https://github.com/dubbo/dubbo-spring-boot-project
:: Dubbo (v2.0.1) : https://github.com/alibaba/dubbo
:: Google group : http://groups.google.com/group/dubbo

...

2018-05-28 16:59:39.624 INFO 59943 --- [ main] com.example.demo.DemoApplication : Started DemoApplication in 1.746 seconds (JVM running for 2.963)

說明:

輸出中打印的以 dubbo. 開頭的配置信息,定義在 main/resources/application.properties 中。

  • 通過 Telnet 管理服務

生成工程的時候如果選擇了激活 qos 的話,就可以通過 telnet 或者 nc 來管理服務、查看服務狀態。

??

??

目前 qos 支持以下幾個命令,更詳細的信息請查閱官方文檔[4]:

  • ls:列出消費者、提供者信息
  • online:上線服務
  • offline:下線服務
  • help:聯機幫助

總結

在本文中,從 RMI 開始,介紹了 Java 領域分布式調用的基本概念,也就是基于接口編程、通過代理將遠程調用偽裝成本地、通過注冊中心完成服務的注冊和發現。

然后為了簡單起見,使用簡單的組播注冊方式和直接面向 Dubbo API 編程的方式介紹了如何開發一個 Dubbo 的完整應用。深入的了解 ServiceConfig 和 ReferenceConfig 的用法,對于進一步的使用 Spring XML 配置、乃至 Spring Boot 的編程方式有這很大的幫助。

最后,簡單的介紹了如何通過 Dubbo 團隊提供的公共服務 start.dubbo.io 快速搭建基于 Spring Boot 的 Dubbo 應用,并通過 qos 來做 Dubbo 服務的簡單運維。

【本文為51CTO專欄作者“阿里巴巴官方技術”原創稿件,轉載請聯系原作者】

??戳這里,看該作者更多好文??

責任編輯:武曉燕 來源: 51CTO專欄
相關推薦

2023-03-17 18:33:12

ChatGPTLLM應用

2019-06-27 10:15:46

架構代碼項目

2021-08-10 07:27:42

Elasticsear集群開源

2011-12-27 09:49:50

AndroidiOSFlurry

2021-05-27 09:50:03

連接池FTP服務器

2022-01-06 14:59:53

Java框架magic-api

2022-11-10 09:28:40

框架開發

2024-07-02 08:28:17

開源代碼社區

2023-02-13 14:47:32

人工智能機器學習ChatGPT

2025-02-13 07:00:00

Dubbo-goJava服務端

2016-03-01 13:48:36

MVVMios快速開發

2024-07-12 08:38:05

2024-08-02 10:28:13

算法NLP模型

2024-08-21 08:21:45

CNN算法神經網絡

2024-07-30 08:08:49

2024-08-08 12:33:55

算法

2024-07-19 08:21:24

2024-06-03 08:09:39

2024-12-19 00:16:43

2024-06-06 09:44:33

點贊
收藏

51CTO技術棧公眾號

国产亚洲一区在线播放| 暖暖日本在线观看| 精品999成人| 久久久久久综合网天天| 中文在线аv在线| 国产精品一区二区免费福利视频| 欧美精品一区二区三| 高清美女视频一区| 亚洲大片在线观看| 免费三级欧美电影| 中文字幕精品—区二区四季| 国产aaa一级片| 成人av电影在线播放| www.18av.com| 成人午夜av电影| 野外做受又硬又粗又大视频√| 日韩在线卡一卡二| 日本不卡二区| 日本不卡123| 在线视频91| 国产老妇另类xxxxx| 97超碰国产精品| 99久久伊人久久99| 成人在色线视频在线观看免费大全| 久久精品免费在线观看| 欧美女同在线观看| 一区二区三区鲁丝不卡| 国产天堂av| 精品女同一区二区三区在线播放| 色视频在线播放| 日韩欧美在线观看视频| shkd中文字幕久久在线观看| 日韩欧美电影一区| 色综合天天色| 欧美黄色小视频| 国产免费播放一区二区| 大波视频国产精品久久| 亚洲在线网站| 免费cad大片在线观看| www久久久久| 手机看片1024久久| 欧美一区二区三区免费视频 | 亚洲kkk444kkk在线观看| 色综合久久久久久久| 在线观看黄色av| 日韩精品极品在线观看| 这里视频有精品| 91久久久在线| 精品一区二区三区在线观看国产| 亚洲丰满少妇videoshd| 3p视频在线观看| 国产亚洲人成a一在线v站| 91午夜精品| 99一区二区| 懂色av一区二区三区蜜臀| 日本成人黄色网址| 91麻豆精品国产自产在线| 日韩免费大片| 国产精品中文字幕在线| 日本欧美一区二区在线观看| 欧美自拍小视频| 欧洲一区二区av| 欧美视频第一| 翡翠波斯猫1977年美国| av不卡在线观看| 欧美人体大胆444www| 国产亚洲综合久久| 国产欧美日韩精品一区二区免费 | 欧美第一精品| 中文字幕av日韩精品| 最新不卡av在线| 1区2区在线观看| 欧美激情按摩在线| 亚洲美女色禁图| 精品免费国产一区二区| 欧美美女喷水视频| 欧美午夜网站| 欧美另类一区| 日韩美女精品在线| 狠狠操一区二区三区| 国产情人节一区| 成人av网站免费| www.在线视频.com| 久久久久久久久久婷婷| 日本中文字幕一区二区有限公司| 男女午夜网站| 亚洲男人天堂手机在线| 亚洲精品小说| 日本精品免费在线观看| 日韩免费一区二区| 99国产**精品****| 99免费视频观看| 亚洲精品日韩久久久| av男人的天堂网| 日韩一区二区三区精品视频| 欧美限制电影| 日韩av播放器| 成年人午夜免费视频| 久久久久一区二区三区| 99精品视频在线免费观看| av大全在线免费看| 欧美一级大片在线观看| 国产iv一区二区三区| 国产毛片在线| 91精品国产色综合久久不卡98口 | 久久久久亚洲精品国产| 日本aⅴ亚洲精品中文乱码| 亚洲高清成人影院| 欧美日产国产成人免费图片| 国产一区二区三区av电影| 在线观看免费毛片| 欧美最顶级的aⅴ艳星| 99久久综合精品| 手机在线观看av网站| 国产精品久久国产精品| 亚洲国产综合人成综合网站| 77成人影视| 91免费黄视频| 亚洲电影免费观看| 每日更新成人在线视频| 888av在线| 99久久精品无码一区二区毛片| 亚洲色图丝袜美腿| 群体交乱之放荡娇妻一区二区| av免费在线播放网站| 中文字幕亚洲综合| 国产一区二区美女| gratisvideos另类灌满| 午夜欧美一区二区三区免费观看| 538prom精品视频线放| 国产精品主播| jizz在线观看中文| 性xxxx欧美老肥妇牲乱| 青青草原国产在线| 国产精品偷伦一区二区| 亚洲国产高清aⅴ视频| 欧美日韩卡一| www.在线观看av| 亚洲人成在线观看| 久久国产精品色| av影院在线免费观看| 中文字幕中文字幕在线中心一区| 日韩一区二区在线观看| 男人天堂欧美日韩| 3d玉蒲团在线观看| 欧美一区二区福利| 亚洲白虎美女被爆操| 极品尤物av久久免费看| 欧美7777| 日韩va欧美va亚洲va久久| 国产免播放器视频| 国产成人av网| 亚洲精品菠萝久久久久久久| 九九综合九九| 一区二区三区视频国产日韩| 51精品国产人成在线观看| 在线视频国内一区二区| 国产午夜久久| 黄在线观看免费网站ktv| 亚洲精品天堂成人片av在线播放| 亚洲美女性视频| 久久久久久久久99精品| 国产精品天天看天天狠| 日本一区二区三区电影| 91传媒视频在线观看| 欧美一区二区视频在线观看2020 | 亚洲品质自拍| 一级毛片在线| 久久久久久久久久久久久久久久av | www成人在线观看| 久久亚洲道色| 色av男人的天堂免费在线 | 国产精品久久久久久久久久10秀| 免费大片在线观看www| 国产在线无码精品| 91国在线精品国内播放| 欧美丝袜丝交足nylons图片| 国产69精品久久久久毛片| 精品72久久久久中文字幕| 黄在线免费观看| 欧美日韩在线不卡视频| 成人h猎奇视频网站| 欧美岛国在线观看| 国产精品欧美久久久久无广告 | 久久国产人妖系列| 国产精品巨作av| 免费黄色在线| 日日噜噜夜夜狠狠| 农村寡妇一区二区三区| 美女黄色丝袜一区| 欧美日韩精品欧美日韩精品一综合| 99久久精品国产精品久久| 一区二区三区网站| 欧美大陆国产| 国产一区二区三区福利| 岛国大片在线播放| 91成人免费视频| 久久久免费精品| 亚洲成人久久一区| 欧美午夜激情在线|