asp.net core api 健康检查

时间:2021-01-07 17:28:56

标签: asp.net-core health-check

我正在向我的 netcore 网站添加一些健康检查。其中之一是检查连接字符串是否指向已激活内存表支持的数据库(基本上,如果文件组是使用 CONTAINS MEMORY_OPTIMIZED_DATA 标志创建的)。

健康检查是使用这个查询:

IF((SELECT COUNT(1) FROM sys.filegroups FG
JOIN sys.database_files DF
ON FG.data_space_id = DF.data_space_id
JOIN sys.master_files MF
ON DF.file_id = MF.file_id
JOIN sys.databases DB
ON DB.database_id = MF.database_id
where FG.type = 'FX'
and DB.name ='MyDB')>0)
BEGIN
SELECT 1
END
ELSE
BEGIN
RAISERROR ('Memory file group not set',  
18, -- Severity,  
-1); -- State);
END

并通过以下方式注册:

.AddSqlServer(connectionString: connString,
    healthQuery: myHealthQuery, name: HealthCheckNames.InMemoryState)

查询确实返回 1,没有任何错误。我已经设置了一个分析器来运行它,并且没有抛出任何错误(我可以看到返回的 Select 1)。

仍然,该健康检查返回不健康。

知道为什么吗?

1 个答案:

答案 0 :(得分:0)

事实证明这是一个权限问题。连接字符串的用户缺少我不愿意分配的权限(VIEW ANY DEFINITION 权限)。

我通过跳过连接到 sys.master_files 表并使用类似运算符解决了这个问题

IF((SELECT Count(1) FROM sys.filegroups FG
JOIN sys.database_files DF
ON FG.data_space_id = DF.data_space_id
where FG.type = 'FX'
and Df.name  LIKE 'MyDB%') > 0)
BEGIN
    SELECT 1
END
ELSE
BEGIN
    RAISERROR ('Memory file group not set',  
        18, -- Severity,  
        -1); -- State);
END