sql server 備份與恢復系列二 事務日誌概述

来源:https://www.cnblogs.com/MrHSR/archive/2018/08/06/9424721.html
-Advertisement-
Play Games

1.1 日誌文件與數據文件一致性 在上一章備份與恢復里瞭解到事務日誌的重要性,這篇重點來瞭解事務日誌。 事務日誌記錄了資料庫所有的改變,能恢復該資料庫到改變之前的任意狀態。在sql server實例每次啟動時都會去檢查數據文件與日誌文件的一致性。 包括日誌記錄的任何已提交的數據必須體現在數據文件上, ...


  1.1  日誌文件與數據文件一致性

 在上一章備份與恢復里瞭解到事務日誌的重要性,這篇重點來瞭解事務日誌。 事務日誌記錄了資料庫所有的改變,能恢復該資料庫到改變之前的任意狀態。在sql server實例每次啟動時都會去檢查數據文件與日誌文件的一致性。 包括日誌記錄的任何已提交的數據必須體現在數據文件上,未被標記為已提交的將禁止寫入數據文件,日誌還存儲了收到客戶端回滾事務請求,sqlserver出錯如死鎖等,日誌產生一個rollback命令。

   事務日誌是在資料庫創建或改變時與資料庫關聯起來的一個或多個文件。 任務改變資料庫的操作都會在事務日誌中寫入描述這些改變的記錄,包括要改變的頁碼,增加或刪除的數據值,事務信息,起止的日期和時間信息等。通過dbcc log可以看到如下信息

  sql server里每個日誌記錄都有一個唯一的日誌序列號標識LSN, 同一個事務里的所有日誌記錄是一個連接起來的整體,這樣能夠容易的定位一個事務的各個部分,從而實現撤銷undo或重做redo操作。

  1.2 優先寫日誌

  在日誌里有個名詞叫“優先寫日誌”。是指:緩存管理器能夠保證日誌寫入磁碟優先於相應的數據改變寫入磁碟,這叫優先寫日誌。一旦某個數據頁發生改變,相應的日誌項的LSN將會被寫入該數據頁的頁頭,緩存管理器能夠保證日誌頁以特定的順序寫入磁碟,使得無論故障在何時發生,sqlserver 能清楚知道在系統故障之後應該處理哪些日誌塊。如下圖所示

   但一個事務日誌記錄被寫入到磁碟,實際上被更改的數據可能還未來得及寫入數據頁,對於事務日誌寫操作是非同步的,數據頁的寫操作也是非同步的,但數據頁不需要立即完成,因為日誌包含了用來重做這些寫操作的所有信息。

  1.3 日誌文件與重啟恢復
  在sqlserver錯誤日誌 error log 里會報告每個資料庫重啟恢復的進展,它會告訴我們每一個資料庫有多少事務被前滾,多少事務被回滾, 有時被稱為“崩潰”恢復,因為sqlserver崩潰或服務異常停止,需要恢復過程在服務重啟時運行。 如果sqlserver里 事務日誌與數據文件一致,則重啟服務很快。

    

  1.4 日誌文件redo與undo

  如果事務在提交時,sql server服務突然停止,數據還未來得及寫入數據頁(註意不是磁碟),當服務啟動,該事務必須前滾,根據事務日誌所指示的更改來重做事務,這稱為恢復的重做(redo)階段。

  如果一個檢查點checkpoint 在事務提交前發生, 它將會把未提交的更改寫入磁碟,隨後sql server服務在提交前被停止, 恢復過程將會找出未提交事務對數據的改動,該過程必須撤銷反映在事務日誌中的改動,回滾所有不完整事務稱為恢復的撤銷(undo)階段。

  1.5 改變日誌文件大小

    資料庫管理員為了控制文件在大小,可能有時候要收縮文件空間可以使用dbcc shrinkdatabase 或  dbcc  shrinkfile 。shrinkdatabase 是收縮指定資料庫中的所有數據文件和日誌文件大小。shrinkfile 是收縮當前資料庫的指定數據文件或日誌文件的大小。註意的是不能在備份資料庫時收縮資料庫。 反之,也不能在資料庫執行收縮操作時備份資料庫。收縮一般在資料庫維護時段可以進行。使用dbcc  shrinkfile來一個文件一個文件地做比較穩妥。

-- 驗證文件是否有足夠的可用空間可供刪除
SELECT name ,size/128.0 - CAST(FILEPROPERTY(name, 'SpaceUsed') AS int)/128.0 AS AvailableSpaceInMB
FROM sys.database_files;

  1.6 虛擬日誌文件VLF

  在前面“sql server 日誌文件結構及誤操作數據找回”中講過每個物理日誌文件是分成多個虛擬日誌單元,虛擬日誌單元沒有固定大小,且數量不固定。可以通過dbcc loginfo來觀察虛擬日誌文件的關鍵屬性。當我們在當前資料庫下運行dbcc loginfo,會為每個VLF返回一行記錄。

use test
dbcc loginfo

  

  上面是查看了test庫日誌文件里的VLF,  Fileld是指物理日誌文件ID,這裡test只有一個日誌文件。 FileSize是文件大小(byte), StartOffset是指起點偏移(byte)。第一個VLF 是包含頁頭信息而不是日誌記錄,VLF從第二頁開始。Status 表示該VLF是否可被重用,狀態2表示該VLF或者是活動的或者是可恢復的,狀態0表示該VLF是可復用的或者完全沒有被使用過。通過備份事務日誌會改變可恢復的VLF到可復用狀態也就是狀態為0.


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

-Advertisement-
Play Games
更多相關文章
  • 1.下載 1)進入官網下載5.7.23壓縮包 下載地址:https://dev.mysql.com/downloads/mysql/5.7.html#downloads 2.安裝與配置 1)將下載的壓縮包解壓到任意目錄,如: 2)在根目錄下創建my.ini配置文件 3)用記事本打開my.ini,填寫 ...
  • 占座 ...
  • 一、可能很多初學大數據的伙伴不知道strom是什麼,先給大家介紹一下strom: 分散式實時計算系統,storm對於實時計算的意義類似於hadoop對於批處理的意義。 storm的適用場景。 流數據處理。Storm可以用來處理源源不斷流進來的消息,處理之後將結果寫入到某個存儲中去。 分散式rpc。由 ...
  • 1.Linux基礎和分散式集群技術 學完此階段可掌握的核心能力: 熟練使用linux,熟練安裝Linux上的軟體,瞭解熟悉負載均衡、高可靠等集群相關概念,搭建互聯網高併發、高可靠的服務架構; 學完此階段可解決的現實問題: 搭建負載均衡、高可靠的伺服器集群,可以增大網站的併發訪問量,保證服務不間斷地對 ...
  • 其中:syspwd:sys的登陸密碼;MyOrcl:所創建的資料庫服務名。 其中:dump_name :所創建的數據泵名字;'E:\DumpFiles' :創建數據泵存放.dump文件的絕對路徑。 導出數據: 其中:schemas:需要導出的用戶名;dumpfile:預設在數據泵目錄下生成對應的.d ...
  • 1. innodb 行鎖是基於索引實現的,如果不通過索引訪問數據,innodb會使用表鎖。 http://www.cnblogs.com/MrHSR/p/9376086.html 2. Innodb 間隙鎖(Next-key)機制,以及innodb使用間隙鎖的原因 http://www.cnblog ...
  • 1.mongodb安裝包下載(mongodb-win32-x86_64-v3.4-latest.zip),解壓到D:\mongodb文件夾下(解壓前創建目錄即可),創建data、logs文件夾【創建mongodb.log文件】 鏈接:https://pan.baidu.com/s/1K7g36CA_ ...
  • 轉自: http://www.maomao365.com/?p=6208 摘要: GROUPING 用於區分列是否由 ROLLUP、CUBE 或 GROUPING SETS 聚合而產生的行 如果是原生態的行聚合,則返回0 ,新增的行數據就返回1 grouping 語法簡介 : GROUPING (< ...
一周排行
    -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.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...