ABP多库支持

ABP支持多库的方案在abp的案例中aspnetboilerplate-samples中给了现成的demo,其中MultipleDbContextDemo是EF的相关针对dotnet的版本,MultipleDbContextEfCoreDemo则是dotnet core版本的多库方案

按照改demo的思路,添加我们的abp的多库支持,F5直接允许,一切ok,欣慰,没有报错。

按照业务要求,完成代码一切美美哒。

ABP多库发布后异常

发布正式环境,请求访问第二个数据库的相关接口,抛出“应用程序内部错误的异常”

查看唯一App_Data目录下的日志文件 发现抛出异常,“Could not find content root folder”

然后就是各种bing,百度,google一通搜,没有找到结果。

问题查找调试

本地发布了一个和正式环境一样的环境,手动去调试一下,想追到是什么地方抛出来的,找到我们应用的进程(dotnet core下不是W3W了,而是你应用的dll名称)。附加到进程,发现我擦怎么进不了断点,换个接口试一下,发现依旧进不来断点。

测试发现附加的时候比之前多了一个选择,有个coreCLR的选择如下图,不知道这个玩意是什么鬼,先去掉吧,点击选择,选中“自动选择要调试的代码类型”。然后再来附加,进断点了,为啥呢,没有深究!

接下来继续排除我们的多库报错问题

跟代码发现异常是从Core下面的WebContentDirectoryFinder.cs抛出来的,如下图

找到问题源头了,我们就看怎么怎么解决,看一下当前代码干了什么事情。

public static string CalculateContentRootFolder()
{
var coreAssemblyDirectoryPath = Path.GetDirectoryName(typeof(AiCoreModule).GetAssembly().Location);
if (coreAssemblyDirectoryPath == null)
{
throw new Exception("Could not find location of Chemical.Ai.Core assembly!");
} DirectoryInfo directoryInfo = new DirectoryInfo(coreAssemblyDirectoryPath);
while (!DirectoryContains(directoryInfo.FullName, "Chemical.Ai.sln"))
{
//发布状态下,应该为当前目录
if (directoryInfo.Parent == null)
{
return coreAssemblyDirectoryPath;
//throw new Exception($"Could not find content root folder!");
} directoryInfo = directoryInfo.Parent;
} var webMvcFolder = Path.Combine(directoryInfo.FullName, "src", "Chemical.Ai.Web.Mvc");
if (Directory.Exists(webMvcFolder))
{
return webMvcFolder;
} var webHostFolder = Path.Combine(directoryInfo.FullName, "src", "Chemical.Ai.Web.Host");
if (Directory.Exists(webHostFolder))
{
return webHostFolder;
} throw new Exception("Could not find root folder of the web project!");
} private static bool DirectoryContains(string directory, string fileName)
{
return Directory.GetFiles(directory).Any(filePath => string.Equals(Path.GetFileName(filePath), fileName));
}

代码翻译:当前代码就是从dll的所在目录一层层找,直到找到解决方案文件所在的目录,然后将解决方案所在的目录的上层目录(A)返回给下面的逻辑使用。而下面的逻辑就是从上层目录A开始往下找到src下面的mvc或者host目录,

也就是我们的应用启动目录,返回appsettings.json所在的目录。

异常原因:在F5的调试状态下,appsettings.json是位于mvc或host下面的。但是当我们发布后,appsettings.json就是当前启动目录了,dll和appsettings.json是并列的级别

,我们在发布状态下,根本没有解决方案,所以根据解决方案找appsettings.json的方案行不通,也就会抛出我们看到的异常。

解决方案:发布状态下,无需如此复杂的逻辑,直接返回程序运行目录就可以了,如下图

修改完成发布,运行,异常没有了,程序完美运行!

ABP在MultipleDbContext也就是多库的场景下发布后异常“Could not find content root folder”问题处理的更多相关文章

  1. 如何使用开源库,吐在VS2013发布之前,顺便介绍下VS2013的新特性"Bootstrap"

    刚看到Visual Studio 2013 Preview - ASP.NET, MVC 5, Web API 2新功能搶先看 看了下VS2013带来的"新特性",直觉上看,除了引 ...

  2. Oracle主库归档丢失,备库日志有gap,在不重建备库的情况下,恢复备库

    本文主要描述Oracle备库日志与主库日志之间有gap,切主库这部分gap的归档日志已经删除或丢失,如何在不重建备库的情况下,恢复备库. 欢迎转载,请注明作者.出处. 作者:张正 blog:http: ...

  3. boost库在windows下的编译和使用

    因为跨平台的原因,现在要使用到boost库,boost库非常大,现在处于摸索阶段. 首先来说boost库在window下的安装和使用. 一.下载 首先从boost官方主页http://www.boos ...

  4. 如何使用开源库,吐在VS2013发布之前,顺便介绍下V2013的新特性"Bootstrap"

    如何使用开源库,吐在VS2013发布之前,顺便介绍下VS2013的新特性"Bootstrap" 刚看到Visual Studio 2013 Preview - ASP.NET, M ...

  5. C++标准库第二版笔记 3 和异常的理解 1

    C++标准库第二版笔记 3 和异常的理解 1 差错和异常(error and exception)的处理 标准异常类(exception class) 定义于 分为: 1.语言本身支持的异常 2.标准 ...

  6. wxWidgets与其他工具库的比较(下)

    2009-07-25 12:37:51   GTK+       ● GTK+的网站:www.gtk.org:     ● GTK+原本是Gimp的一个工具库,是在LGPL协议下发布的Unix系统GU ...

  7. CPPCMS库在Windows下的使用

    标题:CPPCMS库在Windows下的使用时间:2012-7作者:Kagula 环境:[1]WinXP SP3[2]VisualStudio2008 SP1[3]ZLib 1.2.7[4]PCRE ...

  8. C语言静态库与动态库(Windows下测试)

    转载于:https://zhidao.baidu.com/question/1946953913764139388.html,原文为Linux上测试,本文为在Windows上编译测试 我们通常把一些公 ...

  9. < python音频库:Windows下pydub安装配置、过程出现的问题及常用API >

    < python音频库:Windows下pydub安装配置.过程出现的问题及常用API > 背景 刚从B站上看过倒放挑战之后也想体验下,心血来潮一个晚上完成了基本的实现.其中倒放与播放部分 ...

随机推荐

  1. js错误处理Try-catch和throw

    1.try-catch语句   Try{ //可能会导致错误的代码 }catch(error){ //在错误发生时怎么处理 } 例如: try{ window.someNonexistentFunct ...

  2. 关于使用JavaMail发送邮件抛出java.lang.NoSuchMethodError: com.sun.mail.util.TraceInputStream.<init>(Ljava异常的解决方法

    我们在使用JavaMail时有可能会如下异常: Exception in thread "main" java.lang.NoSuchMethodError: com.sun.ma ...

  3. ROS开发过程中遇到:Could not find a package configuration file provided by "qt_build" with any of the following names: qt_buildConfig.cmake qt_build-config.cmake........

    最近在搭建QT开发ROS 界面的环境,遇到了很多问题,参考了很多资料,最后发现有些问题其实没有那么复杂,只是我们对整体环境还不了解,熟悉了以后你会发现有些问题就迎刃而解了. 在这个过程中,我首先新建了 ...

  4. Flask学习之一 hello world

    本人电脑环境: 系统:linux

  5. ArcGIS中的连接和关联表

    大多数数据库的设计指导方针都倾向于将数据库组织成多个表 - 每个表关注一个特定的主题 - 而非一个包含所有必要字段的大型表.设置多个表可以避免数据库中的信息发生重复,因为只会将信息在一个表中存储一次. ...

  6. 威胁快报|新兴挖矿团伙借助shodan作恶,非web应用安全再鸣警钟

    近日,阿里云安全发现了一个使用未授权访问漏洞部署恶意Docker镜像进行挖矿的僵尸网络团伙.我们给这一团伙取名为Xulu,因为该团伙使用这个字符串作为挖矿时的用户名. Xulu并不是第一个攻击Dock ...

  7. @bzoj - 4381@ [POI2015] Odwiedziny

    目录 @description@ @solution@ @accepted code@ @details@ @description@ 给定一棵 n 个点的树,树上每条边的长度都为 1 ,第 i 个点 ...

  8. 独家 | TensorFlow 2.0将把Eager Execution变为默认执行模式,你该转向动态计算图了

    机器之心报道 作者:邱陆陆 8 月中旬,谷歌大脑成员 Martin Wicke 在一封公开邮件中宣布,新版本开源框架——TensorFlow 2.0 预览版将在年底之前正式发布.今日,在上海谷歌开发者 ...

  9. OpenStack组件系列☞glance搭建

    第一步:glance关于数据库的操作 mysql -u root -p #登入数据库 CREATE DATABASE glance; #新建库keystone GRANT ALL PRIVILEGES ...

  10. jvm内存监控

    jstack -- 如果java程序崩溃生成core文件,jstack工具可以用来获得core文件的java stack和native stack的信息,从而可以轻松地知道java程序是如何崩溃和在程 ...