Spring Cloud Netflix多語言/非java語言支持之Sidecar

来源:http://www.cnblogs.com/YrlixJoe/archive/2017/09/12/7509655.html
-Advertisement-
Play Games

Spring Cloud Netflix多語言/非java語言支持之Spring Cloud Netflix Sidecar Polyglot support with Sidecar 前言 公司有一個調研要做,調研如何將Python語言提供的服務納入到Spring Cloud管理中來,找到了這個S ...


Spring Cloud Netflix多語言/非java語言支持之Spring Cloud Netflix Sidecar
Polyglot support with Sidecar

前言

公司有一個調研要做,調研如何將Python語言提供的服務納入到Spring Cloud管理中來,找到了這個Sidecar組件,發現官方提供一篇文檔,對其進行相關翻譯。
聲明:如果在閱讀時發現有誤或有更好的翻譯方式,請及時通知給我。

Sidecar簡介

根據我的理解,Sidecar是作為一個代理的服務來間接性的讓其他語言可以使用Eureka等相關組件。通過與Zuul的來進行路由的映射,從而可以做到服務的獲取,然後可以使用Ribbon,Feign對服務進行消費,以及對Config Server的間接性調用。例如:進行服務消費時,發送Ribbon消費介面的請求會通過Zuul來完成請求路由到具體主機地址及埠的映射解析,然後進行消費的處理。(此段內容僅個人理解,只作為參考,歡迎討論,同時有誤請及時指正。)

正文翻譯

以下是原文翻譯,原文地址:https://cloud.spring.io/spring-cloud-netflix/multi/multi__polyglot_support_with_sidecar.html

你是否想要在非jvm的語言中利用(間接性使用)Eureka,Ribbon以及Config Server?Spring Cloud Netflix Sidecar的誕生受到Netflix Prana的啟發。它包含一個簡單的http api去獲取一個已知服務的所有實例(例如主機和埠)。你也可以通過嵌入的Zuul代理(Zuul中有一個代理功能)對代理的服務進行調用,Zuul從Eureka服務註冊中心獲取所有的路由記錄(route entries)。通過host發現(host lookup)或者Zuul代理可以直接訪問Spring Cloud Config。非jvm需要應該實現一個健康檢查,Sidecar能夠以此來報告給Eureka註冊中心該應用是up還是down狀態。

在你的項目中使用Sidecar,需要添加依賴,其group為org.springframework.cloud,artifact id為spring-cloud-netflix-sidecar。(這是以maven依賴的方式)

啟用Sidecar,創建一個Spring Boot應用程式,併在在應用主類上加上@EnableSidecar註解。該註解包含@EnableCircuitBreaker, @EnableDiscoveryClient以及@EnableZuulProxy。Run the resulting application on the same host as the non-jvm application. (這句不太會翻譯,我的理解為:在與非jvm應用程式相同的主機上運行生成的應用程式)註:這裡的生成應該是通過代理產生的服務。

配置Sidecar,在application.yml中添加sidecar.portsidecar.health-urisidecar.port屬性是非jre程式監聽的埠號,這就是Sidecar可以正確註冊應用到Eureka的原因。sidecar.health-uri是非jre應用提供的一個對外暴露的可訪問uri地址,在該地址對應的介面中需要實現一個模仿Spring Boot健康檢查指示器的功能。它需要返回如下的json文檔。(:通過返回一個json,其用status欄位來標識你的應用的服務狀態,是up還是down,sidecar會將該狀態報告給eureka註冊中心從而實現你的服務的狀態可用情況。簡單的說就是用來控制sidecar代理服務的狀態!)
health-uri-document.

health-uri-document.(heal-uri指向的介面地址需要返回的json文檔) 

{
  "status":"UP"
}

這裡是一個Sidecar應用程式的application.yml配置示例:

application.yml

server:
  port: 5678
spring:
  application:
    name: sidecar

sidecar:
  port: 8000
  health-uri: http://localhost:8000/health.json

API DiscoveryClient.getInstances()所對應的訪問方式是/hosts/{serviceId},這是訪問/hosts/customers後的響應示例,它返回了兩個不同主機上的實例(可以看到主機地址不一樣)。
非jre程式可以訪問這個api,如果sidecar的埠號為5678,那麼完整url則為:http://localhost:5678/hosts/{serviceId}.

/hosts/customers.

[
    {
        "host": "myhost",
        "port": 9000,
        "uri": "http://myhost:9000",
        "serviceId": "CUSTOMERS",
        "secure": false
    },
    {
        "host": "myhost2",
        "port": 9000,
        "uri": "http://myhost2:9000",
        "serviceId": "CUSTOMERS",
        "secure": false
    }
]

Zuul代理會自動為每個在Eureka註冊中心上的服務添加路由到/serviceId上,所以上面那個customers的服務可以通過/customers訪問。非Jre應用可以通過http://localhost:5678/customers來訪問Customer Service(假設Sidecar的監聽埠為5678)

如果Config Server註冊到了Eureka,非jre應用就可以通過Zuul代理訪問它。如果ConfigServer的serviceId為configserver並且Sidecar的埠為5678,那麼可以通過http://localhost:5678/configserver 的方式來訪問Config Server。

非Jvm應用可以利用Config Server的能力來獲取Config Server返回的YAML文檔,通過訪問 http://sidecar.local.spring.io:5678/configserver/default-master.yml 就可以獲取到類似下麵的YAML文檔結果

eureka:
  client:
    serviceUrl:
      defaultZone: http://localhost:8761/eureka/
  password: password
info:
  description: Spring Cloud Samples
  url: https://github.com/spring-cloud-samples

上面是介紹,這裡是一篇具體的使用案例:《使用Sidecar將Node.js引入Spring Cloud


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

-Advertisement-
Play Games
更多相關文章
  • NumPy : Numerical Python,是高性能科學計算和數據分析的基礎包。 部分功能: 大部分數據分析應用關註的功能: ...
  • 描述寫一個程式,找出給出素數範圍內的所有孿生素數的組數。一般來說,孿生素數就是指兩個素數距離為2,近的不能再近的相鄰素數。有些童鞋一看到題就開始寫程式,不仔細看題,咱們為了遏制一下讀題不認真仔細的童鞋,規定,兩個素數相鄰為1的也成為孿生素數。輸入第一行給出N(0 using namespace st... ...
  • 選擇排序是一種非常簡單的排序演算法,從字面意思我們就可以知道,選擇就是從未排序好的序列中選擇出最小(最大)的元素,然後與第 i 趟排序的第 i-1(數組中下標從 0 開始) 個位置的元素進行交換,第 i 個元素之前的序列就是已經排序好的序列。整個排序過程只需要遍歷 n-1 趟便可排好,最後一個元素自動 ...
  • PHP操作實現一個多功能購物網站 一、需要實現的頁面: Index.aspx:瀏覽商品頁面,顯示商品列表,用戶可以點擊“加入購物車“。 ViewCart.aspx:查看購物車頁面,顯示已購買的商品信息,可以點擊“刪除“和“提交添加訂單購買”商品 ViewAccount.aspx:查看個人賬戶餘額 L ...
  • 回到目錄 下麵將介紹以下幾個原則,都是軟體設計里的大哥大,大姐大級別的人物! DRY DRY是Do Not Repeat Yourself的簡稱,不要寫重覆的代碼,可以使用代碼重構里的提取到方法,提取到類來做這事 KISS KISS 是Keep it short and simple 的簡稱。意思是 ...
  • 一、引言 我們常常在會在字元串中搜索匹配字元或判斷一個字元串是否符合我們要的格式時,使用正則表達式,可解決問題的背後是一種什麼思想呢?即我們今天要學習的內容,解釋器模式 二、解釋器模式 定義:給定一個語言,定義它的文法的一種表示,並定義一個解釋器,這個解釋器使用該表示來解釋語言中的句子 1.文法:即 ...
  • 一個很簡單的淘寶優惠券搜索助手 大家看看有沒有用吧 下載地址:http://pan.baidu.com/s/1skRHTDF ...
  • 返回碼規範: 統一六位 000000 表示成功! 參數相關返回碼預留100000-199999;系統相關返回碼預留200000-299999;數據中心310000-319999後續項目以此類推,後續根據業務擴展情況新增操作碼需要提前備案! module = 系統碼 optCode = 操作碼 opt ...
一周排行
    -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.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...