.NetCore集成Dapr踩坑经历
该篇内容由个人博客点击跳转同步更新!转载请注明出处
前言
之前自己有个core2.2的项目一直是用的Surging作为微服务框架的,后来了解到了Dapr,发现比较轻量级,而且像微服务的一些功能比如熔断啥的也用不到,开发部署等也非常方便,故将自己的程序升级到了3.0同时框架改成了Dapr,网上查到的好多Dapr文章基本都是大差不同,大都是用的GIT上的示例或者是直接文章翻译很少有提到实战上的一些问题,下面我把我自己遇到的一些问题和解决方法记录一下同时大致讲下安装集成步骤。
前期准备
- 安装 Docker(dapr安装完后会在Docker中生成两个容器Dapr_redis和Dapr_placement)
- 安装 Dapr CLI(用于使用Dapr的一些命令)
- 安装 .Net Core SDK 3.0(Dapr只能用于3.0的程序中)
- 下载dotnet-sdk(Nuget上暂时只有预览版,所以直接用源码集成方便源码调试)
注意:安装dapr cli的时候他会让你用 一段powershell脚本安装,但由于国内墙的问题使用不了所以需要xxxxemmmm,另一个办法就是直接去release下载文件https://github.com/dapr/cli/releases
具体安装命令步骤啥的不说了,链接点击过去都有介绍
大致集成步骤
具体的如何集成和配置网上都有大家可以看下这篇GIT上的集成步骤,我这里直接给大家看下我示例程序的项目结构重要的内容会写在括号里

- Clients目录下都是用于调用服务的客户端(这里都是通过ActorProxy的RPC方式调用,有点像SF、akka.net和Orleans,都引用下面的Service_Interfaces)
- Dapr目录下就是上面下载的Dapr源代码
- CSRedisCore我项目里面用到了Redis所以把CSRedisCore的源代码下载了下来
- Service_Infrastructure 服务的基础设施存放一些通用的东西或者帮助类
- Service_Interfaces服务的接口都在这里(引用Dapr.Actors)
- Service_Models服务和客户端用到的模型都在这
- Service_Webapi为客户端提供服务(引用Dapr.Actors和Dapr.Actors.AspNetCore)
具体项目依赖如下图

错误内容和解决方法
由于目标计算机积极拒绝,无法连接。
ERROR: DaprHttpInteractor: System.Net.Http.HttpRequestException: 由于目标计算机积极拒绝,无法连接。
---> System.Net.Sockets.SocketException (10061): 由于目标计算机积极拒绝,无法连接。
这是由于dotnet-sdk默认调用的端口是3500但你通过Darp运行的程序端口是随机的所以运行的时候需要指定一个端口通过 -port xx,例如:
dapr run --port 3500 --app-id demo_actor --app-port 5000 dotnet run
或者通过指定程序调用的端口通过设置DAPR_HTTP_PORT的环境变量来指定程序调用端口
ERR_INVOKE_ACTOR
Error converting value "ERR_INVOKE_ACTOR" to type 'System.Nullable
这是由于作者在程序中少写了这个状态应该算个bug我提交了issue但还没回我,具体的在DaprErrorCodes文件中最后加一下就行

Actor服务中如何使用依赖注入
对于这个问题有两个解决方法:
- 默认的服务实现中构造函数只能有两个参数ActorService和ActorId,但是它在注册的时候提供了另一个构造方法,比如我的一个redis服务构造函数是这样的,里面iredisprovider需要通过注入来获取

可以在注册actor的时候提供你所需要的东西,如下
public static IWebHostBuilder CreateHostBuilder(string[] args)=>
WebHost.CreateDefaultBuilder(args)
.UseStartup<Startup>()
.UseActors(actorRuntime =>
{
//重点
actorRuntime.RegisterActor<RedisCachesService>((type) => new ActorService(type, (actorService, actorId) => new RedisCachesService(new RedisProvider(),actorService, actorId)));
})
.UseUrls($"http://localhost:{5000}/");
- 第一个方法有局限性,和自己new对象没啥区别。所以这里推荐自己实现一个ServiceLocator用来获取所需要的服务,简单写一下用法,定义一个ServiceLocator类
public class ServiceLocator
{
public static IServiceProvider Current { get; set; }
}
在startup > configure 中赋值
public void Configure(IApplicationBuilder app, IWebHostEnvironment env)
{
ServiceLocator.Current = app.ApplicationServices;
if (env.IsDevelopment())
{
app.UseDeveloperExceptionPage();
}
app.UseHsts();
}
在Actor服务中使用
public RedisCachesService(ActorService actorService, ActorId actorId) : base(actorService, actorId)
{
using (var scoped=ServiceLocator.Current.CreateScope())
{
_cr = scoped.ServiceProvider.GetService<IRedisProvider>().GetInstance();
}
}
需要注意的点
1.Actor服务中的每个方法最多只能有一个参数,多个参数的话都变成写成一个实体进行传递,不然会报错

2. Dapr提供了一个可视化界面 dashboard 这个暂时有点问题,谷歌打不开,但edge可以,貌似是Angular的BUG,所以推荐大家暂时不要用,因为功能很少不如直接dapr cli方便
结语
大致的问题就如上面这些,但我记得还有几个隔了一天年纪太大忘光了,后续有新问题我会继续更新。不要问我dapr和其它微服务框架比效率性能哪个好,我也没试过。这玩意儿既然是微软开源的我想也不会太差,而且有专业的团队维护,不出太大意外我想发展肯定是越来越好的。
微信关注我哦!(转载注明出处)
.NetCore集成Dapr踩坑经历的更多相关文章
- 『审慎』.Net4.6 Task 异步函数 比 同步函数 慢5倍 踩坑经历
异步Task简单介绍 本标题有点 哗众取宠,各位都别介意(不排除个人技术能力问题) —— 接下来:我将会用一个小Demo 把 本文思想阐述清楚. .Net 4.0 就有了 Task 函数 —— 异步编 ...
- TiDB 深度实践之旅--真实“踩坑”经历
美团点评 TiDB 深度实践之旅(9000 字长文 / 真实“踩坑”经历) 4 PingCAP · 154 天前 · 3956 次点击 这是一个创建于 154 天前的主题,其中的信息可能已经有所发 ...
- Net4.6 Task 异步函数 比 同步函数 慢5倍 踩坑经历
Net4.6 Task 异步函数 比 同步函数 慢5倍 踩坑经历 https://www.cnblogs.com/shuxiaolong/p/DotNet_Task_BUG.html 异步Task简单 ...
- HDP 3.1.0 集成 Sqoop2 踩坑问题记录
HDP 3.1.0 集成 Sqoop2 踩坑问题记录 本文原始地址:https://sitoi.cn/posts/65261.html 问题一 $ sqoop:000> start job -n ...
- myeclipse使用db-brower连接到sqlserver2012踩坑经历
myeclipse使用db-brower连接到sqlserver踩坑经历 首先得建立个角色 右键->创建登录名 权限开大点 连接设置 Driver template选择我选这个,格式按照我的写 ...
- sqlserver安装和踩坑经历
sqlserver安装和踩坑经历 下载 下载 安装 大致是按照这个来的 安装教程 出错 windows系统安装软件弹出"Windows installer service could not ...
- Dubbo 服务 IP 注册错误踩坑经历
个人博客地址 studyidea.cn,点击查看更多原创文章 踩坑 公司最近新建一个机房,需要将现有系统同步部署到新机房,部署完成之后,两地机房同时对提供服务.系统架构如下图: 这个系统当前对外采用 ...
- 使用BeanUtils.copyProperties踩坑经历
1. 原始转换 提起对象转换,每个程序员都不陌生,比如项目中经常涉及到的DO.DTO.VO之间的转换,举个例子,假设现在有个OrderDTO,定义如下所示: public class OrderDTO ...
- nginx搭建网站踩坑经历
为了更好的阅读体验,请访问我的个人博客 前言 早上刷抖音刷到一个只需要三步的nginx搭建教程(视频地址),觉得有些离谱,跟着复现了一遍,果然很多地方不严谨并且省略了大量步骤,对于很多不了解linux ...
随机推荐
- @atcoder - CODE FESTIVAL 2017 Final - J@ Tree MST
目录 @description@ @solution@ @accepted code@ @details@ @description@ 给定 N 个点,第 i 点有一个点权 Xi,再给定一棵边带权的树 ...
- 在SAE上使用Flask插件
因为我之前学习的时候使用的是虚拟环境,下载的所有需要用到的插件都在flask这个文件夹里面,SAE上Flask的版本和我本地用的版本对不上,导致有时候import都不对,于是我就把本地的环境直接放到S ...
- python 自动识别黄图
from watchdog.observers import Observerfrom watchdog.events import *import timeimport sysimport osim ...
- MySQL_分库分表
分库分表 数据切分 通过某种特定的条件,将我们存放在同一个数据库中的数据分散存放到多个数据库(主机)上面,以达到分散单台设备负载的效果.数据的切分同时还能够提高系统的总体可用性,由于单台设备Crash ...
- PyTorch代码调试利器: 自动print每行代码的Tensor信息
本文介绍一个用于 PyTorch 代码的实用工具 TorchSnooper.作者是TorchSnooper的作者,也是PyTorch开发者之一. GitHub 项目地址: https://github ...
- 【[Offer收割]编程练习赛9 B】水陆距离
[题目链接]:http://hihocoder.com/problemset/problem/1478 [题意] [题解] 一开始把所有的水域的位置都加入到队列中去; 然后跑一个bfs. 第一次到达的 ...
- hdu 3873 Invade the Mars(有限制的最短路 spfa+容器)
Invade the Mars Time Limit: 5000/2000 MS (Java/Others) Memory Limit: 365768/165536 K (Java/Others ...
- JQuery---高级选择器
一.派生选择器 例如:$('#bavBar a') 二.孩子选择器 例如:$('body > p') 三.相邻兄弟选择器 例如:$('h2 + div') 四.属性选择器 1.$('img[a ...
- oracle的group by用法
原文链接:https://www.cnblogs.com/Each-Person-Got-a-Dream/p/8946961.html sql如下: select min(es.sku_price) ...
- H3C 802.11协议的发展
