小米正式開源 Istio 管理面板 Naftis

近年來服務(wù)網(wǎng)格(Service Mesh)已成為各大公司關(guān)注重點(diǎn),各大公司紛紛開始調(diào)研 Service Mesh 相關(guān)架構(gòu)鹅髓。作為 Service Mesh 中的佼佼者芹务,Istio 誕生之初就已吸引眾多目光证杭。

作為基礎(chǔ)設(shè)施層腋妙,Istio 有優(yōu)秀的服務(wù)治理能力。但使用 Istio 進(jìn)行服務(wù)治理時(shí)幕庐,開發(fā)者需通過 istioctl 或 kubectl 工具在終端中進(jìn)行操作久锥,這種方式目前存在一些問題,舉例如下:

  1. Istio 要求用戶熟練掌握 istioctl 工具的數(shù)百種指令异剥,有較高的學(xué)習(xí)成本瑟由。
  2. Istio 進(jìn)行服務(wù)治理時(shí)需要的 yaml 配置文件的數(shù)量非常龐大,如何配置和管理這些配置文件冤寿,也是個(gè)難題歹苦。
  3. Istio 的 istioctl 工具沒有用戶權(quán)限的約束,存在一定安全隱患督怜,無法適應(yīng)大公司嚴(yán)格的權(quán)限管理需求殴瘦。
  4. Istio 的 istioctl 工具不支持任務(wù)回滾等需求,在執(zhí)行任務(wù)出錯(cuò)的情況下号杠,無法快速回滾到上一個(gè)正確版本蚪腋。

為了解決這些問題,小米信息部武漢研發(fā)中心為 Istio 研發(fā)出了一套友好易用的 dashboard —— Naftis 姨蟋。

Naftis 意為水手屉凯,和 Istio (帆船)意境契合。作為 dashboard 眼溶, Naftis 能使用戶像水手一樣熟練掌控和管理 Istio 悠砚。

https://github.com/xiaomi/naftis

Naftis 通過任務(wù)模板的方式來幫助用戶更輕松地執(zhí)行 Istio 任務(wù)。用戶可以在 Naftis 中定義自己的任務(wù)模板堂飞,并通過填充變量來構(gòu)造單個(gè)或多個(gè)任務(wù)實(shí)例灌旧,從而完成各種服務(wù)治理功能。

Naftis 提供了如下特性:

  • 集成了一些常用的監(jiān)控指標(biāo)酝静,包括 40X节榜、50X 錯(cuò)誤趨勢等。
  • 提供了可定制的任務(wù)模板的支持别智。
  • 支持回滾指定某一任務(wù)。
  • 提供了 Istio 狀態(tài)診斷功能稼稿,可實(shí)時(shí)查看 Istio 的 Services 和 Pod 狀態(tài)薄榛。
  • 開箱即用讳窟,通過 kubectl 指令一鍵部署。

依賴

目前 Naftis 僅支持 Kubernetes敞恋,不支持其他容器調(diào)度平臺(tái)丽啡。

  • Istio > 1.0
  • Kubernetes>= 1.9.0Jf
  • HIUI >= 1.0.0

Naftis 后端采用 Go 編寫,通過 Kubernetes 和 Istio 的 CRD 接口對(duì) Istio 資源進(jìn)行操作硬猫;
前端則采用了同樣由小米開源的基于 React 的前端組件 HIUI补箍,HIUI 簡潔優(yōu)雅,有一定 React 基礎(chǔ)的前端開發(fā)者能迅速上手:

https://github.com/xiaomi/hiui

快速開始

kubectl create namespace naftis && kubectl apply -n naftis -f mysql.yaml && kubectl apply -n naftis -f naftis.yaml

# 通過端口轉(zhuǎn)發(fā)的方式訪問 Naftis
kubectl -n naftis port-forward $(kubectl -n naftis get Pod -l app=naftis -ui -o jsonpath='{.items[0].metadata.name}') 8080:80 &

# 打開瀏覽器訪問 http://localhost:8080啸蜜,默認(rèn)用戶名和密碼分別為 admin坑雅、admin。

詳細(xì)的部署流程

Kubernetes 集群內(nèi)運(yùn)行

# 創(chuàng)建 Naftis 命名空間
$ kubectl create namespace  naftis

# 確認(rèn) Naftis 命名空間已創(chuàng)建
$ kubectl get namespace  naftis
NAME           STATUS    AGE
naftis          Active    18m

# 部署 Naftis MySQL 服務(wù)
$ kubectl apply -n  naftis  -f mysql.yaml

# 確認(rèn) MySQL 已部署
$ kubectl get svc -n naftis
NAME                           READY     STATUS    RESTARTS   AGE
naftis-mysql-c78f99d6c-kblbq   1/1       Running   0          9s
naftis-mysql-test              1/1       Running   0          10s

# 部署 Naftis API和 UI 服務(wù)
$ kubectl apply -n naftis -f naftis.yaml

# 確認(rèn) Naftis 所有的服務(wù)已經(jīng)正確定義并正常運(yùn)行中
$ kubectl get svc -n naftis
NAME           TYPE           CLUSTER-IP      EXTERNAL-IP   PORT(S)        AGE
naftis-api     ClusterIP      10.233.3.144    <none>        50000/TCP      7s
naftis-mysql   ClusterIP      10.233.57.230   <none>        3306/TCP       55s
naftis-ui      LoadBalancer   10.233.18.125   <pending>     80:31286/TCP   6s

$ kubectl get  Pod  -n  naftis
NAME                           READY     STATUS    RESTARTS   AGE
naftis-api-0                   1/2       Running   0          19s
naftis-mysql-c78f99d6c-kblbq   1/1       Running   0          1m
naftis-mysql-test              1/1       Running   0          1m
naftis-ui-69f7d75f47-4jzwz     1/1       Running   0          19s

# 端口轉(zhuǎn)發(fā)訪問 Naftis
kubectl -n naftis port-forward $(kubectl -n naftis get Pod -l app=naftis-ui -o jsonpath='{.items[0].metadata.name}') 8080:80 &

# 打開瀏覽器衬横,訪問 http://localhost:8080 即可裹粤。默認(rèn)用戶名和密碼分別為 admin、admin蜂林。

本地運(yùn)行

數(shù)據(jù)移植

# 執(zhí)行 sql語句
mysql> source ./tool/naftis.sql;

# 將 in-local.toml 中的數(shù)據(jù)庫的 DSN 配置替換成本地?cái)?shù)據(jù)庫實(shí)例的 DSN遥诉。

啟動(dòng) API 服務(wù)

  • Linux
make build && ./bin/naftis-api start -c config/in-local.toml

./run
  • Mac OS
GOOS=darwin GOARCH=amd64 make build && ./bin/naftis-api start -c config/in-local.toml

GOOS=darwin GOARCH=amd64 ./run

配置 Nginx 代理

cp tool/naftis.conf <your-nginx-conf-directory>/naftis.conf
# 酌情修改 naftis.conf 文件并 reload nginx

啟動(dòng)前端 Node 代理

cd src/ui
npm install
npm run dev

# 打開瀏覽器訪問 http://localhost:5200。

預(yù)覽

dashboard

dashboard 頁面集成了一些常用的圖表噪叙,比如請(qǐng)求成功率矮锈、4XX 請(qǐng)求數(shù)量等。


集成了一些常用的圖表睁蕾,比如請(qǐng)求成功率愕难、4XX請(qǐng)求數(shù)量等

服務(wù)管理

服務(wù)詳情

服務(wù)詳情頁面可以查看查看已部署到 Kubernetes 中服務(wù)信息。


查看已部署到k8s中服務(wù)信息

服務(wù) Pod 和拓?fù)鋱D等

服務(wù)詳情頁面可以查看指定服務(wù) Pod 和拓?fù)鋱D等信息惫霸。


Services - Pod

任務(wù)模板管理

任務(wù)模板列表

任務(wù)模板列表也可以查看已經(jīng)添加好的任務(wù)模板卡片列表猫缭。


任務(wù)模板列表

查看指定模板

點(diǎn)擊“查看模板”可以查看指定模板信息。


查看指定模板

新增模板

點(diǎn)擊“新增模板”可以向系統(tǒng)中新增自定義模板壹店。


新增模板

創(chuàng)建任務(wù)

初始化變量值猜丹。


創(chuàng)建任務(wù)-第一步

確認(rèn)變量值。


創(chuàng)建任務(wù)-第二步

提交創(chuàng)建任務(wù)的分步表單硅卢。


創(chuàng)建任務(wù)-第三步

Istio 診斷

Istio 診斷頁面可以查看 Istio Service 和 Pod 狀態(tài)射窒。


查看 Istio 狀態(tài)

Docker 鏡像

Naftis 的 API 和 UI 鏡像已經(jīng)發(fā)布到 Docker Hub 上,見 apiui将塑。

開發(fā)者指南

獲取源碼

go get github.com/xiaomi/naftis

配置環(huán)境變量

將下述環(huán)境變量添加到 ~/.profile 脉顿。我們強(qiáng)烈推薦通過 autoenv 來配置環(huán)境變量。

# 根據(jù)環(huán)境改變 GOOS 和 GOARCH 變量
export GOOS="linux"   # 或替換成 "darwin"
export GOARCH="amd64" # 或替換成 "386"

# 把 USER 修改成你自己的 DockerHub 用戶名
export USER="sevennt"
export HUB="docker.io/$USER"

如果你使用 autoenv点寥,則輸入 cd . 來使環(huán)境變量生效艾疟。

Go 依賴

我們目前使用 dep 管理依賴。

# 安裝 dep
go get -u github.com/golang/dep
dep ensure -v # 安裝 Go 依賴

代碼風(fēng)格

其他指令

make                 # 編譯所有 targets

make build           # 編譯 Go 二進(jìn)制文件、前端靜態(tài)資源蔽莱、Kubernetes清單
make build.api       # 編譯 Go 二進(jìn)制文件
make build.ui        # 編譯前端靜態(tài)資源
make build.manifest  # 編譯Kubernetes清單

make fmt   # 格式化 Go 代碼
make lint  # lint Go 代碼
make vet   # vet Go 代碼
make test  # 運(yùn)行測試用例
make tar   # 打包成壓縮文件

make docker      # 編譯 docker 鏡像
make docker.api  # 編譯后端 docker 鏡像
make docker.ui   # 編譯前端 docker 鏡像
make push        # 把鏡像推送到 Docker Hub

./bin/naftis-api -h       # 顯示幫助信息
./bin/naftis-api version  # 顯示版本信息

./tool/genmanifest.sh  # 本地渲染Kubernetes部署清單
./tool/cleanup.sh      # 清理已部署的 Naftis

其他

Naftis 目前已在 Github 開源 弟疆,目前功能還比較薄弱,希望更多志同道合的朋友一起參與進(jìn)來共同完善落地 Istio 生態(tài)盗冷。

https://github.com/xiaomi/naftis

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末怠苔,一起剝皮案震驚了整個(gè)濱河市,隨后出現(xiàn)的幾起案子仪糖,更是在濱河造成了極大的恐慌柑司,老刑警劉巖,帶你破解...
    沈念sama閱讀 207,113評(píng)論 6 481
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件锅劝,死亡現(xiàn)場離奇詭異攒驰,居然都是意外死亡,警方通過查閱死者的電腦和手機(jī)鸠天,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 88,644評(píng)論 2 381
  • 文/潘曉璐 我一進(jìn)店門讼育,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人稠集,你說我怎么就攤上這事奶段。” “怎么了剥纷?”我有些...
    開封第一講書人閱讀 153,340評(píng)論 0 344
  • 文/不壞的土叔 我叫張陵痹籍,是天一觀的道長。 經(jīng)常有香客問我晦鞋,道長蹲缠,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 55,449評(píng)論 1 279
  • 正文 為了忘掉前任悠垛,我火速辦了婚禮线定,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘确买。我一直安慰自己斤讥,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 64,445評(píng)論 5 374
  • 文/花漫 我一把揭開白布湾趾。 她就那樣靜靜地躺著芭商,像睡著了一般。 火紅的嫁衣襯著肌膚如雪搀缠。 梳的紋絲不亂的頭發(fā)上铛楣,一...
    開封第一講書人閱讀 49,166評(píng)論 1 284
  • 那天,我揣著相機(jī)與錄音艺普,去河邊找鬼簸州。 笑死鉴竭,一個(gè)胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的勿侯。 我是一名探鬼主播拓瞪,決...
    沈念sama閱讀 38,442評(píng)論 3 401
  • 文/蒼蘭香墨 我猛地睜開眼缴罗,長吁一口氣:“原來是場噩夢啊……” “哼助琐!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起面氓,我...
    開封第一講書人閱讀 37,105評(píng)論 0 261
  • 序言:老撾萬榮一對(duì)情侶失蹤兵钮,失蹤者是張志新(化名)和其女友劉穎,沒想到半個(gè)月后舌界,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體掘譬,經(jīng)...
    沈念sama閱讀 43,601評(píng)論 1 300
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 36,066評(píng)論 2 325
  • 正文 我和宋清朗相戀三年呻拌,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了葱轩。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 38,161評(píng)論 1 334
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡藐握,死狀恐怖靴拱,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情猾普,我是刑警寧澤袜炕,帶...
    沈念sama閱讀 33,792評(píng)論 4 323
  • 正文 年R本政府宣布,位于F島的核電站初家,受9級(jí)特大地震影響偎窘,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜溜在,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 39,351評(píng)論 3 307
  • 文/蒙蒙 一陌知、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧掖肋,春花似錦仆葡、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,352評(píng)論 0 19
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至籽腕,卻和暖如春嗡呼,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背皇耗。 一陣腳步聲響...
    開封第一講書人閱讀 31,584評(píng)論 1 261
  • 我被黑心中介騙來泰國打工南窗, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留,地道東北人。 一個(gè)月前我還...
    沈念sama閱讀 45,618評(píng)論 2 355
  • 正文 我出身青樓万伤,卻偏偏與公主長得像窒悔,于是被迫代替她去往敵國和親。 傳聞我的和親對(duì)象是個(gè)殘疾皇子敌买,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 42,916評(píng)論 2 344

推薦閱讀更多精彩內(nèi)容

  • 10月24日任務(wù) 10.6監(jiān)控io性能 查看磁盤的狀況的非常重要的指標(biāo) b 或者 wa列 壓力大简珠,磁盤有瓶頸 io...
    越來越好_1472閱讀 366評(píng)論 0 0
  • 目錄 一脱货、監(jiān)控io性能二、free命令三律姨、ps命令四振峻、查看網(wǎng)絡(luò)狀態(tài)五、linux下抓包 一线召、監(jiān)控io性能 iost...
    XiaoMing丶閱讀 1,080評(píng)論 0 2
  • 學(xué)習(xí)要點(diǎn) ]1. 變量的含義 ]2. 變量的使用方法 3. 常見的數(shù)據(jù)類型 4. ]變量的命名規(guī)則...
    晨顏閱讀 774評(píng)論 0 0
  • 可以負(fù)責(zé)任的說铺韧,人是健忘的,很多人總是想當(dāng)然享受著別人對(duì)自己的幫助缓淹,而從沒想過感恩哈打。 絕大多數(shù)人就是這樣,其中包括...
    6521d5bb6dd6閱讀 322評(píng)論 0 0
  • 讀格爾德·吉仁澤《直覺 Gut Feeling》有感 格爾德·吉仁澤讯壶,德國認(rèn)知心理學(xué)家料仗,他因在判斷和決策上眾多開創(chuàng)...
    趙昱塵閱讀 793評(píng)論 1 0