從頭開始搭建一個dubbo+zookeeper平臺

来源:http://www.cnblogs.com/ASPNET2008/archive/2016/06/28/5622005.html
-Advertisement-
Play Games

本篇主要是來分享從頭開始搭建一個dubbo+zookeeper平臺的過程,其中會簡要介紹下dubbo服務的作用。 ...


 

本篇主要是來分享從頭開始搭建一個dubbo+zookeeper平臺的過程,其中會簡要介紹下dubbo服務的作用。

  •   首先,看下一般網站架構隨著業務的發展,邏輯越來越複雜,數據量越來越大,交互越來越多之後的常規方案演進歷程。

     

  •   其次,當服務越來越多之後,我們需要做哪些服務治理?

      

  •   最後,是dubbo的架構圖

      
  註冊中心的選擇


  dubbo支持多種類型的註冊中心:

  •   Multicast註冊中心
  •   Zookeeper註冊中心
  •   Redis註冊中心
  •   Simple註冊中心

  這裡我們選擇zookeeper,其實類型的優點缺點可詳細查看文檔。


  1:zookeeper的安裝,還是採用docker這一招鮮的run命令來安裝zookeeper

docker run -dit --name zookeeper  --hostname  zookeeper-host  -v /data:/data -p 2181:2181 jplock/zookeeper:latest 


  2:安裝zkui,可以參考zkui的項目地址來安裝,它提供了一個管理界面,可以針對zookeepr的節點值進行CRUD操作,同時也提供了安全認證,按照如下幾步就可以完成安裝。

  •   mvn clean install,執行前需要安裝java環境,maven環境,執行成功後會生成一個jar文件。
  •   將config.cfg複製到上一步生成的jar文件所在目錄,然後修改配置文件中的zookeeper地址。
  •   執行 jar. ( nohup java -jar zkui-2.0-SNAPSHOT-jar-with-dependencies.jar & ),註意後面的那個&,是指不退出的意思。
  •   測試,http://localhost:9090,如能看到如下頁面則代表zookeeper安裝運行正常。

         

        


  下麵是創建dubbo服務以及使用dubbo服務的過程:

   dubbo提供者,創建一個java工程,註意以下幾點:

  •  包依賴,引入如下三個主要的包就可以了,主要是spring,dubbo以及zkclient  
<dependency>
            <groupId>org.springframework</groupId>
            <artifactId>spring-context</artifactId>
            <version>${spring-framework.version}</version>
        </dependency>

        <dependency>
            <groupId>com.alibaba</groupId>
            <artifactId>dubbo</artifactId>
            <version>2.4.10</version>
            <exclusions>
                <exclusion>
                    <artifactId>spring</artifactId>
                    <groupId>org.springframework</groupId>
                </exclusion>
            </exclusions>
        </dependency>

        <dependency>
            <groupId>com.101tec</groupId>
            <artifactId>zkclient</artifactId>
            <version>0.3</version>
        </dependency>
  •  定義介面,這裡為了演示,簡單定義了一個返回產品名稱的介面。
public interface IProduct {
    String getProductName();

}
  •  介面實現 
@Service
public class ProductService implements IProduct{
    public String getProductName() {
       
        return "jim";
    }
}
  •  服務啟動函數
    • 載入配置文件
    • 調用context.start()
    • 執行一個不退出程式的操作,這裡有很多種做法。
public class App {

    private final static Logger logger = LoggerFactory.getLogger(App.class);
    public static void main(String[] args) {
        ClassPathXmlApplicationContext context = new ClassPathXmlApplicationContext(
                "classpath*:applicationContext.xml");
        context.start();

        logger.info("dubbo service begin to start");
        try {
            System.in.read();
        } catch (IOException e) {
            // TODO Auto-generated catch block
            e.printStackTrace();
        }
    }
}
  •  服務配置文件,這裡需要指出的是:
    • dubbo:service的定義配合了dubbo:annotation,ref="productService",是指定的一個id,實際的實現類通過註解掃描來完成的,並沒有在配置文件中指定實現類,後面的消費者配置文件中會有所體現。
    • dubbo:application中,可以指定logger的實現介面。
    • dubbo:protocol中,可以指定是否啟動訪問日誌,這個對有時排查線上問題非常有幫助。
 <?xml version="1.0" encoding="UTF-8"?>
<beans xmlns="http://www.springframework.org/schema/beans"
    xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns:dubbo="http://code.alibabatech.com/schema/dubbo"
    xmlns:context="http://www.springframework.org/schema/context"
    xmlns:util="http://www.springframework.org/schema/util"
    xmlns:aop="http://www.springframework.org/schema/aop"
    xsi:schemaLocation="http://www.springframework.org/schema/beans  
        http://www.springframework.org/schema/beans/spring-beans.xsd  
        http://code.alibabatech.com/schema/dubbo  
        http://code.alibabatech.com/schema/dubbo/dubbo.xsd
        http://www.springframework.org/schema/context
        http://www.springframework.org/schema/context/spring-context.xsd
        http://www.springframework.org/schema/util
        http://www.springframework.org/schema/util/spring-util.xsd"
        >
    <context:property-placeholder location="classpath*:config.properties"/>
    <dubbo:application name="jim" logger="slf4j" />

    <dubbo:registry protocol="zookeeper" address="192.168.21.128:2181" />

    <dubbo:protocol accesslog="true" name="dubbo" port="20880" />

    <dubbo:annotation package="jim" />

    <dubbo:service interface="jim.IProduct" ref="productService"/>

    <context:component-scan base-package="jim" />
    <import resource="redis-context.xml"/>


</beans>

        
   dubbo消費者

    

  •    消費者配置文件,它的配置相對提供者要簡單很多:
    • 指定消費者的名稱,這個可以隨意,不需要與提供者做任務相關聯的匹配。
    • 指定協定類型,zookeeper地址。
    • 指定引用的服務介面,註意這裡的id就與服務提供者定義的ref值相同。
<?xml version="1.0" encoding="UTF-8"?>
<beans xmlns="http://www.springframework.org/schema/beans"
    xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
    xmlns:dubbo="http://code.alibabatech.com/schema/dubbo"
    xsi:schemaLocation="http://www.springframework.org/schema/beans        http://www.springframework.org/schema/beans/spring-beans.xsd        http://code.alibabatech.com/schema/dubbo        http://code.alibabatech.com/schema/dubbo/dubbo.xsd">

    <dubbo:application name="consumer-of-jim-app"  />

    <dubbo:registry protocol="zookeeper" address="192.168.21.128:2181"/>

    <dubbo:reference interface="jim.IProduct" id="productService" />

</beans>
  •    介面註解定義以及介面調用    
@Controller
public class HomeController {

    private static final Logger logger = LoggerFactory.getLogger(HomeController.class);
    @Autowired
    private IProduct productService;
    @RequestMapping(value = "/", method = RequestMethod.GET)
    public String home(Locale locale, Model model) {
        logger.info("Welcome home! The client locale is {}.", locale);
       
        String productName=this.productService.getProductName();
        model.addAttribute("name", productName);

        return "home";
    }

}

  dubbo admin

  有一個UI工具可以針對dubbo服務進行管理,可惜我沒有在官方文檔提供的鏈接中下載成功,隨後從其它地方雖然下載完成了,但在安裝部署方面暫時遇到了一定的問題,需要手續研究解決。

    

   正常應該可以看到如下界面:

  • 管理提供者
  • 管理消費者

   

       服務治理

      

    經過上面的步驟後,就可以啟動服務端以及客戶端來驗證了。上面只是簡單的搭建了dubbo環境以及實現了一個hello world的服務介面,要想使用好dubbo還有好多提供的最佳實踐,比如服務治理:

  • 本地存根
  • 本地偽裝
  • 結果緩存
  • 多版本
  • 服務降級
  • ......

     

 本文引用:

  1. http://dubbo.io/User+Guide-zh.htm#UserGuide-zh-%E5%A4%9A%E6%B3%A8%E5%86%8C%E4%B8%AD%E5%BF%83
  2. http://blog.csdn.net/yinwenjie/article/details/50113139
  3. https://github.com/DeemOpen/zkui

您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 這幾天在看Java的一些東西,除了覺的Java和.NET的相似度實在太高之外,就是Java太原始,急需被拯救。之後又回到.NET的思維來,想著怎麼在框架里實現讀寫分離控制請求切換。之前幾個月一直都有在思考,想及對框架現有的代碼改動可能較大,所以遲遲沒怎麼下手。最近終於在廁所蹲下的一瞬間,靈光一閃,感... ...
  • 我的個人博客站在使用百度富文本編輯器UEditor修改文章時,遇到了一些問題,(不知是bug,還是我沒有配置好)。但總算找到瞭解決方法,在此記錄下來。 小站首頁文章列表顯示為(顯示去除HTML標簽後的前600個字元): 具體在 www.zynblog.com 遇到的問題: 正常來講,進入文章修改頁, ...
  • 在這一個練習中,我們要使用帶返回值的方法。如果一個方法帶返回值,那麼它的形式是這樣的。 定義一個帶返回值的C#方法 static 返回類型 方法名字 (參數類型 參數1的名字,參數類型 參數2的名字) { 你的代碼 return 返回值 } static: 先不用管是什麼意思。在沒有講它的含義之前, ...
  • 最近寫了一個SOA服務,開始覺得別人拿到我的服務地址,然後直接添加引用就可以使用了,結果"大牛"告知不行。 讓我寫一個SOAP調用服務的樣例,我有點愣了,因為沒做過這方面的,於是搞到了一個Demo,然後學習了下。 學習如下: 在.Net中有一個對象:WebRequest它可以在後臺直接請求服務的方法 ...
  • 大家先來看看表單提交的幾種方式: 1、<!--通用提交按鈕--> <input type="submit" value="提交"> 2、<!--自定義提交按鈕--> <button type="Submit">提交</button> 3、<!--圖像按鈕--> <input type="image" ...
  • 函數最初的用處 大家剛學編程的時候,一定還記得為什麼要用函數。那就是把重覆的代碼歸納到一個函數中多次利用。這點毋庸置疑,大家也用的很熟了,但是除了這個還有什麼改進空間嗎?答案肯定是有的! PS.本文不討論面向對象、不討論設計模式,只是把視線聚焦在 Class 內部的函數上。 出現什麼問題了? 大家都 ...
  • ...
  • 本篇將詳細介紹Python 類的成員、成員修飾符、類的特殊成員。還有兩個類的綜合運用實例。 環境為:python3.5.1 類的成員 類的成員包括三大類:欄位、方法和屬性 最重要的是:所有成員中,只有普通欄位的內容保存在對象中,即:根據此類創建了多少對象,在記憶體中就有多少個普通欄位。而其他的成員,則 ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...