日本综合一区二区|亚洲中文天堂综合|日韩欧美自拍一区|男女精品天堂一区|欧美自拍第6页亚洲成人精品一区|亚洲黄色天堂一区二区成人|超碰91偷拍第一页|日韩av夜夜嗨中文字幕|久久蜜综合视频官网|精美人妻一区二区三区

RELATEED CONSULTING
相關咨詢
選擇下列產(chǎn)品馬上在線溝通
服務時間:8:30-17:00
你可能遇到了下面的問題
關閉右側(cè)工具欄

新聞中心

這里有您想知道的互聯(lián)網(wǎng)營銷解決方案
使用Nocalhost開發(fā)Rainbond上的微服務應用

Nocalhost 可以直接在 Kubernetes 中開發(fā)應用,Rainbond 可以快速部署微服務項目,無需編寫Yaml,Nocalhost 結合 Rainbond 加速我們的微服務開發(fā)效率。

一. 簡介

Nocalhost[1] 是一款開源的基于 IDE 的云原生應用開發(fā)工具:

直接在 Kubernetes 集群中構建、測試和調(diào)試應用程序。

提供易于使用的 IDE 插件(支持 VS Code 和 JetBrains),即使在 Kubernetes 集群中進行開發(fā)和調(diào)試,Nocalhost 也能保持和本地開發(fā)一樣的開發(fā)體驗。

使用即時文件同步進行開發(fā):即時將您的代碼更改同步到遠端容器,而無需重建鏡像或重新啟動容器。

Rainbond[2] 是一款云原生應用管理平臺:

使用簡單,不需要懂容器、Kubernetes和底層復雜技術,支持管理多個Kubernetes集群,和管理企業(yè)應用全生命周期。主要功能包括應用開發(fā)環(huán)境、應用市場、微服務架構、應用交付、應用運維、應用級多云管理等。

二. 本地 + Rainbond 開發(fā)微服務

以前我們在本地 + Rainbond 開發(fā)微服務時,要開發(fā)的模塊我們運行在本地,其他模塊運行在 Rainbond 上,我們通過 Rainbond 的網(wǎng)關與本地進行通信、聯(lián)調(diào)。

這樣會遇到一些問題:

  • 多人協(xié)作開發(fā)聯(lián)調(diào)困難
  • 本地環(huán)境差異化
  • 無法通過注冊中心(Nacos)調(diào)用其他微服務
  • 遠程Debug較難
  • 受限于本地資源

三. 使用 Nocalhost + Rainbond 開發(fā)微服務

現(xiàn)在我們通過 Nocalhost + Rainbond 開發(fā)微服務時,所有服務都運行在 Rainbond 上,當要開發(fā)時本地 Vscode 直連到 Rainbond 組件中,并與本地代碼實時同步到 Rainbond 組件中。多人開發(fā)聯(lián)調(diào)時,可通過 Rainbond 內(nèi)置的 Service Mesh 進行服務之間聯(lián)調(diào)。

使用 Nocalhost 開發(fā),可以解決本地開發(fā)時遇到的問題:

  • 多人聯(lián)調(diào)開發(fā)更便捷
  • 服務都運行在 Rainbond 上,不再受限于本地
  • 與生產(chǎn)環(huán)境更接近
  • 遠程Debug
  • 通過注冊中心(Nacos)調(diào)用其他微服務組件

四. 實踐操作步驟

Nocalhost 目前支持兩種開發(fā)模式:

  • Repliace DevMode
  • Duplicate DevMode

本篇將主要介紹 Replace DevMode,當進入 Replace DevMode 時,Nocalhost 會對 組件 執(zhí)行以下操作:

  • 將副本數(shù)縮減為 1
  • 替換容器的鏡像為開發(fā)鏡像
  • 增加一個 sidecar 容器。
  • 轉(zhuǎn)發(fā)一個本地端口到文件同步服務器。
  • 啟動本地文件同步客戶端。
  • 打開遠程終端。

4.1 安裝 Nocalhost 插件

Nocalhost 支持 VScode JetBrains ,這里我們主要介紹 VScode 插件安裝[3]參考官網(wǎng)文檔。

  • 打開 VScode,點擊左側(cè)的 Extension 按鈕圖標
  • 在搜索框中輸入 Nocalhost 選擇 Nocalhost 插件,并點擊 Install 按鈕

4.2 安裝 Rainbond

我們選擇 基于主機安裝 Rainbond[4]。

4.3 Nocalhost 對接 Rainbond 集群

  • 獲取 kubeconfig 文件,進入 Rainbond 集群視圖 -> 點擊節(jié)點配置 -> kubeconfig。
  • 我們將 kubeconfig 文件復制到本地并保存為 yaml 文件。
  • 打開 Vscode,點擊按鈕,打開 Nocalhost 插件,選擇 Connect to Cluster,選擇我們 kubeconfig 文件的路徑,點擊 Add Cluster,添加集群。
  • 添加完成后,如下圖:

4.4 在 Rainbond 上部署 Spring Cloud 微服務

  • 這里選擇從開源應用商店安裝 Spring Cloud Pig 微服務組件,在應用商店中搜索 Pig 進行安裝。
  • 部署完成后,效果如下:

4.5 進入 Nocalhost 開發(fā)模式

上面我們已經(jīng)在本地 Vscode 中對接好了集群,并且也已經(jīng)在 Rainbond 中安裝了 Spring Cloud Pig 微服務,那么接下來我們在本地 Vscode 中選擇其中一個組件進行開發(fā),這里為了效果更明顯,選擇開發(fā) pig-ui 組件。

Spring Cloud Pig 后端[5]

Spring Cloud Pig 前端[6]

4.5.1 克隆 Pig-ui 代碼到本地

git clone https://gitee.com/zhangbigqi/pig-ui

4.5.2 啟動本地開發(fā)

打開 Vscode,點擊按鈕,找到我們的 Pig-ui 組件,由于該應用是從開源應用商店中安裝,Deployment名稱是自動生成的字符串,我們需要在組件中查詢下。

我們點擊旁邊的進入開發(fā)模式,

  • 提示選擇容器,我們選擇 gred5f1c 這個容器,剩下那個容器是 Rainbond 的 Mesh 容器,用于內(nèi)部通信,不可替換。
  • 提示指定源代碼目錄,選擇我們剛剛克隆下來的代碼目錄。
  • 等待片刻后,會默認打開遠端容器的終端界面并且容器內(nèi)的文件會與本地實時同步,如下:

4.5.3 啟動項目

  • 安裝項目依賴,執(zhí)行
npm install

運行項目

npm run dev

啟動后效果如下,容器內(nèi)端口為 80。

開啟端口轉(zhuǎn)發(fā),點擊按鈕,找到我們的 Deployment,右鍵選擇 Port Forward,Add Port Forward,輸入 38000:80 將容器的80端口轉(zhuǎn)發(fā)到本地的38000端口。

  • 通過 http://localhost:38000 可以訪問到頁面,并且也可以正常登錄。

4.5.4 修改代碼查看效果

上面已經(jīng)演示了如果通過本地訪問到遠端容器內(nèi)的服務,接下來我們修改代碼看下效果。

修改 src/page/wel.vue,新增一段代碼,保存??梢园l(fā)現(xiàn),當我們保存的時候,終端中就自動重啟了,與本地開發(fā)效果一致。

文件的修改會實時同步到容器中。

刷新頁面http://localhost:38000,可以看到修改的內(nèi)容已生效。

寫在最后

通過以上的實踐步驟,我們已經(jīng)可以通過 Nocalhost 開發(fā) Rainbond 上的微服務應用,擺脫本地開發(fā),進入云原生快速開發(fā),提升我們的開發(fā)效率。

本文僅介紹了基本的開發(fā),還可以為項目配置 Nocalhost開發(fā)配置[7] 等等,小伙伴們可以自行探索。

[1]Nocalhost: https://nocalhost.dev

[2]Rainbond: https://www.rainbond.com/docs

[3]VScode 插件安裝: https://nocalhost.dev/docs/installation

[4]基于主機安裝 Rainbond: https://www.rainbond.com/docs/installation/install-with-ui/host-install-with-ui

[5]Spring Cloud Pig 后端: https://gitee.com/zhangbigqi/pig

[6]Spring Cloud Pig 前端: https://gitee.com/zhangbigqi/pig-ui[7]Nocalhost開發(fā)配置: https://nocalhost.dev/docs/config/config-overview-en

本文為作者張齊投稿,作者為云原生愛好者,歡迎各位投稿。


本文標題:使用Nocalhost開發(fā)Rainbond上的微服務應用
網(wǎng)頁路徑:http://www.dlmjj.cn/article/cooejgg.html