微服務~Eureka實現的服務註冊與發現及服務之間的調用

来源:http://www.cnblogs.com/lori/archive/2017/09/26/7598058.html
-Advertisement-
Play Games

微服務里一個重要的概念就是服務註冊與發現技術,當你有一個新的服務運行後,我們的服務中心可以感知你,然後把加添加到服務列表裡,然後當你死掉後,會從服務中心把你移除,而你作為一個服務,對其它服務公開的只是服務名稱,而不是最終的服務地址URL,這對於雲平臺,容器化架構來說是非常重要的! 一 安裝單獨的Eu ...


微服務里一個重要的概念就是服務註冊與發現技術,當你有一個新的服務運行後,我們的服務中心可以感知你,然後把加添加到服務列表裡,然後當你死掉後,會從服務中心把你移除,而你作為一個服務,對其它服務公開的只是服務名稱,而不是最終的服務地址URL,這對於雲平臺,容器化架構來說是非常重要的!

  1. 安裝單獨的Eureka服務(server)
  2. 服務註冊-aspnetcore建立Eureka客戶端(client)
  3. 服務發現-實現服務與服務的調用

一 安裝單獨的Eureka服務

  1. 安裝tomcat,到apache官網http://tomcat.apache.org下載tomcat
  2. 下載Eureka,可以到http://mvnrepository.com/artifact/com.netflix.eureka/eureka-server選擇一下版本下載
  3. 配置埠,預設是8080,tomcat\webapps\eureka\WEB-INF\classes\eureka-client.properties
  4. 重啟tomcat服務即可

二 aspnetcore建立Eureka客戶端(client)

  1. nuget添加包包Pivotal.Discovery.Client
  2. 在startup.cs里添加客戶端的自動發現代碼(相對於eureka是客戶端,事實上它是微服務里的一種服務)
  3. program里添加對某個埠的監聽
  4. 將EurekaServer的地址添加到appsettings里
  5. 啟動項目,然後去服務中心查看自己的新服務

在startup.cs里

 

       public void ConfigureServices(IServiceCollection services)
        {
            services.AddDiscoveryClient(Configuration);
            services.AddMvc();
        }

        // This method gets called by the runtime. Use this method to configure the HTTP request pipeline.
        public void Configure(IApplicationBuilder app, IHostingEnvironment env)
        {

            if (env.IsDevelopment())
            {
                app.UseDeveloperExceptionPage();
            }

            app.UseMvc();
            app.UseDiscoveryClient();
        }

 

program里添加對某個埠的監聽

 public static IWebHost BuildWebHost(string[] args) =>
            WebHost.CreateDefaultBuilder(args)
                .UseStartup<Startup>()
                .UseUrls("http://*:8010")
                .Build();

將EurekaServer的地址添加到appsettings里,其中8010是自己監聽的埠,Order是自己的名稱

 "spring": {
    "application": {
      "name": "Order"
    }
  },
  "eureka": {
    "client": {
      "serviceUrl": "http://localhost:8080/eureka/V2/",
      "shouldFetchRegistry": false,
      "shouldRegisterWithEureka": true
    },
    "instance": {
      "port": 8010
    }

然後啟動項目,在你的服務中心就可以看到新加的服務了(http://localhost:8080/eureka/),這就是服務的註冊!

三 服務發現-實現服務與服務的調用

我們在某個微服務的項目里,可以調用其它的服務,這類似於一種請求鏈的過程,以後我們講spring cloud里會說其它相關的技術

       [HttpGet]
        public IEnumerable<string> Get()
        {
            DiscoveryClient _discoveryClient = new DiscoveryClient(new EurekaClientConfig
            {
                EurekaServerServiceUrls = "http://localhost:8080/eureka/V2/",
                ProxyHost = "http://localhost:8080/eureka/V2/",
                ProxyPort = 8080,

            });
            //得到服務中心所有服務和它的Url地址
            foreach (var item in _discoveryClient.Applications.GetRegisteredApplications())
                yield return $"{item.Name}={item.Instances.FirstOrDefault().HomePageUrl}";
        }

頁面顯示的結果中我們看到了所有的服務,它的名稱和它的URL,這種URL在容器化部署里是動態的,所以我們不能像原來那樣,把它寫死了,這也就是服務發現產生的原因!

好了,今天對於服務註冊與服務發現就說到這裡,都是比較實幹的東西!

感謝各位閱讀!

 


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

-Advertisement-
Play Games
更多相關文章
  • 模擬購物車程式,判斷用戶薪資是否是0 如果是0就需要輸入薪資,並記錄到文件內。 可以預先存個字典格式的字元串,然後去讀取文件的時候讀到的是字字元串然後再去用eval去轉換成字典。 當我們覆蓋寫到文件的時候就會發現首行會有空格,當我們再去讀取eval的時候就會報錯,那怎麼樣可以解決這個問題呢! ...
  • 參考教程:http://www.tensorfly.cn/tfdoc/tutorials/mnist_beginners.html 數據下載地址:http://wiki.jikexueyuan.com/project/tensorflow-zh/tutorials/mnist_download.ht ...
  • 今天我們來學習集合的第一大體系 List。 List 是一個介面,定義了一組元素是有序的、可重覆的集合。 List 繼承自 Collection,較之 Collection,List 還添加了以下操作方法 位置相關:List 的元素是有序的,因此有get(index)、set(index,objec ...
  • 1.什麼是servlet轉發? servlet將用戶的請求通過一組servlet來處理,每個servlet都有自己特定的職責,當該servlet完成自己的工作後將請求轉發到下一個servlet來處理,這種通過不同servelet相互轉發請求來完成對某個請求的處理過程就叫做servlet轉發。 2.什 ...
  • 本節內容 1.交互操作 2.變數 3.字元串 4.for迴圈、while迴圈 5.break語句、continue語句 1.交互操作 在cmd下的 開始--》cmd--》cd c:\ --》dir cd d:\=切換到d盤 cd=change directory dir=查看當前路徑下的文件 文件名 ...
  • 靜態代碼塊:最早執行, 類 被載入記憶體時執行,只執行一次。沒有名字、參數和返回值,有關鍵字static。 構造代碼塊:執行時間比靜態代碼塊晚,比構造函數早,和構造函數一樣,只在 對象 初始化的時候運行。沒有名字、參數和返回值。 構造函數:執行時間比構造代碼塊時間晚,也是在 對象 初始化的時候運行。沒 ...
  • 初學者先廣在精,關註代碼背後的實現,關註內功修煉,瞭解實現原理和思想,形成自己完整的技術體系,知識成片之後就容易觸類旁通,進步的速度就會越來越快。最後以我在每一個項目組和開發人員聊天都會說的幾個例子結尾:“少林功夫裡面有功和拳之分,馬步功,石鎖功是功,蛇拳猴拳是拳,你不可能練會了蛇拳猴拳就能打人,你... ...
  • 簡單工廠模式 工廠模式 抽象工廠模式 簡單工廠模式 工廠模式 抽象工廠模式 簡單工廠模式 什麼是簡單工廠模式? 在現實生活中工廠是負責生產產品的,同樣在設計模式中,簡單工廠模式我們也可以理解為負責生產對象的一個類, 我們平常編程中,當使用"new"關鍵字創建一個對象時,此時該類就依賴與這個對象,也就 ...
一周排行
    -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.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...