背景
Dapr 是一個開源的分布式應用運行時,幫助開發(fā)者構建松耦合的分布式應用程序,具有良好的可擴展性和可維護性。Rainbond 是一款企業(yè)級的云原生應用管理平臺,提供了豐富的功能和工具,方便開發(fā)者管理和部署應用。Rainbond 和 Dapr 結合可以提供以下價值點:
「1.為Dapr擴展云原生支持:」Rainbond 提供了一套完整的云原生應用支持方案,包括應用開發(fā)、應用編排、應用交付、應用運維等應用全生命周期管理能力,而 Dapr 只是應用開發(fā)框架,包括應用開發(fā)模型、服務發(fā)現(xiàn)、事件驅動等功能。將 Rainbond 和 Dapr 結合起來可以提供更完整的云原生應用支持,幫助開發(fā)人員更快地構建和部署應用。
「2.讓Dapr應用可移植性增強:」Rainbond提供應用模版能力,Dapr開發(fā)的應用以模版的方式打包,可以方便交付和遷移到其他平臺運行。
「3.為Rainbond擴充服務治理能力:」Rainbond 支持通過插件擴展服務治理能力,和 Dapr結合,可以通過Dapr的方式實現(xiàn)服務治理。將二者結合起來,可以提供更完整的服務治理功能,幫助開發(fā)人員更好地管理和控制應用中的服務。
「4.為Rainbond增加BaaS能力:」在Rainbond上開發(fā)軟件,需要自己安裝后端數(shù)據(jù)庫和中間件,而Dapr將后端能力以API的方式對外提供,開發(fā)者只需要通過API統(tǒng)一訪問后端能力,實現(xiàn)了BaaS體驗。
總之,Dapr和Rainbond能互相補充能力不足,Rainbond 解決了應用生命周期管理的問題,開發(fā)者不需要懂底層技術,但還是需要了解后端服務, Dapr 補足了這塊能力,讓開發(fā)者更加專注業(yè)務。
Rainbond和Dapr的整合思路

在 Dapr 微服務框架的業(yè)務體系中,Daprd 是整個業(yè)務的核心,應用程序通過運行時 API 發(fā)送請求給 Daprd,Daprd 負責處理這些請求,并與底層服務進行交互。Daprd 是由 Dapr Services 中的 dapr-sidecar-injector 服務進行注入的,當 Pod 滿足注入條件后進行注入。同時 Dapr Services 中的 dapr-operator 會監(jiān)聽整個集群下的 Dapr 配置資源(CRD),當捕獲到有 Dapr 配置類資源的創(chuàng)建后,會記錄在內(nèi)存中,再次注入的 Daprd 如果 Pod 聲明了使用該配置,則會提供對應的能力。
「Dapr Service 的安裝」:Rainbond 將 Dapr Services 資源進行了整合,作為一個插件應用上架到了應用商店,通過安裝便可以快速讓我們的集群具備 dapr 微服務架構能力,避免了集群中執(zhí)行 dapr init -k
命令,同時解決了國外鏡像拉取的問題。
「DaprD注入」:傳統(tǒng)注入方式我們需要手動添加注入條件字段,費時費力且不易維護還容易出錯;Rainbond 支持通過切換應用的治理模式的方式,為我們的 Pod 添加不同屬性字段以滿足不同微服務架構的注入條件,從而達到批量注入,快速使用、便于管理的效果。
「Dapr配置」:Dapr 提供了四種配置 Daprd 的資源來擴展我們的服務治理能力,分別為Configuration、Component、Resiliency、Subscription,我們需要通過編寫 Yaml 的形式在集群中創(chuàng)建這些資源供業(yè)務組件使用,Rainbond 平臺在應用的 k8s 資源的管理入口,其效果與kubectl
有些類似但比kubectl
更易于管理。其中 Configuration 資源用于存儲應用程序的配置信息,例如連接字符串、密鑰、證書等,需要為 Pod 配置的 annotations
屬性去聲明才可使用,Rainbond 的組件視圖提供對annotations
屬性配置,簡化了我們配置的流程。
「Dapr Component安裝和對接」:Rainbond 的應用商店已經(jīng)有很多后端實現(xiàn),如 MySQL、Redis等,在Rainbond里可以一鍵安裝便可使用。在Dapr應用的K8s資源管理里配置Component的yaml,綁定后端服務的地址。
「Dapr應用開發(fā):」Dapr開發(fā)的應用可以用源碼、鏡像、yaml部署到Rainbond平臺上,然后根據(jù)Dapr的API規(guī)范訪問后端服務,Rainbond提供對Dapr應用的持續(xù)集成、持續(xù)交付、環(huán)境管理、配置管理、日志和性能監(jiān)控、訪問網(wǎng)關、應用運維等能力,輔助Dapr應用的開發(fā)和管理。
部署和使用流程
基于 Rainbond 使用 Dpar 的目標:
- 一鍵部署 Dapr Service,讓集群具備 Dapr 微服務架構能力。
- 自動為業(yè)務組件注入 Daprd。
- 可視化管理 Dapr 配置。
- 簡化 Daprd 屬性參數(shù)配置流程。
- 多種方式交付你的 Dapr 業(yè)務。
下面我通過部署一個發(fā)布訂閱的示例,供大家快速了解并掌握 Dapr 在 Rainbond 中是如何使用的
前提條件
- Rainbond 版本大于 v5.13。
- Rainbond 已經(jīng)對接過開源應用商店并擁有推送權限。
實踐步驟

1. 安裝 Rainbond Service Mesh 插件
Rainbond ServiceMesh 插件負責按照指定治理模式對應用組件進行加工調(diào)整,以滿足微服務治理插件注入的基本條件。通過在平臺管理->應?市場->開源應?商店->搜索 Rainbond-ServiceMesh 并進行安裝
2. 安裝Dapr 應用插件
創(chuàng)建一個以 dapr-system 為英文名的團隊,安裝 Dapr Services 。通過在平臺管理->應?市場->開源應?商店->搜索 Rainbond-Dapr 并進行安裝
。
3. 綁定 Component
Dapr 支持對接多種 Component 實現(xiàn),如 Redis、Mysql、Oauth等,在 Rainbond 平臺中安裝也非常簡單,大部分實現(xiàn)都可以在 Rainbond 應用商店中找到,少數(shù)不支持的存儲也歡迎大家參與應用制作發(fā)布到應用商店中來。本次示例我們需要安裝的是 Redis 通過在平臺管理->應?市場->開源應?商店->搜索 Redis 并進行安裝
。安裝完成后,在應用視圖->k8s資源->編寫 Component 資源
進行綁定。
apiVersion:dapr.io/v1alpha1
kind:Component
metadata:
name:pubsub
spec:
type:pubsub.redis
version:v1
metadata:
-name:"redisHost"
value:"YOUR_REDIS_HOST_HERE"
-name:"redisPassword"
value:"YOUR_REDIS_PASSWORD_HERE"
如果是 MySQL ,步驟是平臺管理->應?市場->開源應?商店->搜索 MySQL 并進行安裝
,安裝完成后在 應用視圖->k8s資源->編寫 Component 資源
進行綁定。
apiVersion:dapr.io/v1alpha1
kind:Component
metadata:
name:
spec:
type:state.mysql
version:v1
metadata:
-name:connectionString
value:""
-name:schemaName
value:""
-name:tableName
value:""
-name:pemPath
value:""
4. 切換應用治理模式
將業(yè)務應用的治理模式切換至 Dapr 。通過在 應用視圖->治理模式->選擇 Dapr 治理模式進行切換
。其中 dapr 治理模式會為我們組件的 annotations
屬性添加字段dapr.io/enabled: "true"
以及dapr.io/app-id="xxx"
其中 xxx 為組件的英文名,由于dapr.io/app-id
是Dapr 體系中的唯一標識,Rainbond 支持自行配置,如果檢測到有該屬性字段,則優(yōu)先使用原配置。滿足注入條件后,dapr-sidecar-injector 服務開始工作,為我們的業(yè)務組件注入 Daprd。
5. 部署業(yè)務
Rainbond 提供了多種方式部署你的業(yè)務,鏡像、Helm、Yaml、源碼等等。這里我選擇使用鏡像部署,具體步驟為: 應用視圖->添加組件->指定鏡像->填寫鏡像地址
。
demo鏡像地址:
registry.cn-hangzhou.aliyuncs.com/zhangqihang/pubsub-node-subscriber:latest
registry.cn-hangzhou.aliyuncs.com/zhangqihang/pubsub-react-form:latest
registry.cn-hangzhou.aliyuncs.com/zhangqihang/pubsub-go-subscriber:latest
由于 Dapr 中消息隊列需要為組件 annotations
屬性設置 dapr.io/app-port
字段,切換治理模式的時候并沒有自動生成,所以我們需要在組件視圖->其他設置->Kubernetes屬性->新增屬性->選擇 annotations->添加 dapr.io/app-port=組件端口字段
。同理其他擴展的 annotations
屬性字段均在此處配置。
6. 部署最終效果
在pubsub-react-form 組件的組件視圖->端口->打開對外服務
便可實現(xiàn)訪問消息發(fā)布組件,向訂閱 A、B、C中發(fā)布消息,通過觀察pubsub-node-subscriber
和pubsub-go-subscriber
組件的日志可看到訂閱的內(nèi)容,日志位置:組件視圖->日志
。
7. 通過Dapr控制臺管理
訪問 dapr dashboard 可以查看到我們的微服務組件在 Dapr 中的注冊信息。

8.發(fā)布應用模版
Rainbond提供應用一鍵發(fā)布應用模版的能力,在Dapr開發(fā)應用的應用視圖,點擊發(fā)布
來發(fā)布應用模版,并通過應用模版在線和離線快速安裝到其他環(huán)境。不過在其他環(huán)境使用時需要先安裝Rainbond和Dapr基礎環(huán)境。
在Rainbond上擴展Dapr
鏈路追蹤
鏈路追蹤是一種網(wǎng)絡監(jiān)控和故障排除技術,用于追蹤數(shù)據(jù)包在網(wǎng)絡中的路徑和經(jīng)過的節(jié)點,以便優(yōu)化網(wǎng)絡性能和發(fā)現(xiàn)問題,在 Dapr 中是通過配置Configuration資源
綁定追蹤器實現(xiàn)進行工作的。下面是以 Zipkin 追蹤器實現(xiàn)的Configuration
資源配置示例。更多詳見 Dapr Observability[1]。
在應用視圖->k8s資源->編寫 Configuration 資源
apiVersion:dapr.io/v1alpha1
kind:Configuration
metadata:
name:daprConfig
namespace:default
spec:
tracing:
samplingRate:"1"
zipkin:
endpointAddress:"http://localhost:9411/api/v2/spans"
熔斷限流
限制每秒允許的最大 HTTP 請求數(shù),速率限制可以保護您的應用程序免受拒絕服務 (DOS) 攻擊。我們需要配置component
資源作為中間件,然后通過Configuration 資源
進行綁定,然后在業(yè)務組件中配置掛載使用。
在應用視圖->k8s資源->編寫 Component 資源
作為中間件,設置每秒的最大請求數(shù)為 10。
apiVersion:dapr.io/v1alpha1
kind:Component
metadata:
name:ratelimit
spec:
type:middleware.http.ratelimit
version:v1
metadata:
-name:maxRequestsPerSecond
value:10
在應用視圖->k8s資源->編寫 Configuration 配置資源
綁定中間件。
apiVersion:dapr.io/v1alpha1
kind:Configuration
metadata:
name:appconfig
spec:
httpPipeline:
handlers:
-name:ratelimit
type:middleware.http.ratelimit
在組件視圖->其他設置->Kubernetes屬性->新增屬性->選擇annotations->添加 dapr.io/config 屬性字段
綁定 Configuration 。
審核編輯 :李倩
聲明:本文內(nèi)容及配圖由入駐作者撰寫或者入駐合作網(wǎng)站授權轉載。文章觀點僅代表作者本人,不代表電子發(fā)燒友網(wǎng)立場。文章及其配圖僅供工程師學習之用,如有內(nèi)容侵權或者其他違規(guī)問題,請聯(lián)系本站處理。
舉報投訴
-
模塊化
+關注
關注
0
文章
340
瀏覽量
21990
-
微服務
+關注
關注
0
文章
145
瀏覽量
7742
-
云原生
+關注
關注
0
文章
261
瀏覽量
8272
原文標題:Dapr和Rainbond集成,實現(xiàn)云原生BaaS和模塊化微服務開發(fā)
文章出處:【微信號:OSC開源社區(qū),微信公眾號:OSC開源社區(qū)】歡迎添加關注!文章轉載請注明出處。
發(fā)布評論請先 登錄
相關推薦
熱點推薦
新品推薦|模塊化集成式高速連接器
LRM連接器隨著電子技術的快速發(fā)展,在電力傳輸、工業(yè)自動化、航空航天等領域,對高效、穩(wěn)定、可靠的電氣連接解決方案的需求日益增長。因此日晟萬晟開發(fā)了新一代模塊化集成式高速連接器-LRM系
云原生環(huán)境里Nginx的故障排查思路
本文聚焦于云原生環(huán)境下Nginx的故障排查思路。隨著云原生技術的廣泛應用,Nginx作為常用的高性能Web服務器和反向代理服務器,在容器化和
Snap Store開發(fā)者工具圖譜:從全棧到云原生,一張圖解鎖Linux開發(fā)新姿勢!
PyCharm+Postman構建微服務,還是云原生新人嘗試Kubectl+Helm馴服K8s,SnapStore早已備好全套裝備。本文作為《UbuntuSnap》系列的第三彈
云原生AI服務怎么樣
云原生AI服務,是指采用云原生的原則和技術來構建、部署和管理人工智能應用及工作負載的方法和模式。那么,云原生AI服務怎么樣呢?下面,AI部落
微服務容器化部署好處多嗎?
微服務容器化部署好處有很多,包括環(huán)境一致性、資源高效利用、快速部署與啟動、隔離性與安全性、版本控制與回滾以及持續(xù)集成與持續(xù)部署。這些優(yōu)勢助力應用可靠穩(wěn)定運行,提升開發(fā)運維效率,是現(xiàn)代軟
云原生LLMOps平臺作用
云原生LLMOps平臺是一種基于云計算基礎設施和開發(fā)工具,專門用于構建、部署和管理大型語言模型(LLM)全生命周期的平臺。以下,是對云原生LLMOps平臺作用的梳理,由AI部落小編整理。
如何選擇云原生機器學習平臺
當今,云原生機器學習平臺因其彈性擴展、高效部署、低成本運營等優(yōu)勢,逐漸成為企業(yè)構建和部署機器學習應用的首選。然而,市場上的云原生機器學習平臺種類繁多,功能各異,如何選擇云原生機器學習平臺呢?下面,AI部落小編帶您探討。
什么是云原生MLOps平臺
云原生MLOps平臺,是指利用云計算的基礎設施和開發(fā)工具,來構建、部署和管理機器學習模型的全生命周期的平臺。以下,是對云原生MLOps平臺的介紹,由AI部落小編整理。
模塊化儀器的技術原理和應用場景
輸入/輸出通道,或者根據(jù)特定應用定制其測量能力。
計算機集成:模塊化儀器與計算機高度集成,通過共享元器件、高速總線和用戶定義的開放式軟件,實現(xiàn)自動化
發(fā)表于 11-28 15:09
k8s微服務架構就是云原生嗎?兩者是什么關系
k8s微服務架構就是云原生嗎?K8s微服務架構并不等同于云原生,但兩者之間存在密切的聯(lián)系。Kubernetes在云原生架構中扮演著核心組件的
入門級攻略:如何容器化部署微服務?
第一步理解容器化基礎,第二步創(chuàng)建Dockerfile,第三步構建推送鏡像,第四步部署微服務,第五步管理微服務、第六步優(yōu)化更新。容器化部署微服務
云原生和非云原生哪個好?六大區(qū)別詳細對比
云原生和非云原生各有優(yōu)劣,具體選擇取決于應用場景。云原生利用云計算的優(yōu)勢,通過微服務、容器化和自動化
京東云原生安全產(chǎn)品重磅發(fā)布
“安全產(chǎn)品那么多,我怎么知道防住了?”“大家都說自己是云原生的,我看都是換湯不換藥”在與客戶溝通云原生安全方案的時候,經(jīng)常會遇到這樣的吐槽。越來越的客戶已經(jīng)開始了云原生化的技術架構改造,也意識到
從積木式到裝配式云原生安全
云原生安全風險 隨著云原生架構的快速發(fā)展,核心能力逐漸穩(wěn)定,安全問題日趨緊急。在云原生安全領域不但有新技術帶來的新風險,傳統(tǒng)IT基礎設施下的安全威脅也依然存在。要想做好云原生安全,就要
基于DPU與SmartNic的云原生SDN解決方案
個輕量級,可移植的運行環(huán)境,逐漸成為云原生時代基礎設施的事實標準。Kubernetes通過網(wǎng)絡插件(CNI,Container Network Interface)實現(xiàn)靈活地配置和管理集群中的容器網(wǎng)絡,確保容器之間的有效通信和網(wǎng)絡安全。
評論