SQL SERVER運維日記--收縮資料庫

来源:http://www.cnblogs.com/OwenZeng/archive/2017/02/10/6385780.html
-Advertisement-
Play Games

一個小故事 某天,小王正在和HR妹妹閑聊,正HAPPY時,,突然收到系統告警消息,資料庫磁碟被剩餘空間500M,OMG,不行,磁碟快滿了,要是業務要停了,,那就小王只能刪庫到跑路了,,, 先檢查下,有沒有可以刪除的不用的文件,結果都是重要的或者拿不准的。先收縮下資料庫吧,點擊運行。等收縮完成就可以繼 ...


一個小故事

某天,小王正在和HR妹妹閑聊,正HAPPY時,,突然收到系統告警消息,資料庫磁碟被剩餘空間500M,OMG,不行,磁碟快滿了,要是業務要停了,,那就小王只能刪庫到跑路了,,,

 


先檢查下,有沒有可以刪除的不用的文件,結果都是重要的或者拿不准的。先收縮下資料庫吧,點擊運行。等收縮完成就可以繼續去根HR妹妹聊天了。突然電話座機和手機齊鳴,小王心裡一種不祥的預感呢?好像這個場景在哪裡見過。。不會是資料庫阻塞了吧?? 手忙腳亂的先接起手機,因為來電顯示是某業務部門主管 “小王啊,,現在系統卡死了,全部不動了,是怎麼回事啊,你趕緊處理下”,,“恩,好的,我馬上檢查下”,然後又接起座機,是另外一個部門的主管說報表看不了。慌忙應付完了,趕緊檢查資料庫執行中的語句。 果然資料庫產生大量的阻塞,,連帶資料庫伺服器的操作都變得好慢(是我的心理作用嗎?)。正準備先把收縮操作取消了,,電話有同時響起了,,,唉,不管了,先處理問題。然後點擊取消。經過漫長的等待,,終於完成了,然後打電話跟各個部門解釋,,寫事故報告,,悲劇,,今天的午飯都不想吃了。

這個場景是不是很熟悉啊,關於資料庫收縮的問題,是我在群里,論壇里,看到新人問過最頻繁的問題之一。今天這篇文章對資料庫收縮進行有個框架性說明,希望小伙伴在以後遇到相關的

問題時,做到心中有數。

 

 

關於收縮的建議

不到萬不得已,千萬不要收縮資料庫。收縮資料庫影響極大:

1.收縮資料庫對資料庫的影響極大,產生大量日誌和碎片,而且會鎖表。如果你的庫當前正在被使用,收縮不下去非常正常。
2.收縮資料庫一定要手工來做的,而且是在維護視窗期做的事。
3.儘量使用語句來執行,可以提示錯誤

下麵的文章詳細介紹:
http://www.sqlskills.com/blogs/paul/why-you-should-not-shrink-your-data-files/.

 

收縮的正確姿勢

在不得不收縮的時候,參考下麵的步驟

1.找到資料庫中最大的幾個表,重建所有索引。首先嘗試指定Truncate Only收縮方式.它只是移除文件尾部的空閑空間,並不重新組織已經使用的數據頁。

DBCC SHRINKDATABASE (AdventureWorks2012, TRUNCATEONLY);  

2 最後才考慮,不帶選項的收縮。收縮不要一次性全部收縮。 可以每次收縮2G左右。不要把空間可用空間全部收縮了,可以剩餘一部分比如4G。

3.可在進程中的任一點停止 DBCC SHRINKDATABASE 操作,任何已完成的工作都將保留。

4. 不能在備份資料庫時收縮資料庫

 

總結

那我們處理磁碟空間不足的最好的辦法是什麼呢?最好的辦法是在最初規劃時,預估好未來一年或者二年的數據增長。給磁碟劃分足夠的空間。設置好資料庫的初始大小,並且將自動增長使用固定量增長。

 


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

-Advertisement-
Play Games
更多相關文章
  • 熱更新方案:使用騰訊的tinker,對於加固的apk(360和應用寶2個渠道)不支持 不加固的apk:使用熱更新方案,無需安裝,所有不加固的文件共用一個更新包 加固的apk:使用下載新的完整apk的方案,重新安裝,後臺管理補丁時先上傳加固的補丁apk再上傳不加固共用的補丁文件 增加補丁配置文件(每次 ...
  • /** * bitmap 圖片縮放到指定大小 */ public static Bitmap resizeImage(Bitmap bitmap, int w, int h) { Bitmap BitmapOrg = bitmap; int width = BitmapOrg.getWidth();... ...
  • 個人微信公眾號:zhaoyanjun125 , 歡迎關註 QQ交流群:431048982 ...
  • Paint類的常用的方法 1.setColor方法,用於設置畫筆的顏色,public void setColor(int color)//參數color為顏色值,也可以使用Color類定義的顏色Color.BLACK:黑色Color.BLUE:藍色Color.CYAN:青綠色Color.DKGRAY ...
  • 知識點: 1.UIScrollView使用 2.UIPageControl使用 @interface RootViewController ()<UIScrollViewDelegate> UIScrollView使用 1.UIScrollView創建 2.常用屬性 1)滾動內容大小 2)是否分頁滾 ...
  • 知識點: 1.UITableView搜索功能 <UITableViewDataSource,UITableViewDelegate,UISearchResultsUpdating,UISearchControllerDelegate> UITableView搜索功能 1.UISearchContro ...
  • 一、引言在iOS開發中使用動畫時,可以通過設置動畫的duration、speed、begintime、offset屬性,來設置動畫的時長、速度、起始時間及起始偏移。用一個簡單的例子來說明各個參數的的作用。動畫很簡單,一個紅色的方塊從左移到右邊。動畫的持續時間是1s,沒有重覆,效果如下。 CFTime... ...
  • 首先看一下界面: SharedPreferencesUtils.java ...
一周排行
    -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.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...