dapr入门与本地托管模式尝试

news2025/1/4 19:24:10

1 简介

Dapr是一个可移植的、事件驱动的运行时,它使任何开发人员能够轻松构建出弹性的、无状态和有状态的应用程序,并可运行在云平台或边缘计算中,它同时也支持多种编程语言和开发框架。Dapr支持的语言很多,包括C++/Go/Java/JavaScript/Python/Rust/.NET/PHP等。

目前,可用的构建块如下:

构建块说明
服务调用跨服务调用允许进行远程方法调用(包括重试),不管处于任何位置,只需该服务托管于受支持的环境即可。
状态管理独立的状态管理,使用键/值对作为存储机制,可以轻松的使长时运行、高可用的有状态服务和无状态服务共同运行在您的应用程序中。 状态存储是可插拔的,目前支持使用Azure CosmosDB、 Azure SQL Server、 PostgreSQL、AWS DynamoDB、Redis 作为状态存储介质。
发布订阅发布事件和订阅主题。
资源绑定Dapr的Bindings是建立在事件驱动架构的基础之上的。通过建立触发器与资源的绑定,可以从任何外部源(例如数据库,队列,文件系统等)接收和发送事件,而无需借助消息队列,即可实现灵活的业务场景。
ActorsActor模型 = 状态 + 行为 + 消息。一个应用/服务由多个Actor组成,每个Actor都是一个独立的运行单元,拥有隔离的运行空间,在隔离的空间内,其有独立的状态和行为,不被外界干预,Actor之间通过消息进行交互,而同一时刻,每个Actor只能被单个线程执行,这样既有效避免了数据共享和并发问题,又确保了应用的伸缩性。 Dapr 在Actor模式中提供了很多功能,包括并发,状态管理,用于 actor 激活/停用的生命周期管理,以及唤醒 actor 的计时器和提醒器。
可观测性Dapr记录指标,日志,链路以调试和监视Dapr和用户应用的运行状况。 Dapr支持分布式跟踪,其使用W3C跟踪上下文标准和开放式遥测技术,可以轻松地诊断在生产环境中服务间的网络调用,并发送到不同的监视工具。
秘密Dapr 提供了密钥管理,支持与公有云和本地的Secret存储集成,以供应用检索使用。

Sidecar与托管

Dapr是以Sidecar的架构模式来提供对应功能的,这也是Kubernetes中很常用的一种模式:

Dapr可以自托管,也可以托管在Kubernetes上,一般我们都会托管在Kubernetes上。

Dapr不是服务网格,它们有重叠的部分,也有各自独特的地方,具体如何选择,还要看具体需求。实际上是可以整合在一起使用的。

2 dapr本地安装

2.1 下载

我们直接从Github下载:https://github.com/dapr/cli/releases ,解压对某个目录,然后添加到环境变量即可:

export PATH=$PATH:/Users/larry/Software/dapr

测试一下,查看版本:

$ dapr --version
CLI version: 1.9.1 
Runtime version: n/a

2.2 在本地环境初始化dapr

首先要确保已经安装了Docker,并成功启动。

$ docker --version
Docker version 19.03.13, build 4484c46d9d

接着执行以下命令进行初始化:

$ dapr init
⌛  Making the jump to hyperspace...
ℹ️  Container images will be pulled from Docker Hub
ℹ️  Installing runtime version 1.9.3
↘  Downloading binaries and setting up components... 
Dapr runtime installed to /Users/larry/.dapr/bin, you may run the following to add it to your path if you want to run daprd directly:
    export PATH=$PATH:/Users/larry/.dapr/bin                                                                                 ✅  Downloading binaries and setting up components...
✅  Downloaded binaries and completed components set up.
ℹ️  daprd binary has been installed to /Users/larry/.dapr/bin.
ℹ️  dapr_placement container is running.
ℹ️  dapr_redis container is running.
ℹ️  dapr_zipkin container is running.
ℹ️  Use `docker ps` to check running containers.
✅  Success! Dapr is up and running. To get started, go here: https://aka.ms/dapr-getting-started

注意会在用户目录.dapr安装对应的文件。这时再查看version信息就不一样了:

$ dapr --version
CLI version: 1.9.1 
Runtime version: 1.9.3

查看Docker容器情况,也看到启动了多个实例:

$ docker ps
CONTAINER ID        IMAGE               COMMAND                  CREATED             STATUS                   PORTS                              NAMES
110165beae0d        daprio/dapr:1.9.3   "./placement"            2 minutes ago       Up 2 minutes             0.0.0.0:50005->50005/tcp           dapr_placement
346be0cdcb7e        redis:6             "docker-entrypoint.s…"   3 minutes ago       Up 3 minutes             0.0.0.0:6379->6379/tcp             dapr_redis
42a8279db947        openzipkin/zipkin   "start-zipkin"           3 minutes ago       Up 3 minutes (healthy)   9410/tcp, 0.0.0.0:9411->9411/tcp   dapr_zipkin

3 尝试一下dapr

3.1 启动一个应用

启动一个空白的应用如下,同时也会启动一个Sidecar,并启用3500端口:

dapr run --app-id myapp --dapr-http-port 3500

3.2 状态管理

我们刚才开启了3500端口,接下来可以更新状态,如下:

$ curl -X POST -H "Content-Type: application/json" -d '[{ "key": "name", "value": "Larry Deng"}]' http://localhost:3500/v1.0/state/statestore
$ curl -X POST -H "Content-Type: application/json" -d '[{ "key": "webSite", "value": "www.pkslow.com"}]' http://localhost:3500/v1.0/state/statestore

查看状态:

$ curl http://localhost:3500/v1.0/state/statestore/name
"Larry Deng"

$ curl http://localhost:3500/v1.0/state/statestore/webSite
"www.pkslow.com" 

因为状态是通过Redis来保存的,我们可以直接进去Redis查看:

$ docker exec -it dapr_redis redis-cli
127.0.0.1:6379> keys *
1) "myapp||name"
2) "myapp||webSite"
127.0.0.1:6379> hgetall "myapp||name"
1) "data"
2) "\"Larry Deng\""
3) "version"
4) "1"
127.0.0.1:6379> hgetall "myapp||webSite"
1) "data"
2) "\"www.pkslow.com\""
3) "version"
4) "1"
127.0.0.1:6379> exit

删除测使用以下接口:

curl -v -X DELETE -H "Content-Type: application/json" http://localhost:3500/v1.0/state/statestore/name

3.3 dapr dashboard

Dapr为大家提供了管理界面,以下命令来启动:

$ dapr dashboard
Dapr Dashboard running on http://localhost:8080

打开界面,可以看到我们刚才启动的Application:

还能查看一些组件、配置等信息:

我们还可以查看一些Tracing方面的信息,打开:http://localhost:9411/zipkin/

4 总结

因为本次实验只是一个本地版本的dapr,所以还有很多功能没有体验,我们后续有机会再继续学习。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/194378.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

antv/x6 2.x 搭建流程图编辑页面(1)

进来闲来无事,看到x6 2.x版本也更新了有几个月了,便想着熟悉下2.x版本 一、首先搭建项目基础框架。 // yarn 方式 yarn create vitejs/app v3-ts --template vue-ts cd v3-ts yarn yarn dev// npm npm init vitejs/app v3-ts --template vue-ts cd v3…

人工神经网络BP神经网络结构及优化原理单隐层,多隐层及反向传播梯度下降释义

神经网络:人工神经网络(Artificial Neural Networks,简写为ANNs)也简称为神经网络(NNs)或称作连接模型(Connection Model),它是一种模仿动物神经网络行为特征&#xff0c…

ASEMI整流模块MDA110-16参数,MDA110-16规格

编辑-Z ASEMI整流模块MDA110-16参数: 型号:MDA110-16 最大重复峰值反向电压(VRRM):1600V 最大RMS电桥输入电压(VRMS):1700V 最大平均正向整流输出电流(IF&#xff0…

多线程synchronized对象锁与静态锁之间的8锁问题理解

目录8锁问题锁1:多个线程使用同一对象分别调用不同带有带synchronized关键字且非静态的方法锁2:在锁1基础上,增加A线程执行的方法的执行时间,使得B有机会参与执行锁3:多个线程使用同一对象,一个线程执行带有…

三菱Q系列QJ71C24N模块 MODBUS通信(含完整步骤+源代码)

MODBUS通信的其它相关基础知识请参看下面的文章链接: SMART S7-200PLC MODBUS通信_RXXW_Dor的博客-CSDN博客MODBUS 是 OSI 模型第 7 层上的应用层报文传输协议,它在连接至不同类型总线或网络的设备之间提供客户机/服务器通信。自从 1979 年出现工业串行链路的事实标准以来,…

7z压缩包有可能被破解吗,需要多久,暴力穷举和字典破解分别的速度分析

开门见山,我看到网上有很多此类软件,功能就是来破解7zip格式的压缩包,但都没有认真进行测试,这里认真进行判断和测试 首先,目前世界最快的计算机为Frontier,算力1,685.65 PFlop/s。目前最高的算力为全网比…

【IoT】智能小产品:简易电子琴设计

说明 随着电子技术的发展,电子技术正在逐渐改善着人们的学习、生活、工作,因此开发本系统希望能够给人们多带来一点生活上的乐趣,电子技术与音乐的结合不断加深。 由此而产生的电子琴在这种形势下,因其体积小,易于携…

芯科EFRBG22C112 empty工程创建

目录 1.使用工具 2.创建工程 2.1进入welcome,选择芯片,点击start ​编辑 2.2选择sdk4.2.0版本 2.3点击Create New Project 2.4同步步骤创建引导程序bootloader-apploader 3.遇到问题 1.使用工具 ARM仿真器 EFR32BG22C112芯片开发板 pc 使用ARM仿真器连接BG22…

PMP考试多少分算通过?

PMP 是没有具体分数的,只有等级, PASS 就是通过了这张成绩单就是 PASS,3A。主要看头部这里,PASS 就是通过了,FAIL 就是没通过。至于说的 3A,2A1T 啥的,是对应的每个模块的成绩,PMP 的…

【leetcode - 基础】编程能力( 4 / 20天 )

目录 Day - 1 896. 单调数列 - 简单ac 28. 找出字符串中第一个匹配项的下标 - KMP 1、kmp模板 2、java api Day - 2 110. 平衡二叉树 - 递归 1、自顶向下 - 暴力 459. 重复的子字符串 - 暴力 Day - 3 150. 逆波兰表达式求值 - 栈 后缀表达式 66.加一 - 模拟 Day…

Tensorflow 基础与实战

目录 一、线性回归实现 1.1 数据加载与查看绘图 1.2 模型建立、训练与预测 二、神经网络实现 2.1 数据加载与查看绘图 2.2 模型建立、训练与预测 三、逻辑回归实现 3.1 数据加载与查看绘图 3.2 模型建立、训练与预测 四、softmax分类 4.1 数据加载 4.2 数据归一化 …

ReadyAPI x64bit 3.43.0 Crack

ReadyAPI 允许团队在一个集中的界面中创建、管理和执行自动化的功能、安全和性能测试——为敏捷和 DevOps 软件团队提高 API 质量。 ReadyAPI 在单一平台上提供三个模块: 在ReadyAPI 测试模块中,您创建功能测试以验证您的服务是否按预期工作。您可以使用…

高频数组算法

1.二分查找 给定一个 n 个元素有序的(升序)整型数组 nums 和一个目标值 target ,写一个函数搜索 nums 中的 target,如果目标值存在返回下标,否则返回 -1。 示例 1: 输入: nums [-1,0,3,5,9,12], target 9 输…

程序员的职业生涯个人规划(附上学习资料)

目录 前言 1.程序员的规划 2.程序员的进化路径 3.IT行业的难度 4.你的选择 5.再谈谈资本、工具人和内卷 总结: 前言 今天不讲技术也不讲干货,来聊一聊程序员职业生涯的个人规划。希望对不管是想入门的还是已经在这条路上的朋友能有一个帮助。 1.程…

opencv之直方图绘制及均衡化

直方图均衡化优势:增强图像对比度,使对比度较低的局部区域获得高对比度。当图像非常暗或者非常亮,并且背景和前景之间的差异非常小时,此方法非常有效,能够解决暴露过度或暴露不足的问题。直方图均衡化缺陷:…

多彩的书写工具,画图写字更好看,米家液晶小黑板多彩版上手

平时临时记些信息,或者是教小朋友认字的时候,液晶小黑板都是特别实用的工具,我之前就用过米家液晶小黑板,最近我发现米家新出了一款彩色笔迹的小黑板,书写效果更加好看,比以前单色款的更好用。 这款米家液晶…

【技术分享】MA21日均线交易策略

文章目录1.前言1.1.相关术语1.2.MA均线系统设置分类1.3.斐波那契数列2.MA21日均线2.1.MA21日均线2.2.MA21日均线交易策略2.3.MA21日均线案例分析1.前言 1.1.相关术语 空头市场(Bear Market):亦称熊市,指价格长期呈 下跌 趋势的证…

操作系统权限提升(十)之系统错误配置-计划任务提权

系列文章 操作系统权限提升(一)之操作系统权限介绍 操作系统权限提升(二)之常见提权的环境介绍 操作系统权限提升(三)之Windows系统内核溢出漏洞提权 操作系统权限提升(四)之系统错误配置-Tusted Service Paths提权 操作系统权限提升(五)之系统错误配置-PATH环境变量提权 操作…

VUE3.0学习

一、父子传值 父组件向子组件传值和vue2.0相比区别不大&#xff0c;区别在于api的使用&#xff0c;让接收参数的写法多样化。父组件::::: <template><div class"about"><div><main><TheWelcome :info"parMsg"/></main>…

【react】理解Fiber

FiberFiber概念结构Fiber 树的遍历是这样发生的【深度遍历】。window.requestIdleCallback()requestAnimationFrameFiber 是如何工作的结论有react fiber&#xff0c;为什么不需要vue fiberFiber 概念 JavaScript引擎和页面渲染引擎两个线程是互斥的&#xff0c;当其中一个线…