SQL Server 資料庫引擎怎樣記錄完整備份後修改過的數據

来源:http://www.cnblogs.com/chenmh/archive/2017/08/30/7307384.html
-Advertisement-
Play Games

SQL Server 使用兩個內部數據結構跟蹤被大容量複製操作修改的區,以及自上次完整備份後修改的區。這些數據結構極大地加快了差異備份的速度。當資料庫使用大容量日誌恢復模式時,這些數據結構也可以加快將大容量複製操作記錄至日誌的速度。與全局分配圖 (GAM) 和共用全局分配圖 (SGAM) 頁相同,這 ...


SQL Server 使用兩個內部數據結構跟蹤被大容量複製操作修改的區,以及自上次完整備份後修改的區。這些數據結構極大地加快了差異備份的速度。當資料庫使用大容量日誌恢復模式時,這些數據結構也可以加快將大容量複製操作記錄至日誌的速度。與全局分配圖 (GAM) 和共用全局分配圖 (SGAM) 頁相同,這些結構也是點陣圖,其中的每一位代表一個單獨的區。

  • 差異更改映射表 (DCM)

    這樣便可以跟蹤自上次執行 BACKUP DATABASE 語句後更改過的區。如果擴展盤區的位是 1,則自上次執行 BACKUP DATABASE 語句後擴展盤區已被修改。如果位是 0,則擴展盤區沒有被修改。

    差異備份只讀取 DCM 頁便可以確定已修改的區。這樣大大減少了差異備份必須掃描的頁數。運行差異備份所需的時間與自上次執行 BACKUP DATABASE 語句之後修改的區數成正比,而不是與整個資料庫的大小成正比。

  • 大容量更改映射表 (BCM)

    跟蹤自上次執行 BACKUP LOG 語句後,被大容量日誌記錄操作修改的區。如果某個擴展盤區的位是 1,表明自上次執行 BACKUP LOG 語句後,該擴展盤區已經被有日誌記錄的大容量複製操作修改。如果位是 0,則該擴展盤區未被有日誌記錄的大容量複製操作修改。

    儘管所有資料庫中都顯示 BCM 頁,但只有在資料庫使用大容量日誌記錄恢復模式時,才會與 BCM 頁有關。在此恢復模式中,當執行 BACKUP LOG 時,備份進程將掃描 BCM 查找已經修改的區。然後,將那些區包括在日誌備份中。如果資料庫從資料庫備份和一系列事務日誌備份恢復,便可以恢復大容量日誌記錄操作。在使用簡單恢復模式的資料庫中,BCM 頁是不相關的,因為大容量日誌記錄操作不記入日誌。在使用完整恢復模式的資料庫中,BCM 頁同樣不相關,因為該恢復模式將大容量日誌記錄操作視為有完整日誌記錄的操作。

DCM 頁和 BCM 頁的間隔與 GAM 和 SGAM 頁的間隔相同,都是 64,000 個區。在物理文件中,DCM 和 BCM 頁位於 GAM 和 SGAM 頁之後。


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 當遇到備份或者還原操作占用較長時間時,很多人會問: 1. 備份/還原是不是僵死了?要不要kill掉,再重來? 2. 到底是哪一個部分的操作占用較長時間? 3. 到底現在進行到什麼階段了 ? 在SQL 2016 之前,要回答這些問題會比較困難一些,或者藉助某些不受支持的方式。SQL 2016開始引入了 ...
  • 1、查看哪些對象被鎖 2、下麵的語句用來殺死一個進程: 3、再一次查詢目前鎖定的對象,若發現以上方法不能解除鎖定的表,則用以下方法: (1)執行下麵的語句獲得進程(線程)號: (2)在OS上kill掉這個進程 Linux: Windows(unix也適用)用orakill殺死線程,orakill是o ...
  • 在分析ORACLE的AWR報告時,發現SQL ordered by Executions(記錄了按照SQL的執行次數排序的TOP SQL。該排序可以看出監控範圍內的SQL執行次數)下有一個SQL語句執行非常頻繁,一個小時執行了上萬次: update seq$ set increment$=:2, m... ...
  • 1.先查看目前日誌輸出方式 show variables like '%log_output%'; log_output 參數設定日誌文件的輸出,可選值為 TABLE, FILE ,NONE; "TABLE" 意思為設定日誌分別記錄到 mysql 庫的 general_log 和 slow_log ...
  • 原地址:http://www.cnblogs.com/shootercheng/p/5836657.html 1.查看資料庫編碼格式 mysql> show variables like 'character_set_database'; 2.查看數據表的編碼格式 mysql> show creat ...
  • 給mongo配置文件坑了好久,今天終於解決了。寫個博客,慶祝一下。 mongo3.4 版本,我是用YAML格式的配置文件。 一開始,配置之後,啟動服務的時候,老是提示:“unrecognized option: systemLog ” (如下圖) 很奇怪的事,它總是提示配置文件的第五行出錯,如下圖, ...
  • 背景 最近越來越多的公司把業務搬遷到雲上,公司也有這個計劃,自己抽時間在阿裡雲和Azure上做了一些小的嘗試,現在把阿裡雲上部署ES和kibana記錄下來。為以後做一個參考,也希望對其他人有幫助。 這裡以阿裡雲為例,由於測試只有一臺機器所以這裡就展開到集群了,下麵介紹下詳細的步驟。 步驟: 1.申請 ...
  • 第一次在博客園寫博客,也算是一個新的開始吧。閑話少說! 筆者之前推行OA系統的時候,管理員賬號一開始設的是admin,用了一段時間之後為了規範統一要改為ADMIN。 那問題來了,除了用戶表之外,還有哪些表哪些欄位的內容,已經記錄了admin呢? 上網查了表及欄位的相關知識之後,加上游標整庫搜索,終於 ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...