SQLSERVER数据库快照的工作方式

SQLSERVER数据库快照工作方式 翻译自:how database snapshots work 最近有一个帖子《errorlog中的异常信息rolled forward 和rolled back》 里面说到: 每周六凌晨1点会出现以下信息,服务器及数据库未出现重启,节点未切换,filestream access level =0,

SQLSERVER数据库快照的工作方式

翻译自:how database snapshots work

最近有一个帖子《errorlog中的异常信息rolled forward 和rolled back》

里面说到:

每周六凌晨1点会出现以下信息,服务器及数据库未出现重启,节点未切换,filestream access level =0,请各位高手帮忙解释,是什么原因导致的。

Configuration option ‘user options’ changed from 0 to 0. Run the RECONFIGURE statement to install.

FILESTREAM: effective level = 0, configured level = 0, file system access share name = ‘MSSQLSERVER’.

148 transactions rolled forward in database ‘XX_DB’ (12). This is an informational message only. No user action is required.

1 transactions rolled back in database ‘XX_DB’ (12). This is an informational message only. No user action is required.

Recovery completed for database XX_DB (database ID 12) in 21 second(s) (analysis 22 ms, redo 15062 ms, undo 3293 ms.) This is an informational message only. No user action is required.

 为什麽会有rolled back和rolled forward?

回复者给出了下面答案:

是DBCC CHECKDB造成的,由于DBCC CHECKDB在执行时要先创建一个数据库快照,所以才会有这些提示。

这些提示并不是针对当前数据库,而是针对快照库,所以当前数据库不会有rolled forward和 rolled back。

如果还有伴有其它error信息,才可能是真的遇到问题了。

参考:

但是回复者还没有回复一个问题:

Configuration option ‘user options’ changed from 0 to 0. Run the RECONFIGURE statement to install.

FILESTREAM: effective level = 0, configured level = 0, file system access share name = ‘MSSQLSERVER’.

为什麽会出现FILESTREAM??LZ说他们的系统没有使用到FILESTREAM的相关功能

今晚又看了一篇文章《》

里面说到:

正常情况下,CHECKDB/CHECKTABLE的运行不会对数据库使用排它锁,而是使用内部数据库快照(internal database snapshot)。

这个内部数据库快照实质就是Sparse Filestream, 它使用sparse file,COPY-ON-WRITE技术。详细的工作原理可以参考如下的文档:
 
数据库快照的工作方式
(v=SQL.105).aspx

 

我决定翻译一下这篇文章,看文章里是否有说到FILESTREAM

正文

数据库快照提供了一个在源数据库创建快照的时候只读的静态视图,这个静态视图会把还没有提交的事务去除掉

没有提交的事务会在新创建的数据库快照里被回滚,因为数据库引擎会在数据库快照创建完之后运行修复检查程序

但是,源数据库中的事务不会受到任何影响

 

数据库快照是独立于源数据库的。快照数据库会作为一个数据库存在于同一数据库服务器实例中

此外,无论什么原因,当数据库变为不可用的状态的时候,快照数据库也一样变为不可用

快照数据库不单只可以用来做报表之用,当在源数据库发生一个用户错误的时候,你可以修复源数据库到数据库快照被创建的那个时刻

自从数据库快照被创建之后,数据丢失仅仅限于快照创建之后的那些数据库数据更新的丢失

而且,创建数据库快照对于在一个大的数据库更新操作之前特别有用,例如改变数据库的架构或者表结构

对于更多数据库快照的用途,大家可以看一下数据库快照的典型应用

 

理解数据库快照的工作方式是很有帮助的,虽然不一定要使用数据库快照。数据库快照操作的级别是“页面级别”

在源数据库的一个页面被第一次修改之前,源数据页面会从源数据库复制到数据库快照。这个过程叫做:“COPY-ON-WRITE”操作

 

数据库快照存储了源数据页面,保留当快照被创建时已经存在的数据记录。后来的数据页面修改不会影响到快照里的页面内容。

对于每一个第一次被修改的页面会重复上面的COPY-ON-WRITE操作。用这种方法,快照会保存保留了所有已经被修改的数据记录的原始页面

当快照被创建的时候。

 

为了存储这些复制的原始页面,快照使用一个或者多个稀疏文件。最初,一个稀疏文件实际上是一个没有用户数据和还没有分配磁盘空间的空白的文件

当源数据库里越来越多的数据页面被更新,数据文件的size会增长。当快照建立之后,稀疏文件只会占用一点磁盘空间,当源数据库不断更新,

启科网络PHP商城系统 启科网络PHP商城系统

启科网络商城系统由启科网络技术开发团队完全自主开发,使用国内最流行高效的PHP程序语言,并用小巧的MySql作为数据库服务器,并且使用Smarty引擎来分离网站程序与前端设计代码,让建立的网站可以自由制作个性化的页面。 系统使用标签作为数据调用格式,网站前台开发人员只要简单学习系统标签功能和使用方法,将标签设置在制作的HTML模板中进行对网站数据、内容、信息等的调用,即可建设出美观、个性的网站。

启科网络PHP商城系统 0 查看详情 启科网络PHP商城系统

一个稀疏文件会增长成为一个大文件

想知道稀疏文件的更多信息,可以参阅:Understanding Sparse File Sizes in Database Snapshots

 

下面的图片描述了一个”copy-on-write”操作。在下面的快照图里灰白色的方块表示一个稀疏文件里还没有被分配的空间

当接收到第一个源数据库的第一个数据页面更新,数据库引擎会将页面写入到稀疏文件,并且操作系统会在快照的稀疏文件里分配

空间然后复制原始数据页。然后数据库引擎会更新源数据库的数据页面。

 

SQLSERVER数据库快照的工作方式

 

注意:因为数据库快照不是数据库存储冗余,快照不会防止磁盘错误或者其他类型的数据库损坏。如果你必须还原源数据库到某一个

时间点,这个时间点是数据库快照创建的时刻,那么你就要执行一个备份策略,从数据库备份中还原,而不是从数据库快照中还原

 

数据库快照的读操作

对于用户来讲,数据库快照从来不会发生改变,因为在数据库快照上的读操作总是访问原始数据页面无论这些数据页面来自哪里

如果在源数据库的数据页面从来没有被更新过,快照上的读操作会读取源数据库的源数据页面。下面的图片显示了一个在刚刚新建的快照上

的读操作,对应的稀疏文件并没有包含任何数据页面。这个读操作只会读取源数据库的数据

 

SQLSERVER数据库快照的工作方式

 

当有一个数据页面被更新之后,快照上的读操作就会访问存储在稀疏文件里原始数据页面,下面的图片描述了一个快照上的读操作

访问一个在源数据库被更新了的数据页面。读操作读取快照稀疏文件里的原始页面。

SQLSERVER数据库快照的工作方式

 

数据库快照增长对于更新模式的影响

如果你的源数据库相当大并且你正在关注磁盘空间的使用率,在某一时刻你应该用新的数据库快照替换旧的快照。

理想的数据库快照生存期依据于快照的增长速率和磁盘的可用空间。所需的磁盘空间取决于快照期间源数据库有多少的数据页面被更新了

因此,如果大部分的更新只是一小部分页面的重复更新,快照增长速率会比较慢,快照所需空间也会保持相对比较小的空间

相反,当所有原始页面至少最终被更新,快照会增长到与源数据库大小一样。如果磁盘开始填满,快照和磁盘会进行相互竞争对于磁盘空间

如果磁盘已经没有空间,对于快照的写操作会失败

 

记录:关于实际和潜在的快照大小的更多信息可以参阅:Understanding Sparse File Sizes in Database Snapshots

 

因此,当计划要多少磁盘空间在快照期间知道典型的数据库更新模式是很有用的。对于某些数据库,更新的频率是固定的,

例如:一个库存数据库有可能有很多每日都需要更新的页面,每日或每个星期替换旧的数据库快照是很有用的。对于其他数据库,

页面更新的比例有可能有很大的不同在业务运作期间;例如,一个目录数据库有可能只在季度更新,在其他时间只会偶尔更新

在季度的交替前和后创建数据库快照是一种业务策略。季度交替前的数据库快照允许修复重要的更新错误

而季度交替后的快照能够被用来做报表写入一直到下一个季度

 

下面的图片描述了两种更新模式的数据库快照的size的影响。

更新模式A影响只有30%原始页面被更新的快照环境

更新模式B影响80%原始页面被更新的快照环境

SQLSERVER数据库快照的工作方式

 

数据库快照的元数据

对于数据库快照,数据库元数据包括源数据库ID属性,ID属性存储在sys.databases目录视图里的某一列里

更多关于ID属性的信息,,可以查看sys.databases (Transact-SQL).

通常,一个数据库快照不会显示元数据信息(就是说你查不到快照数据库里面的一些元数据),不过你可以从源数据库那里查询这些元数据。

这些元数据包括,下面的SQL语句返回的数据

database_snapshotsys.database_files

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

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2025年12月2日 21:34:49
下一篇 2025年12月2日 21:35:09

相关推荐

  • 声明css有哪几种方式

    声明css有三种方式,分别是:1、在head标签中使用style标签声明;2、在标签上使用style属性声明;3、在head标签中使用link标签引入外部声明好的css文件。 本文环境:windows10、css3,本文适用于所有品牌的电脑。 (学习视频分享:css视频教程) 声明css有三种方式,…

    2025年12月24日
    000
  • CSS实现多重边框的5种方式

    这篇文章主要介绍了关于CSS实现多重边框的5种方式 ,有着一定的参考价值,现在分享给大家,有需要的朋友可以参考一下 简言 目前最优雅地实现多重边框的方案是利用CSS3 的 box-shadow属性,但如果要兼容老的浏览器,则需要选择其它的方案。本文简要地列举了几种多重边框的实现方案,大家可以根据项目…

    2025年12月24日 好文分享
    000
  • css的多种书写方式

    这次给大家带来css的多种书写方式,css书写方式的注意事项有哪些,下面就是实战案例,一起来看一下。 优先级: 外部样式 优先级,即:同名的选择器右边的会覆盖左边 1.内部样式表 CSS Code复制内容到剪贴板                 /*内部样式表,一般用于覆盖公用样式*/       …

    好文分享 2025年12月24日
    000
  • CSS有多少清除浮动的方式

    这次给大家带来CSS有多少清除浮动的方式,清除浮动的注意事项有哪些,下面就是实战案例,一起来看一下。 1、设置父元素高度 如果一个元素要浮动,那么它的祖先元素一定要有高度.高度的盒子,才能关住浮动 只要浮动在一个有高度的盒子中,那么这个浮动就不会影响后面的浮动元素.所以就是清除浮动带来的影响了. 弊…

    2025年12月24日
    000
  • 5种css实现左中右布局的方式

    本文主要和大家介绍了css布局实现左中右布局的5种方式的相关资料,小编觉得挺不错的,现在分享给大家,也给大家做个参考,希望能帮助到大家。 效果如下: 左中右布局 Document html *{ margin: 0; padding: 0; } article{ height: 100px; } s…

    2025年12月24日
    000
  • HTML数据如何存储到数据库 HTML数据存储的技术方案比较

    直接存储原始HTML字符串最常见,适用于富文本编辑器输出等内容,实现简单、读取快,但需防范XSS和SQL注入;结构化JSON存储适合需程序化处理的场景,支持条件查询但渲染开销大;专用格式如Delta适用于协同编辑;分离存储则提升大型系统的查询性能与管理灵活性。 将HTML数据存储到数据库时,核心目标…

    2025年12月23日
    000
  • 数据库查询与HTML整合

    通过以下步骤,您可以将数据库查询结果整合到 html 页面中:建立数据库连接。执行查询并存储结果。遍历查询结果并将其显示在 html 元素中。 使用 PHP 将数据库查询与 HTML 整合 整合数据库查询结果和 HTML 页面可使您创建动态和交互式 Web 应用程序。本文将引导您完成使用 PHP 执…

    2025年12月22日
    000
  • 深入解析HTML如何读取数据库

    html 无法直接读取数据库,但可以通过 javascript 和 ajax 实现。其步骤包括建立数据库连接、发送查询、处理响应和更新页面。本文提供了利用 javascript、ajax 和 php 来从 mysql 数据库读取数据的实战示例,展示了如何在 html 页面中动态显示查询结果。该示例使…

    2025年12月22日
    000
  • html怎么读取数据库

    HTML 本身不具备直接读取数据库的能力,而是需要结合后端编程语言和数据库查询语言来实现。后端代码负责与数据库交互,从数据库中读取数据,并将数据嵌入到 HTML 页面中。这个过程通常涉及设置数据库、编写后端代码、将后端代码嵌入 HTML、配置服务器和访问网页。此外,前端 JavaScript 也可以…

    2025年12月22日
    000
  • 前端工程师职责解析:主要做什么工作?

    前端工程师职责解析:主要做什么工作? 随着互联网的快速发展,前端工程师作为一个非常重要的职业角色,扮演着连接用户与网站应用程序的桥梁,起着至关重要的作用。那么,前端工程师主要做些什么工作呢?本文将对前端工程师的职责进行解析,让我们来一探究竟。 一、前端工程师的基本职责 网站开发与维护:前端工程师负责…

    2025年12月22日
    000
  • 前端与后端的职责与技能要求

    前端与后端是软件开发中不可或缺的两个部分,它们分别承担着不同的职责和技能要求。本文将从职责和技能方面探讨前端与后端开发工程师的工作内容和要求。 一、前端工程师的职责及技能要求前端工程师负责实现用户界面和交互功能,直接面向用户,需要具备以下职责和技能要求: 实现网站或应用程序的用户界面设计,确保页面视…

    2025年12月22日
    000
  • 前端后端开发的发展历程与趋势展望

    随着互联网的迅猛发展和信息技术的日新月异,前端和后端开发作为两个重要的IT领域在过去几十年中也取得了巨大的进步。本文将探讨前端后端开发的发展历程,分析当前的发展趋势,并展望未来的发展方向。 一、前端后端开发的发展历程 早期阶段在互联网刚刚兴起的时期,网站开发主要关注内容的呈现,前端开发工作主要集中在…

    2025年12月22日
    000
  • 剖析前端和后端的技术差异

    前端和后端是软件开发中常见的两个领域,前端指的是用户界面和用户交互逻辑的开发,而后端则负责处理数据存储、逻辑处理和业务规则的实现。两者在技术上有着明显的差异,本文将从不同的角度来剖析前端和后端的技术差异。 首先,在技术栈方面,前端和后端使用的技术有很大的不同。前端常用的技术包括HTML、CSS和Ja…

    2025年12月22日
    000
  • 了解隐式类型转换的方式有哪些?

    你知道隐式类型转换的几种方式吗? 在编程中,类型转换是将一个数据类型转换为另一个数据类型的常见操作。类型转换可以是显式的,即通过代码指定要转换的数据类型,也可以是隐式的,即根据上下文自动进行数据类型转换。 隐式类型转换在一些编程语言中是非常常见的特性,它能够在不显式指定类型转换的情况下,自动完成类型…

    2025年12月21日
    000
  • 了解SessionStorage:它的工作原理在浏览器中是怎样的?

    解析SessionStorage:它是如何在浏览器中工作的? 随着现代Web应用在功能和复杂性上的不断增加,为了提供更好的用户体验,开发人员开始使用各种技术来储存和管理应用程序中的数据。其中,会话存储(SessionStorage)成为了一种流行的解决方案。 会话存储是HTML5标准中的一项功能,它…

    2025年12月21日
    000
  • 了解localstorage:它的数据库特点是什么?

    探究localstorage:它是一种什么样的数据库? 概述:在现代的Web开发中,数据的存储和管理是非常重要的一部分。随着技术的不断进步,新的数据库技术也不断涌现。其中之一就是localstorage。本文将介绍localstorage的概念、用途以及一些常用的代码示例,帮助读者更好地了解并使用l…

    好文分享 2025年12月21日
    000
  • 揭开localstorage的面纱:揭示它的真实本质和功能

    揭秘localstorage:究竟是什么样的数据库? 近年来,随着Web应用的快速发展,前端开发中涉及到数据存储的需求也越来越多。而localstorage作为一种前端数据存储的解决方案,备受广大开发者的关注和使用。那么,这个被称为“本地存储”的localstorage究竟是什么样的数据库呢?本文将…

    2025年12月21日
    000
  • 揭开localstorage的神秘面纱:深入探究这种数据库的特性

    解读localStorage:它到底是怎样的一种数据库? 概述: 在现代网页开发中,本地存储是一项非常重要的技术。其中之一就是localStorage(本地存储)技术。localStorage是一种在浏览器中储存数据的机制,它提供了一种简单的方式来存储和读取持久性数据。这种存储是基于浏览器的,而不是…

    2025年12月21日
    000
  • 分析localstorage的优缺点:探讨五种数据保存方式

    了解 localstorage:五种方式保存数据的优缺点分析 【引言】随着互联网的迅速发展,我们现在能够获取和处理的数据量变得越来越大。在前端开发中,保存和处理数据是一个非常重要的问题。而作为前端开发人员,我们需要了解各种保存数据的方式,选择最适合项目需求的方式。本文将介绍 localstorage…

    2025年12月21日
    000
  • 做web前端开发怎么样?

    前端工程师是互联网时代软件产品研发中不可缺少的一种专业研发角色。从狭义上讲,前端工程师使用 html、css、javascript 等专业技能和工具将产品ui设计稿实现成网站产品,涵盖用户pc端、移动端网页,处理视觉和交互问题。从广义上来讲,所有用户终端产品与视觉和交互有关的部分,都是前端工程师的专…

    2025年12月21日
    000

发表回复

登录后才能评论
关注微信