好湿?好紧?好多水好爽自慰,久久久噜久噜久久综合,成人做爰A片免费看黄冈,机机对机机30分钟无遮挡

主頁 > 知識庫 > 詳解Go語言微服務開發框架之Go chassis

詳解Go語言微服務開發框架之Go chassis

熱門標簽:上海企業外呼系統排名 智能語音電銷的機器人 百度地圖標注位置網站 如何利用高德地圖標注家 電腦外呼系統輻射大嗎 400手機電話免費辦理 揚州電銷外呼系統軟件 武漢百應人工智能電銷機器人 開通400電話申請流程

引言

https://github.com/go-chassis/go-chassis是一個微服務開發框架,而微服務開發框架帶來的其中一個課題就是:當單體應用向微服務轉型后,有大量的配置需要管理,而你并不希望登錄到遠端機器去更改配置,并重啟應用,尤其是現在已經是容器的時代了,也不希望因為一個配置的變更,而發布一個新的軟件包。那么分布式系統中每個進程的動態配置管理及運行時熱加載就成為了一個亟待解決的問題。https://github.com/go-chassis/go-archaius為gochassis而生,他汲取了netflix的archaius框架經驗,并做出來自己的創新特性。

架構

Source:配置源是一種標準接口,可以通過實現一個source來接入不同配置源,它定義配置來自哪個資源,配置可以來自配置中心configcenter,來自本地文件,來自環境變量或是啟動命令行。source負責將配置項緩存到本地內存。用戶可以選擇加載任意的source實現。

Config center source:配置中心源不同于其他source,它包含一個client抽象,可以對接不同的生態系統,目前對接了攜程開源的配置中心Apollo。

Config manager:負責整合管理所有source的配置,每個source可以定義優先級,當通過manager獲取配置時,如果2個不同的source有相同的配置,那么就會取最大優先級的配置。

Event Dispatcher:用戶可以通過Archaius API進行配置變化監聽,當source內部的配置項新增,更新,刪除配置時,都會通知到監聽器。

Source優先級:優先級由大到小依次為Config center,CLI,ENV,file,當有相同配置項的時候僅優先級大的配置生效。在一個分布式系統中,遠程的配置中心理應擁有最大優先級,而在本地運行一個獨立的進程時,通常的思維是,命令行參數優先級高于環境變量,高于本地文件內容。擁有了這樣一套機制后,用戶就無需再寫代碼處理配置項生效邏輯。

Config Factory:封裝了event 和 config manager的API

Archaius API:封裝底層實現,提供友好的API供開發者使用

獲取配置

獲取配置有2種不同的手段:

1. 調用archaius API的Get 方法

2. 注冊監聽器

事件的觸發是由soruce的開發者來決定的,每個source的行為會有不同:

命令行與環境變量是不會產生任何事件的,當archaius運行后配置項就已經定下來了,只能使用Get方法獲取。而文件source會在啟動后拉取一遍本地文件內容并轉換為配置項(可自定義轉換算法,決定配置項形態),之后持續監聽本地文件變化,當有變化發生時會刷新本地配置并通知到監聽器。所以2種方法都支持。config center source行為與文件又不同,在啟動后,它就會周期拉取配置中心的配置,并且對比每一次配置項的不同,并觸發不同類型事件。

配置項形態

假設程序有一個配置文件叫a.yaml,內容如下

registry:

  enabled: true

  interval: 30s復制代碼

要考慮該如何去對待這raw data,目前有2種方式

第一種,將配置項拆分為java properties風格的配置:

registry.refresh: true

registry.interval: 30s

go archaius開放了file handler接口,允許你決定如何將文件內容處理為配置項

那么在遠程的配置中心中,key value的管理方式就要遵循 file handler的行為,當你想變更registry.refresh時,就要在配置中心種更改這個配置項及值。

類似于開關類的配置項,這種java properties的管理方式還是不錯的,當一個配置項改變時觸發一次事件。

但是有一類配置項并不適合如此管理,這就是第二種方式,比如go chassis中的路由管理配置文件:

通常都需要大范圍的更改配置項,那么如果還使用切分的方式在配置中心中管理將會引起go archaius運行時大量的事件觸發,并且,用戶在使用體驗上大打折扣,到處去找分散的配置項,逐一更改。正確的行為是,將文件名作為配置中心中的key,文件內容作為value。用戶需要更改時,去找對應的文件名即可,修改后一次性下發,只會觸發一次事件,完成路由的變更。

開發者應根據實際場景判斷如何處理配置項形態。也可以自己實現handler來決定配置項形態

配置運行時熱加載

在運行時可以隨時通過統一的配置中心或者本地文件(不推薦分布式環境登到機器里改文件,但在本地debug時還是推薦使用文件來測試程序的熱加載邏輯)更改配置了,那么接下來要解決的問題就是配置在運行時生效。

這里的技巧是使用go語言中的讀寫鎖。我以go chassis中路由配置來說明

go chassis運行時總是會有不斷地大并發數據訪問router config這塊緩存,使用一個讀寫鎖lock中的讀鎖,每次訪問緩存都用讀鎖,使用后,解開讀鎖。

向archaius注冊監聽器,需要自己編寫監聽器的邏輯,每當事件出發后就會通過archaius中的數據構建一個結構體數據,然后將數據存到本地緩存,首先使用lock的寫鎖鎖住router config,更新后,解開寫鎖。

在這樣的機制下,就可以做到運行時熱加載配置項而無需重啟服務。

例子

一個本地文件事件監控的例子

https://github.com/go-chassis/go-archaius/tree/master/examples/event

管理本地多文件的例子

https://github.com/go-chassis/go-archaius/tree/master/examples/file

Go chassis介紹

https://juejin.im/post/6844903682362834952

以上就是詳解Go語言微服務開發框架之Go chassis的詳細內容,更多關于Go語言的資料請關注腳本之家其它相關文章!

您可能感興趣的文章:
  • 詳解PHP調用Go服務的正確方式
  • goto語法在PHP中的使用教程
  • 基于Go和PHP語言實現爬樓梯算法的思路詳解
  • ThinkPHP5 框架引入 Go AOP,PHP AOP編程項目詳解
  • golang、python、php、c++、c、java、Nodejs性能對比
  • Linux安裝PHP MongoDB驅動
  • PHP中安裝使用mongodb數據庫
  • 詳解Go與PHP的語法對比

標簽:江西 新余 宜賓 張掖 黑龍江 嘉峪關 延邊 武漢

巨人網絡通訊聲明:本文標題《詳解Go語言微服務開發框架之Go chassis》,本文關鍵詞  詳解,語言,微,服務,開發,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《詳解Go語言微服務開發框架之Go chassis》相關的同類信息!
  • 本頁收集關于詳解Go語言微服務開發框架之Go chassis的相關信息資訊供網民參考!
  • 推薦文章
    主站蜘蛛池模板: 亚洲尺码和欧洲尺码的区别和联系| 西门庆潘金莲三级在线观看| 波多野结衣50连精喷在线| 肉体?粗喘娇吟国产AV视频免费| 欧美一级特黄AAAAAA片| 最近在线字幕国语视频| 三上悠亚免费| 日久精品国产免费无码A片| 国产AV无码白丝喷水爆乳| 婷婷五月狠狠色综合久久| 调教男生穿女装做女仆小说| se亚洲| 欧美白嫩少妇蜜桃AV| 398av视频在线播放| 国产乱码一区二区三区四川人| 97精产国品一二三产区区别免费| 老师我好爽再深一点视频| 高h羞辱调教小说| 亚洲精品aⅴ中文字幕乱码| 浪荡受年下攻h| 91香蕉国产线观看免费全集| 大陆三级午夜理伦三级三| 99久久成人| porno日本xxxx老师| 777色情综合久色AⅤ网黑| 人妻洗澡被强公日日澡| 中文字幕乳桑田授乳奶水电影| 91在线高清视频| 被两个男人吃奶三p好爽| 亚洲Gay男生露J自慰网站| 一品道一本香蕉视频| 九九热精品视频| 免费男人添女人下身视频高清 | 男女上床网站| 欧美变态杂交在线看| 欧美一级片在线视频| 羞羞漫画喷水漫画yy漫画| 啊…嗯啊好深男男高h文总受| 无码免费婬AV片在线观看精工厂| 亚洲综合在线成人一区| 日本高清无卡码一区二区久久 |