中文字幕av专区_日韩电影在线播放_精品国产精品久久一区免费式_av在线免费观看网站

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

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

發布時間:2020-06-29 00:38:50 來源:網絡 閱讀:371 作者:jjjssswww 欄目:網絡安全
  • 首先,看下一般網站架構隨著業務的發展,邏輯越來越復雜,數據量越來越大,交互越來越多之后的常規方案演進歷程。

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

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

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

  •   最后,是dubbo的架構圖

       從頭開始搭建一個dubbo+zookeeper平臺
  注冊中心的選擇

從頭開始搭建一個dubbo+zookeeper平臺
  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+zookeeper平臺

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


  下面是創建dubbo服務以及使用dubbo服務的過程:
從頭開始搭建一個dubbo+zookeeper平臺
   dubbo提供者,創建一個java工程,注意以下幾點:

  •  包依賴,引入如下三個主要的包就可以了,主要是spring,dubbo以及zkclient  

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

<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>

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

  •  定義接口,這里為了演示,簡單定義了一個返回產品名稱的接口。

public interface IProduct {
    String getProductName();

}
  •  接口實現 

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

@Servicepublic class ProductService implements IProduct{    public String getProductName() {       
        return "jim";
    }
}

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

  •  服務啟動函數

    • 加載配置文件

    • 調用context.start()

    • 執行一個不退出程序的操作,這里有很多種做法。

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

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+zookeeper平臺

  •  服務配置文件,這里需要指出的是:

    • dubbo:service的定義配合了dubbo:annotation,ref="productService",是指定的一個id,實際的實現類通過注解掃描來完成的,并沒有在配置文件中指定實現類,后面的消費者配置文件中會有所體現。

    • dubbo:application中,可以指定logger的實現接口。

    • dubbo:protocol中,可以指定是否啟動訪問日志,這個對有時排查線上問題非常有幫助。

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

 <?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平臺

         
   dubbo消費者

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

  •    消費者配置文件,它的配置相對提供者要簡單很多:

    • 指定消費者的名稱,這個可以隨意,不需要與提供者做任務相關聯的匹配。

    • 指定協定類型,zookeeper地址。

    • 指定引用的服務接口,注意這里的id就與服務提供者定義的ref值相同。

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

<?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>

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

  •    接口注解定義以及接口調用    

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

@Controllerpublic 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+zookeeper平臺

  dubbo admin

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

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

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

  • 管理提供者

  • 管理消費者

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

       服務治理

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

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

  • 本地存根

  • 本地偽裝

  • 結果緩存

  • 多版本

  • 服務降級

  • ......


向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

青铜峡市| 双峰县| 东乌珠穆沁旗| 和平区| 乌拉特中旗| 启东市| 来安县| 南涧| 南华县| 杨浦区| 江城| 江陵县| 开远市| 平阳县| 南漳县| 安多县| 天津市| 鄂伦春自治旗| 叶城县| 灵宝市| 绥江县| 拜城县| 时尚| 新沂市| 萍乡市| 舞钢市| 揭阳市| 宜丰县| 盱眙县| 娄烦县| 读书| 新源县| 来宾市| 临澧县| 祁门县| 沧源| 岳阳市| 巴林右旗| 仁布县| 临邑县| 乌什县|