诊断SQLSERVER问题常用的日志

诊断SQLSERVER问题常用的日志 这里主要有两个: (1)Windows事件日志 (2)SQLSERVER ErrorLog 1、Windows事件日志 Event Log 作为一个Windows开启和管理的服务程序,Windows会在自己的系统日志system log里记录 SQLSERVER这个服务的启动、正常关闭、异常关

诊断SQLSERVER问题常用的日志

这里主要有两个:

(1)Windows事件日志

(2)SQLSERVER ErrorLog

1、Windows事件日志 Event Log

作为一个Windows开启和管理的服务程序,Windows会在自己的系统日志system log里记录

SQLSERVER这个服务的启动、正常关闭、异常关闭等信息。

SQLSERVER也会把自己的一些概要信息同时记录在Windows的应用程序日志里Application Log

而Windows日志本身又能够反映操作系统的健康情况,是否有任何软件或硬件的异常。

如果Windows本身不能正常工作,SQLSERVER的运行一定会受到影响。

当遇到一些问题需要微软的售后工程师解决的时候,Windows事件日志是一个很好的界定问题性质的工具。

在Windows里,点击“开始”-》运行  -》输入:eventvwr  点确定 就可以打开事件查看器Event Viewer

在Windows7、Windows2008和Windows2008R2里面,界面会有所不同,但是主要内容还是类似的

诊断SQLSERVER问题常用的日志

 

Windows主要有三种日志:应用程序,安全,系统 (我的系统是Windows7)

诊断SQLSERVER问题常用的日志

对于SQLSERVER会主要关心应用程序日志和系统日志。当处理一些连接认证问题时,可能会偶尔用上安全日志。

日志里的每一条记录,都属于信息、警告、错误中的一类。

每条记录都会标明日期、时间、来源、事件ID。

如果在应用日志里,从SQLSERVER产生的记录其来源名称都会是MSSQLSERVER

双击某一条记录,Windows会弹出一个对话框,显示记录的具体内容

诊断SQLSERVER问题常用的日志

 

在这里说一下我遇到的机器内存不足,导致SQLSERVER需要把内存换出去硬盘的情况,导致经常SQLSERVER反应缓慢

事件查看器显示的信息就是上面那个截图,一句话概括就是:系统内存不足

我的机器情况:

 

8GB内存没有用尽,因为32位操作系统的关系,迟一点打算更换为64位Windows7

 

所以平时多看一下事件查看器或者遇到问题的时候就先看事件查看器,一定能找到一些问题的蛛丝马迹

另外一个,在事件查看器里,还能把日志另存为*.evt文件或*.txt文件,以供DBA带到其他机器上打开分析。

打开一个*.evt文件的方法是:是右键点击“事件查看器(本地)”树型结构—》打开保存的日志

诊断SQLSERVER问题常用的日志

用这种方法,DBA就能像看本机上的日志记录一样,分析从其他机器保存下来的日志文件了

保存的时候可以保存单个事件或者整个类别的事件

诊断SQLSERVER问题常用的日志

诊断SQLSERVER问题常用的日志

最后,用事件日志查看器打开的日志,其时间会和时区有关系的,

不同时区设置的机器打开一个*.evt文件,其显示的时间会不一样。

例如,如果某个错误信息发生在美国的白天,那么用在中国的机器打开,其时间会显示在晚上

如果你按美国时间找,就会找不到了。但是保存成 *.txt格式 文本文件格式就不会有这种问题

 

2、SQLSERVER ErrorLog文件

Kits AI Kits AI

Kits.ai 是一个为音乐家提供一站式AI音乐创作解决方案的网站,提供AI语音生成和免费AI语音训练

Kits AI 492 查看详情 Kits AI

检查完Windows的基本状况后,就可以开始检查SQLSERVER的健康状况。

不管你是遇到什么问题,建议第一个要检查的是SQLSERVER的ErrorLog文件

当SQLSERVER启动的时候,会在某个固定的路径下生成一个“errorlog”的文件

SQLSERVER默认会保留7份errorlog文件,按照时间顺序,依次用文件扩名.1,.2,.3,…,.6表示。

每重启一次服务,文件扩展名都会加一,最早的那份会被删除。

 

日志文件的默认路径是安装路径下的C:Program FilesMicrosoft SQL ServerMSSQL.1MSSQLLOGLOG子目录。

C:Program Files是我的机器的安装路径,这个路径是你安装SQLSERVER的时候选择的

当然DBA也能够修改其设置(在配置管理器里,双击sql服务-》高级-》转储目录)

诊断SQLSERVER问题常用的日志

发觉Windows对错误日志或者目录都叫转储的,像某些软件,例如QQ,有道词典好像也是用dmp格式的转储文件

诊断SQLSERVER问题常用的日志

 

说回正题o(∩_∩)o 

如果你要分析的是一台陌生的服务器,可以用很多种方法找到errorlog路径。

一种比较简单的方法是在SQLSERVER 配置管理器里选择SQL服务,在其属性-》高级里找到一个“启动参数”的高级属性

在属性字符串里,会有一个“-e”的参数。他的后面就是跟errorlog文件的位置

诊断SQLSERVER问题常用的日志

 

或者干脆在上面说的转储目录就可以看到了

errorlog文件以文本方式记录,用任何文件编辑器,包括记事本,SSMS都能打开

一般来讲,errorlog文件的大小不会很大。用这些工具完全能够满足需求

但是,网站空间,errorlog本身非常重要,他记录了SQL的整个开启、运行、终止过程。

如果SQLSERVER遇到了比较严重的问题,在errorlog里都会有所显示

ErrorLog显示包括以下内容:

(1)SQL的版本,以及Windows和Processor基本信息

(2)SQL的启动参数,香港服务器,以及认证模式,内存分配模式

(3)每个数据库是否能够被正常打开。如果不能,原因是什么

(4)数据库损坏相关的错误

(5)数据库备份与恢复动作记录

(6)DBCC CHECKDB记录

(7)内存相关的错误和警告

(8)SQL调度出现异常时的警告。一般SERVER HANG 服务器死机会伴随着有这些警告

(9)SQL I/O操作遇到长时间延迟的警告

(10)SQL在运行过程中遇到的其他级别比较高的错误

(11)SQL内部的访问越界错误(Access Violation)

(12)SQL服务关闭时间

在检查SQLSERVER相关问题的时候,总是从errorlog着手,香港服务器,先确认errorlog里是干净的。

如果errorlog里有一些错误或警告,就要确认这些错误和警告发生的时间,是不是前端感觉到问题的时间。

如果时间能对得上,那就要着重分析一下

如果开启一些设置,在errorlog里还能看到的有用信息有:

(1)所有用户成功或失败的登入

(2)死锁以及其参与者的信息:需要打开跟踪标志1222 或1204

1 DBCC TRACEON(1222)TRACEON(1204)

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/901812.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2025年11月28日 20:52:12
下一篇 2025年11月28日 20:52:44

相关推荐

  • 解决绝对定位故障的快速指南

    遭遇绝对定位故障?快速诊断与修复指南,需要具体代码示例 引言: 在Web开发过程中,使用绝对定位是常见的CSS布局技术之一。然而,有时我们可能会遭遇到绝对定位故障,导致元素位置偏移或不正确显示。本篇文章将为大家提供一些诊断和修复绝对定位故障的方法,同时给出相关的代码示例。 一、诊断绝对定位故障的常见…

    2025年12月24日
    000
  • 浅谈css网页的布局问题

    这次给大家带来浅谈css网页的布局问题,css网页的布局问题的注意事项有哪些,下面就是实战案例,一起来看一下。 1、左边固定,右边自适应布局的两种实现方式 效果图如下: 大屏展示: 小屏展示:   第一种实现方式通过负边距与浮动 实现左边固定,右边自适应的布局。 主要代码如下: .left{floa…

    2025年12月24日 好文分享
    000
  • html5运行程序怎么生成日志_html5程序生成日志方法【教程】

    可通过浏览器控制台、页面元素、服务器存储和本地存储四种方式实现HTML5程序日志生成。首先使用console.log()等方法输出日志至开发者工具;其次将日志写入指定DOM元素,便于实时查看;然后通过Ajax将包含时间戳、级别、内容等信息的日志发送至服务器持久化存储;最后利用LocalStorage…

    2025年12月23日
    000
  • 探究HTTP状态码80:疑难问题与应对方法

    了解HTTP状态码80:常见问题与解决方案 HTTP状态码是由Web服务器发送给浏览器的一种标准状态码,用于表示服务器对请求的处理结果。在HTTP协议中,状态码被分为五类,其中在80类中包含了一些特殊的状态码。了解这些状态码以及相应的问题和解决方案可以帮助开发者更好地排查和解决网络问题。 801 &…

    2025年12月22日
    000
  • XHTML中有哪些常用的标签

    这次给大家带来xhtml中有哪些常用的标签,xhtml中使用常用标签的注意事项有哪些,下面就是实战案例,一起来看一下。 什么是 XHTML 标签?XHTML 标签元素是 XHTML 文档的基本组成部分。XHTML 标签可以理解为是 XHTML 语言用于定义描述 XHTML 文档 “这是什么,那是什么…

    好文分享 2025年12月21日
    000
  • HTML页面跳转及参数传递问题

    这篇文章给大家详细介绍了html页面跳转及参数传递问题,希望能帮助到大家。 HTML页面跳转: window.open(url, “”, “width=600,height=400”); 第二个参数:_self,在当前窗口打开窗口;_blank(默认值),在另外的新建窗口打开新窗口; 立即学习“前端…

    好文分享 2025年12月21日
    000
  • html中图片调整大小问题解决办法

    我从一个第三方接口获取了一张图片。当我把图片嵌入到我的页面的时候,发现图片太大了。 直接调整div大小不起作用,图片还是那么大。请问有什么办法可以调整图片显示的大小吗? 图片是动态获取的,也就是说刷新一下页面就会获取一张新的图片。所以重新裁图片解决不了问题。 html源码如下 @@##@@ @@##…

    好文分享 2025年12月21日
    000
  • 关于html中空格的问题解决

    联系我们 联系我们 联系我们 上边三种写法图标和文字的距离为什么都不一样?和inline-block的图标和换行有关系吗?如果我换5行 联系我们 联系我们 上边两种效果是一样的,为什么呢? 联系我们 nasp和实际打出来的空格效果是一样的为什么还要用nbsp呢? 联系我们 联系我们 像这种1个空格1…

    好文分享 2025年12月21日
    000
  • C++日志文件记录 时间戳分级写入方法

    答案是使用spdlog库实现高效日志记录,包含时间、级别、内容等要素,并支持格式定制与文件切割。首先选择高性能、功能丰富的spdlog库;其次定义TRACE、DEBUG、INFO、WARNING、ERROR、CRITICAL等日志级别;然后通过set_pattern设置包含时间戳、级别、文件名、行号…

    2025年12月18日
    000
  • 如何用C++生成临时日志文件 自动滚动和清理日志实现

    在c++++中实现临时日志文件的自动滚动与清理机制,可通过以下步骤完成:1. 使用mkstemp或标准库函数创建唯一的临时日志文件;2. 实现日志滚动策略,如按大小(如超过1mb)或时间(如每天生成新文件)切换日志文件;3. 设置自动清理机制,如保留最近7天或最多10个日志文件;4. 推荐使用成熟的…

    2025年12月18日
    200
  • 如何用C++实现桥接模式 抽象与实现分离设计方案

    c++++中桥接模式的核心优势在于解耦抽象与实现,使其能独立变化。1. 它通过将一个类中可能变动的具体操作抽离为独立的实现体系,降低类组合数量,避免“m x n”组合爆炸;2. 抽象类(如shape)包含指向实现接口的指针或引用,调用具体实现(如drawingapi),使两者互不影响;3. 适用于多…

    2025年12月18日 好文分享
    200
  • 利用日志记录增强 C++ 函数的调试能力

    如何利用日志记录增强 c++++ 函数的调试能力?使用 glog 库进行日志记录: 安装 glog,并在代码中使用 glog 头文件和 initgooglelogging() 初始化日志记录。添加日志记录语句: 使用 log() 宏在要记录的代码块中添加日志记录语句,以记录函数开始、结束或其他重要事…

    2025年12月18日
    000
  • 剖析C++框架中的日志和异常处理

    日志和异常处理是 c++++ 框架中用于捕获事件、诊断问题和处理意外情况的必备组件。日志允许记录应用程序事件,而异常处理通过 try-catch 结构处理运行时异常。通过结合使用日志和异常处理,可以方便地诊断问题,增强应用程序的稳定性和鲁棒性,并捕获和记录错误信息。 C++框架中的日志和异常处理剖析…

    2025年12月18日
    000
  • 如何调试和诊断C++框架扩展中的问题?

    调试 c++++ 框架扩展中的问题步骤如下:使用调试工具(如 pudb)检查变量、设置断点并逐步执行代码。添加日志记录语句,捕获关键信息,了解问题发生的时间和原因。通过单元测试隔离代码,识别特定错误。在论坛(如 github 或 stack overflow)寻求社区支持。 如何调试和诊断 C++ …

    2025年12月18日
    000
  • C++ 框架构建企业级应用的日志和监控最佳实践

    对于企业级 c++++ 应用程序,日志和监控的最佳实践包括:使用日志框架并标准化日志格式;采用分级日志和旋转日志;使用监控框架监控关键指标并设置警报;集成分布式跟踪工具以跟踪请求的生命周期。 C++ 框架构建企业级应用的日志和监控最佳实践 引言 对于企业级应用程序,日志和监控至关重要,可以洞察应用程…

    2025年12月18日
    000
  • C++ 框架中日志和跟踪机制的最佳实践

    c++++ 框架中日志和跟踪机制的最佳实践包括:确定日志级别(调试、信息、警告、错误)选择日志工具(如 boost.log、spdlog)获取调用堆栈信息用于跟踪(如 std::stacktrace) C++ 框架中日志和跟踪机制的最佳实践 一个健壮且可维护的 C++ 框架必须具有强大的日志和跟踪机…

    2025年12月18日
    000
  • C++ 模板的错误和诊断技巧有哪些?

    诊断 c++++ 模板错误的技巧检查编译器错误消息。使用 -g 和 -gstl 编译标志生成调试信息。使用 gdb 调试器逐步执行模板实例化。使用静态分析工具查找潜在错误。 C++ 模板的错误和诊断技巧 C++ 模板是一个强大的特性,允许您创建可重用的、类型安全的代码。然而,模板可能很复杂,并且可能…

    2025年12月18日
    000
  • 在 C++ 中,异常处理如何用于诊断和故障排除?

    使用异常处理诊断和故障排除:捕获异常:使用 try 和 catch 语句指定异常发生时的代码处理方式。异常类型:使用内置异常类(如 std::runtime_error)或自定义异常类指定异常类型。抛出异常:使用 throw 语句抛出异常,提供错误信息。诊断和故障排除:异常对象包含错误消息和信息,有…

    2025年12月18日
    000
  • C++ 函数异常与日志记录:全面故障诊断

    在 c++++ 中,异常和日志记录是关键的故障诊断工具。异常处理用于处理运行时错误事件,而日志记录用于记录程序运行时信息。在实战案例中,可使用异常和日志记录来诊断计算文件大小的函数中的错误,并在无法打开文件时抛出异常并记录错误消息。 C++ 函数异常与日志记录:全面故障诊断 在 C++ 程序开发中,…

    2025年12月18日
    000
  • C++ 函数如何用于调试和诊断 GUI 应用程序中的问题?

    c++++ 函数为 gui 应用程序调试提供了强大的工具,包括调试输出、调用堆栈跟踪、内存管理、调试器和日志记录。这些函数允许开发者识别和解决问题,确保应用程序的可靠性和稳定性。 使用 C++ 函数调试和诊断 GUI 应用程序 C++ 中的函数提供了强大的工具,用于调试和诊断 GUI 应用程序中的问…

    2025年12月18日
    000

发表回复

登录后才能评论
关注微信