我们有Microsoft SQL Server 2017 (RTM-GDR) (KB4583456) - 14.0.2037.2 (X64) Nov 2 2020 19:19:59 Copyright (C) 2017 Microsoft Corporation Standard Edition (64-bit) on Windows Server 2016 Standard 10.0 <X64> (Build 14393: )
服务器实际安装了256 GB的RAM。Server的内存限制设置为210 GB。我注意到,服务器在进行查询时每个查询请求39 GB内存(210 * 0.7
在服务器上进行内存升级之后,我准备增加我们的max server memory值。我正在测试Server上的命令,我不知道为什么要看到test与GUI的不同结果。我将测试服务器上的内存更改为24 as,如下所示:
sp_configure 'show advanced options', 1;
GO
RECONFIGURE;
GO
sp_configure 'max server memory', 24576;
GO
RECONFIGURE;
GO
在GUI中,我看到了24576。
但是使用下面的查询,我看到了22421。我做错什
我们有一个具有混合OLAP/OLTP工作负载的数据库。查询非常特别,是在中间层应用程序服务器中动态创建的。当我们启动服务器时,性能是可以接受的,但是内存消耗越来越多,直到所有可用内存(30 we )耗尽为止。在那之后,系统变得越来越慢。
像Dbcc freeproccache这样的命令没有效果。
select * from sys.dm_tran_session_transactions中的事务不多(不超过系统正常时),有时此列表为空。
dbcc memorystatus的第一个结果是
VM Reserved 42136628
VM Committed
我正在尝试理解SQL Server的内存管理。我有一个64 GB内存的虚拟环境下的Windows 2019。我还安装了Server 2019,最大服务器内存为59776 MB。通过使用以下查询,我找到了所有内存管理员的列表:
SELECT [type] AS [ClerkType], SUM(pages_kb) / 1024 AS [SizeMb]
FROM sys.dm_os_memory_clerks WITH (NOLOCK)
GROUP BY [type]
ORDER BY SUM(pages_kb) DESC
所有内存记录的总和等于23523 MB。
Value for MEMOR