SQL Server 数据库有三种文件类型,分别是数据文件、次要数据文件和日志文件,其中日志文件包含着用于恢复数据库的所有日志信息,SQL Server总是先写日志文件ldf,数据变化写入mdf则可以滞后,所以日志写入的速度在一定程序上决定了SQL Server所能承载的写事务量,那么ldf写入大小是多少呢?
要知道SQL Server写 Log的大小,这里使用工具Process Monitor
这里设置一个Filter,以满足只收集SQL Server 写日志,如下图所示:
在一个OLTP生产环境的结果分析如下:
从中可以看到这个UserDB.ldf的Log写入是顺序写,写入大小以1024byte为主:
通过上面的结果,针对Log文件ldf的写要求,我们在选择磁盘及RAID时,如何来做呢?推荐使用工具SQLIO来做一个针对单线程顺序写1kb硬件性能比对测试,来模拟Log写操作,这个将在以后的文章里进行测试。
那么,SQL Log写入ldf一定是以1024byte最多吗?这个不一定的,以下是在另外的OLTP下得到的结果:
下面这个是Tempdb:
那么你的是多少呢?可以用Process Monitor下测下。
Process Monitor下载地址
收集到的数据存成Logfile.CSV.
然后用下列语句进行分析:
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 | USE tempdb GO CREATE TABLE [dbo].[Logfile] ( [ Time of Day ] [nvarchar]( MAX ) NULL , [Process Name ] [nvarchar]( MAX ) NULL , [PID] [nvarchar]( MAX ) NULL , [Operation] [nvarchar]( MAX ) NULL , [Path] [nvarchar]( MAX ) NULL , [Result] [nvarchar]( MAX ) NULL , [Detail] [nvarchar]( MAX ) NULL ) ON [ PRIMARY ] GO BULK INSERT [Logfile] FROM 'D:\Tmp\Logfile.CSV' WITH ( FIELDTERMINATOR = ',' , FIRSTROW=2 ) SELECT [ Time of Day ] , [Process Name ] , PID , Operation , REPLACE (PATH, 'DBname' , 'myDB' ) AS Path , Result , Detail FROM [Logfile] --WHERE PATH LIKE '%DBname%' SELECT SUBSTRING (detail, CHARINDEX( 'Length:' , detail) + 7, CHARINDEX( 'Flags' , detail) - CHARINDEX( 'Length:' , detail) - 13) AS size INTO # FROM [Logfile] WHERE PATH LIKE '%HighEndSeekerDB%' SELECT size AS [ SIZE (Bypte)] , COUNT (*) AS CNT , LTRIM( CAST ( COUNT (*) * 1.0 / ( SELECT COUNT (*) FROM # ) * 100 AS NUMERIC (18, 4))) + '%' AS ratio FROM # GROUP BY size --ORDER BY count(*) desc --ORDER BY CAST(REPLACE(size, ',', '') AS BIGINT) ORDER BY ratio DESC |
作者:nzperfect
出处:http://www.cnblogs.com/nzperfect/
引用或者转载本BLOG的文章请注明原作者和出处,并保留原文章中的版权信息。
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· AI与.NET技术实操系列:基于图像分类模型对图像进行分类
· go语言实现终端里的倒计时
· 如何编写易于单元测试的代码
· 10年+ .NET Coder 心语,封装的思维:从隐藏、稳定开始理解其本质意义
· .NET Core 中如何实现缓存的预热?
· 分享一个免费、快速、无限量使用的满血 DeepSeek R1 模型,支持深度思考和联网搜索!
· 25岁的心里话
· 基于 Docker 搭建 FRP 内网穿透开源项目(很简单哒)
· ollama系列01:轻松3步本地部署deepseek,普通电脑可用
· 按钮权限的设计及实现