跟我學習dubbo-使用Maven構建Dubbo服務的可執行jar包(4)

来源:http://www.cnblogs.com/jeesml/archive/2016/01/06/5104270.html
-Advertisement-
Play Games

Dubbo服務的運行方式 服務容器是一個standalone的啟動程式,因為後臺服務不需要Tomcat或JBoss等Web容器的功能,如果硬要用Web容器去載入服務提供方,增加複雜性,也浪費資源。 服務容器只是一個簡單的Main方法,並載入一個簡單的Spring容器,用於暴露服務。 服務容器的載入內...


Dubbo服務的運行方式:

1、使用Servlet容器運行(Tomcat、Jetty等)----不可取

缺點:增加複雜性(埠、管理) 浪費資源(記憶體)

官方:服務容器是一個standalone的啟動程式,因為後臺服務不需要Tomcat或JBoss等Web容器的功能,如果硬要用Web容器去載入服務提供方,增加複雜性,也浪費資源。

2、自建Main方法類來運行(Spring容器) ----不建議(本地調試可用)

缺點: Dobbo本身提供的高級特性沒用上 自已編寫啟動類可能會有缺陷 

官方:服務容器只是一個簡單的Main方法,並載入一個簡單的Spring容器,用於暴露服務。

3、使用Dubbo框架提供的Main方法類來運行(Spring容器)----建議使用

優點:框架本身提供(com.alibaba.dubbo.container.Main)

可實現優雅停機(ShutdownHook) 

官方:服務容器的載入內容可以擴展,內置了spring, jetty, log4j等載入,可通過Container擴展點進行擴展

Dubbo是通過JDK的ShutdownHook來完成優雅停機的,所以如果用戶使用"kill -9 PID"等強制關閉指令,是不會執行優雅停機的,只有通過"kill PID"時,才會執行。

原理:

 

  • 服務提供方

    • 停止時,先標記為不接收新請求,新請求過來時直接報錯,讓客戶端重試其它機器。

    • 然後,檢測線程池中的線程是否正在運行,如果有,等待所有線程執行完成,除非超時,則強制關閉。

  • 服務消費方

    • 停止時,不再發起新的調用請求,所有新的調用在客戶端即報錯。

    • 然後,檢測有沒有請求的響應還沒有返回,等待響應返回,除非超時,則強制關閉。

設置優雅停機超時時間,預設超時時間是10秒:(超時則強制關閉)

< dubbo:application ...>      < dubbo:parameter key = "shutdown.timeout" value = "60000" /> <!-- 單位毫秒 -->

</dubbo:application>

如果ShutdownHook不能生效,可以自行調用:

ProtocolConfig.destroyAll();

打包

傳統的打jar包,大部分人員還在使用eclipse自帶的導出一個jar包,對於傳統的單實例項目是沒有問題的,但對於比較複雜的maven分模塊項目,這種做法就不行了。

下麵介紹maven打包方式:

<resources>
            <resource>
                <targetPath>${project.build.directory}/classes</targetPath>
                <directory>src/main/resources</directory>
                <filtering>true</filtering>
                <includes>
                    <include>**/*.xml</include>
                    <include>**/*.properties</include>
                </includes>
            </resource>
            <!-- 結合com.alibaba.dubbo.container.Main,需要重點掌握-->
            <resource>
                <targetPath>${project.build.directory}/classes/META-INF/spring</targetPath>
                <directory>src/main/resources/spring</directory>
                <filtering>true</filtering>
                <includes>
                    <include>spring-context.xml</include>
                </includes>
            </resource>
 </resources>

官網聲明: Spring Container

  • 自動載入META-INF/spring目錄下的所有Spring配置。

  • 配置:(配在java命令-D參數或者dubbo.properties中)

  • dubbo.spring.config=classpath*:META-INF/spring/*.xml ----配置spring配置載入位置

    所以聲明必須使用maven方式配置才能將spring配置文件打包到META-INF/spring目錄下

引入相關插件:

<plugins>
            <!-- 打包jar文件時,配置manifest文件,加入lib包的jar依賴 -->
            <plugin>
                <groupId>org.apache.maven.plugins</groupId>
                <artifactId>maven-jar-plugin</artifactId>
                <configuration>
                    <classesDirectory>target/classes/</classesDirectory>
                    <archive>
                        <manifest>
                            <mainClass>com.alibaba.dubbo.container.Main</mainClass>
                            <addClasspath>true</addClasspath>
                            <classpathPrefix>lib/</classpathPrefix>
                        </manifest>
                        <manifestEntries>
                            <Class-Path>.</Class-Path>
                        </manifestEntries>
                    </archive>
                </configuration>
            </plugin>

....省略一些配置

</plugins>

重點關註標紅色的配置,容器啟動使用的是容器Main方法啟動,故需要配置

配置好以後,我們就可以使用maven的命令打需要的服務jar包。利用java -jar命令去執行你的jar包,就可以將服務註冊到你的zookeeper註冊中心了。

 

請各位持續關註《跟我學習dubbo-在Linux操作系統上手工部署Dubbo服務(5)》

由於第一次寫關於dubbo的博客,還希望大家加入dubbo學習交流群(446855438),一起學習。


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

-Advertisement-
Play Games
更多相關文章
  • 點擊按鈕之後將其設置為不可用狀態:不少效果中,希望按鈕只能夠被點擊一次,再點擊之後就會被設置為不可用,代碼非常的簡單。代碼如下:點擊按鈕之後將其設置為不可用-螞蟻部落以上代碼在點擊按鈕之後,可以將其設置為不可用狀態,代碼非常簡單,這裡就不介紹了。相關參閱:1.onclick事件可以參閱javascr...
  • CSS實現的背景圖片替代顏色代碼:有時候在背景圖片由於網路或者其他原因沒有顯示的時候,可以使用指定的背景顏色替代,下麵就是一段能夠實現此功能的代碼:background: url("a.jpg") no-repeat #ccc;原文地址是:http://www.softwhy.com/forum.p...
  • jQuery列印json格式對象實例代碼:所謂的json格式對象其實就是對象直接量,很多教程多說這是json對象,其實這是不正確。下麵是一段列印json格式對象的實例代碼,希望能夠對初學者有所幫助。代碼如下: 螞蟻部落 原文地址是:http://www.softwhy.com/f...
  • 通過上下左右鍵控制div的運行方向:使用小鍵盤附近的上下左右鍵控制方向可能在很多應用程式中都有用到,有時候甚至特別的方便,比如有些游戲可以使用者四個鍵控制方位,下麵就簡單介紹一下javascript如何實現使用這四個鍵控制div的運動方向。方向鍵控制div的移動-螞蟻部落紅色方塊為鍵盤操作區域,您可...
  • 實現table細線表格效果代碼:細線表格相比較表格的預設表格來說要美觀很多,當然更受歡迎,下麵就通過代碼實例介紹一下如何實現此效果。代碼如下: 螞蟻部落 螞蟻部落一 螞蟻部落二 javascript教程 jQuery教程 ...
  • jQuery實現的垂直可伸縮導航菜單:垂直可伸縮導航菜單在網頁中非常的常用,首先可以進行分類,第二個也可以節省網頁的空間,本章節就通過實例代碼分享一個這樣的效果,希望能夠給需要者帶來一定的幫助。代碼實例如下:螞蟻部落 螞蟻部落一 前端教程 ...
  • javascript實現的iframe數據共用介面:在iframe與父視窗或者與子視窗傳遞數據是一個麻煩的事情,如果我們能夠寫一個一勞永逸的介面那就再方便不過了,下麵就來簡答介紹一下如何實現此功能。原理就是將數據緩存早window.top這個視窗,這樣無論子視窗父視窗的層次如何變化,數據總是存在不會...
  • 查看效果:http://hovertree.com/texiao/css/14/本效果用css3的animation實現動畫定義和用法animation 屬性是一個簡寫屬性,用於設置六個動畫屬性:animation-nameanimation-durationanimation-timing-fun...
一周排行
    -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.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...