.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 ...
随机推荐
- [软考]之软件过程模型II 标签: 软件工程 2015-11-01 11:52 1612人阅读 评论(22) 收
上一篇博客总结了瀑布模型/V模型/增量模型这三种软件模型,然而我们还有一个很重要的问题忘了回答,那就是,什么是软件过程模型? 什么是软件过程模型? 软件过程是软件开发与维护的工作流程和工艺流程,是软件 ...
- j2se--异常机制
版权声明:本文为博主原创文章,未经博主同意不得转载. https://blog.csdn.net/quwenzhe/article/details/35610853 java异常机制中主要包含一个 ...
- LA 4119 Always an integer (数论+模拟)
ACM-ICPC Live Archive 一道模拟题,题意是问一个给出的多项式代入正整数得到的值是否总是整数. 这题是一道数论题,其实对于这个式子,我们只要计算1~最高次项是否都满足即可. 做的时候 ...
- 异常解决:non-compatible bean definition of same name and class【com.xxx.xxx.XXX】
昨天同事遇到这样一个问题,意思是spring找到 有相同的实现类名在不同的package目录下. 跟踪他的项目代码并未发现问题. 重新给他的maven项目进行maven install一下. 查看 ...
- LRJ-Example-06-12-Uva572
#define _CRT_SECURE_NO_WARNINGS #include <cstdio> #include <cstring> #include <string ...
- ArrayList存储基本类型时的封装类
- hdu 1599 find the mincost route(无向图的最小环)
find the mincost route Time Limit: 1000/2000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/O ...
- Java Annotation详解(一): 理解和使用Annotation
JDK1.5之后,引入了元数据的概念,也就是Annotation(注释),其实它是代码里的特殊标记,这些标记可以再编译.类加载.运行时被读取,并执行相应的处理. 元数据的作用: 如果要对于元数据的作用 ...
- js常见错误类型及chrome常见报错(更新中)
ECMA-262 定义了下列 7 种错误类型: 1.Error 错误 2.EvalError 全局错误 eval函数没有正确执行 3.RangeError 范围错误 4.ReferenceError ...
- Mysql5.7在忘记密码的情况下如何修改密码?
1.停止服务 2.mysqld --skip-grant-tables 3.回车之后就不要动了,再新打开一个命令提示符窗口,同样进入mysql的安装目录下, 输入:mysql -u root -p 密 ...
