Memory Manager surface area changes in SQL Server 2012
here were various changes to memory related DMVs, DBCC memory status, and Perfmon counters in SQL Server 2012 as part of the redesign of the Memory Manager component of SQLOS. The Memory Manager redesign resulted in being able to more accurately size and govern all SQL Server memory consumption, making page allocations more efficient, and better handling and tracking of NUMA node memory allocations. This post aims to document these surface area changes in one place to serve as a quick reference.
Some of these changes were to standardize memory counters as “kb” rather than bytes or pages, continuing a process begun earlier, but now more relevant since the single and multi-page allocators were replaced by an any-size page allocator, so counting pages allocated would no longer give a meaningful view of memory use. This consolidation of allocators also resulted consolidated counters for page allocation.
Other changes reflect the central role of the redesigned Memory Manager in being the interface to the OS, providing page allocations for the other components. A modular summary of the architectural changes is shown below:

DMV Changes
sys.dm_os_memory_nodes
The consolidation of the single and multi-page allocators is reflected in the pages_kb column in sys.dm_os_memory_nodes. The new foreign_committed_kb counter is a result of the improved NUMA management and reporting in SQL 2012 and identifies memory on a noe that belongs to a remote node, which can be useful if you’re troubleshooting slower memory access. We will always try and use local memory first, at least until the target memory is reached.
|
sys.dm_os_memory_nodes |
|
|
SQL Server 2012 |
SQL Server 2008 R2 |
|
pages_kb |
single_pages_kb + |
|
foreign_committed_kb |
– |
sys.dm_os_sys_info
The main memory manager changes here are to standardize memory counters.
|
sys.dm_os_sys_info |
|
|
SQL Server 2012 |
SQL Server 2008 R2 |
|
physical_memory_kb |
physical_memory_in_bytes |
|
virtual_memory_kb |
virtual_memory_in_bytes |
|
committed_kb |
bpool_committed |
|
committed_target_kb |
bpool_commit_target |
|
visible_target_kb |
bpool_visible |
sys.dm_os_memory_cache_counters
|
sys.dm_os_memory_cache_counters |
|
|
SQL Server 2012 |
SQL Server 2008 R2 |
|
pages_kb |
single_pages_kb + |
|
pages_in_use_kb |
single_pages_in_use_kb |
sys.dm_os_memory_cache_entries
|
sys.dm_os_memory_cache_entries |
|
|
SQL Server 2012 |
SQL Server 2008 R2 |
|
pages_kb |
pages_allocated_count |
sys.dm_os_memory_clerks
|
sys.dm_os_memory_clerks |
|
|
SQL Server 2012 |
SQL Server 2008 R2 |
|
pages_kb |
single_pages_kb + |
|
page_size_in_bytes |
page_size_bytes |
sys.dm_os_memory_objects
|
sys.dm_os_memory_objects |
|
|
SQL Server 2012 |
SQL Server 2008 R2 |
|
pages_in_bytes |
pages_allocated_count |
|
max_pages_in_bytes |
max_pages_allocated_count |
DBCC Memory Status changes
Many of the DBCC memory counters that were previously under Buffer Pool have now been consolidated under Memory Manager to reflect the revised architecture. There is also some additional information to reflect OS errors and NUMA awareness. NUMA growth phase shows memory growth before the target is reached. The “Pages In Use” counter shows the actual number of pages in use, including the stolen pages, database pages, and the reserved memory. The Away Committed counter indicates how much memory from this node is committed from other nodes.
|
SQL Server |
SQL Server |
|
Memory Manager \ |
– |
|
Memory Manager \ |
Memory Manager \ |
|
Memory Manager \ Emergency |
Memory Manager \ |
|
Memory Manager \ |
Buffer Pool \ |
|
Memory Manager \ |
Buffer Pool \ |
|
Memory Manager \ |
Buffer Pool \ |
|
Memory Manager \ |
Buffer Pool \ |
|
Memory Manager \ |
Buffer Pool \ Free |
|
Memory Manager \ |
– |
|
Memory Manager \ |
Buffer Pool \ |
|
Memory Manager \ |
– |
|
Memory Manager \ |
Buffer Pool \ Last |
|
Memory Manager \ |
– |
|
SQL Server |
SQL Server |
|
Memory Manager \ |
– |
|
Memory Manager \ |
Memory Manager \ |
|
Memory Manager \ |
Memory Manager \ |
|
Memory Manager \ |
Buffer Pool \ |
|
Memory Manager \ Current |
Buffer Pool \ |
|
Memory Manager \ |
Buffer Pool \ |
|
Memory Manager \ |
Buffer Pool \ |
|
Memory Manager \ |
Buffer Pool \ Free |
|
Memory Manager \ |
– |
|
Memory Manager \ |
Buffer Pool \ |
|
Memory Manager \ |
– |
|
Memory Manager \ |
Buffer Pool \ Last |
|
Memory Manager \ |
– |
|
SQL Server |
SQL Server |
|
Memory node Id = n |
Memory node Id = n |
|
Memory node Id = n |
– |
|
Memory node Id = n |
– |
|
Memory node Id = n |
– |
|
Memory node Id = n |
– |
|
Memory Clerks \ |
Memory Clerks \ |
Perfmon counters
The Perfmon counter changes follow the same consolidation of counters under the Memory Manager object, and the standardization of counters to KB. Several deprecated AWE counters are now removed.
|
SQL Server 2012 |
SQL Server 2008 R2 |
|
Object – SQLServer:Memory |
Object – SQLServer:Buffer |
|
Database Cache Memory (KB) |
Database pages |
|
Free Memory (KB) |
Free pages |
|
Reserved Server Memory (KB) |
Reserved pages |
|
Stolen Server Memory (KB) |
Stolen pages |
|
Target |
Target |
|
Total |
Total |
|
– |
AWE |
|
– |
AWE stolen maps / sec |
|
– |
AWE |
|
– |
AWE |
|
– |
AWE |
|
SQL Server |
SQL Server |
|
Object – |
Object – |
|
Database Node |
Database pages |
|
Free Node Memory |
Free pages |
|
Foreign Node Memory |
Foreign pages |
|
Stolen Node Memory |
Stolen pages |
|
Target Node Memory |
Target pages |
|
Total Node Memory |
Total pages |
I’ll follow up this article with some additional surface area changes for configuration and new memory manager messages that appear in the errorlog.
The goal of these changes is to make the new Memory Manager activity easier and more intuitive to track, and to clean up some of the values that no longer make sense with the any size page allocator and deprecation of AWE. Anything you used to use but can’t find any more? Let me know.
Memory Manager surface area changes in SQL Server 2012的更多相关文章
- SQL Server 2012 内存管理 (memory management) 改进
SQL Server 2012 的内存管理和以前的版本相比,有以下的一些变化. 一.内存分配器的变化 SQL Server 2012以前的版本,比如SQL Server 2008 R2等, 有sing ...
- SQL Server 2012:SQL Server体系结构——一个查询的生命周期(第1部分)
为了缩小读取操作所涉及范围,本文首先着眼于简单的SELECT查询,然后引入执行更新操作有关的附加过程.最后你会读到,优化性能时SQLServer使用还原工具的相关术语和流程. 关系和存储引擎 如图所示 ...
- 数据库服务器构建和部署列表(For SQL Server 2012)
前言 我们可能经常安装和部署数据库服务器,但是可能突然忘记了某个设置,为后来的运维造成隐患.下面是国外大牛整理的的检查列表. 其实也包含了很多我们平时数据库配置的最佳实践.比如TEMPDB 文件的个数 ...
- 疑难杂症--SQL SERVER 2012下数据库内存异常回收
--=================================================================== --背景: 在一台SQL SERVER 2012 SP1(1 ...
- 在Windows Server 2012 R2中搭建SQL Server 2012故障转移集群
需要说明的是我们搭建的SQL Server故障转移集群(SQL Server Failover Cluster)是可用性集群,而不是负载均衡集群,其目的是为了保证服务的连续性和可用性,而不是为了提高服 ...
- SQL Server 2012 各版本功能比较
有关不同版本的 SQL Server 2012 所支持的功能的详细信息. 功能名称 Enterprise 商业智能 Standard Web Express with Advanced Service ...
- SQL Server 2012 AlwaysOn集群配置指南
1. AlwaysOn介绍 AlwaysOn是SQL Server 2012提供的全新综合.灵活.高效经济的高可用性和灾难恢复解决方案.它整合了镜像和群集的功能,基于OS 故障转移群集(Windows ...
- SQL Server 2012 连接到数据库引擎
第 1 课:连接到数据库引擎 https://msdn.microsoft.com/zh-cn/library/ms345332(v=sql.110).aspx 本课将介绍主要的工具以及如何连接并 ...
- 卸载sql server 2012
好不容易装上了sql server 2012数据库,可是却不能连接本地的数据库,后来发现缺少一些服务,于是决定重新安装,但是卸载却很麻烦,如果卸载不干净的话,重新安装会出问题,所以下面就总结一些方法: ...
随机推荐
- git提交到远程虚拟机
git到自己的虚拟机中第一步:打通git(一)Linux中(ip为10.1.8.1)1.安装git如:Ubuntu中安装gitapt install git 2.Ubuntu中添加git用户sudo ...
- 文件传输(xmodem协议)
https://www.menie.org/georges/embedded/ 需要移植如下两个基础的硬件读写函数 int _inbyte(unsigned short timeout); void ...
- Apache Spark 2.0三种API的传说:RDD、DataFrame和Dataset
Apache Spark吸引广大社区开发者的一个重要原因是:Apache Spark提供极其简单.易用的APIs,支持跨多种语言(比如:Scala.Java.Python和R)来操作大数据. 本文主要 ...
- OOM问题分析
一.背景 在实际的开发中,性能问题的分析一直是运维团队的痛点,无论是缓慢内存溢出还是迅速的内存爆炸,对系统和业务的破坏都是快速而巨大的,此贴分享下简单的分析内存问题的经验. 二.相关名词 分代:根据对 ...
- iClap专访:颠覆传统办公方式,规范化产品管理系统
背景:DevStore是成立于2014年的移动互联网企业运营解决方案整合平台,线上资源涉及产品研发,设计,推广运维各个阶段,致力于为互联网从业者提供帮助.iClap是DevStore的全新产品,于20 ...
- testng失败截图,注解方式调用。
今天一整天都在研究testng失败截图的方法,参考网上的前辈们的资料,加上自己的理解,终于搞出来了. package com.dengnapianhuahai; /** * 自定义注释 * */ im ...
- 适配移动端的在图片上生成水波纹demo
<!DOCTYPE html> <html lang="zh"> <head> <meta charset="UTF-8&q ...
- python3 使用opencv 画基本图形
在Python3 环境下安装opencv-python 后练习画基本图形: import numpy as np import cv2 # BGR format GREEN = (0, 255, 0) ...
- 刷新DNS解析缓存
为了提高网站的访问速度,系统会在成功访问某网站后将该网站的域名.IP地址信息缓存到本地.下次访问该域名时直接通过IP进行访问. 一些网站的域名没有变化,但IP地址发生变化,有可能因本地的DNS缓存没有 ...
- 20145216史婧瑶《Java程序设计》第二次实验报告
实验二 Java面向对象程序设计 实验内容 1. 初步掌握单元测试和TDD 2. 理解并掌握面向对象三要素:封装.继承.多态 3. 初步掌握UML建模 4. 熟悉S.O.L.I.D原则 5. 了解设计 ...