SQL Server求生秘籍

出版時間:2009-2  出版社:人民郵電出版社  作者:(美) 亨德森 主編,若啟,一輝,瞿杰 譯  頁數(shù):342  字數(shù):554000  
Tag標簽:無  

前言

原本我想在本書中讓微軟技術(shù)支持工程師撰寫多年來在SQL Server的技術(shù)支持工作中所學到的知識。當我加入微軟后,令我驚奇的是,技術(shù)支持工程師們并沒有把關(guān)于產(chǎn)品支持的實踐知識(在認識論中叫作“領(lǐng)域知識”)記錄下來。這些知識僅僅停留在口口相傳的狀態(tài)。當然,這導致了一個問題:人們并不知道如何做好工作,除非有熱心人來向他們展示該如何做。這也是一種非常容易犯錯誤的方式,會導致一些最重要的產(chǎn)品支持知識集中在少數(shù)人手中——這些經(jīng)驗被他們充分利用,但其他的支持團隊卻不了解這些知識。加入微軟之前,我做全職軟件開發(fā)工程師已經(jīng)20多年了。令我十分驚訝的是,原來支持部門的高端人群都是些曾經(jīng)做過開發(fā)的人。通常,在成為技術(shù)支持工程師之前,他們都有3~5年的開發(fā)或相關(guān)工作經(jīng)驗。作為一名職業(yè)開發(fā)人員,我很難想象技術(shù)支持也可以做長工。對于我來說,支持工作似乎與軟件開發(fā)世界中的看門人類似。他們不得不幫那些編寫亂糟糟代碼的開發(fā)者“擦屁股”的人。雖然我知道這很重要,但是私下里還是覺得把技術(shù)支持工作作為職業(yè)并不是一件開心的事。盡管如此,確實有好幾個程序員前輩呆在技術(shù)支持部門,這讓我感到迷惑。

內(nèi)容概要

  本書幫助你解決眾多數(shù)據(jù)庫引擎方面的問題,每一章從關(guān)鍵的SQL Server 組件入手,然后探討用戶遇見的常見問題,并給出解決方案。本書的主要內(nèi)容包括等待和阻塞、數(shù)據(jù)毀壞和恢復、內(nèi)存、過程緩存、查詢進程等。本書的作者都是來自微軟公司SQL Server 開發(fā)團隊和客戶支持服務部門的支持專家。在你的SQL Server 系統(tǒng)遇到問題時,本書將變得不可或缺。  本書適合數(shù)據(jù)庫管理員和數(shù)據(jù)庫開發(fā)人員閱讀。    作者簡介:  Ken Henderson(1967-2008)SQL Sewer世界級權(quán)威。生前供職于微軟SQL Sewer開發(fā)組。以Guru's Guide系列經(jīng)典著作和SQLDiag等工具享譽業(yè)界。  創(chuàng)作團隊  來自SQL Server開發(fā)小組的7位開發(fā)人員和來自微軟客戶支持服務機構(gòu)的3位支持專家,他們都有豐富的開發(fā)經(jīng)驗,熟悉SQL Sewer源代碼。

書籍目錄

第1章 等待和阻塞 1.1 等待類型 1.2 對阻塞問題進行故障排查 1.3 識別阻塞  1.3.1 通過sys.dm_os_waiting_tasks來識別阻塞  1.3.2 從統(tǒng)計上識別阻塞 1.4 確定阻塞的原因  1.4.1 當前的語句和計劃  1.4.2 阻塞模式  1.4.3 阻塞鏈 1.5 資源類型的細節(jié)  1.5.1 閂鎖  1.5.2 鎖  1.5.3 外部等待類型  1.5.4 計時器和隊列等待類型  1.5.5 IO操作的等待類型  1.5.6 其他等待類型 1.6 死鎖 1.7 監(jiān)視阻塞  1.7.1 等待的統(tǒng)計信息  1.7.2 當前的等待信息 1.8 小結(jié) 1.9 其他資源第2章 數(shù)據(jù)損壞及恢復 2.1 基本原理 2.2 SQL Server 2005存儲內(nèi)幕  2.2.1 數(shù)據(jù)庫及文件狀態(tài)  2.2.2 資源數(shù)據(jù)庫  2.2.3 目錄視圖和基本系統(tǒng)表  2.2.4 分配結(jié)構(gòu)  2.2.5 數(shù)據(jù)庫校驗和  2.2.6 快速恢復  2.2.7 延期事務  2.2.8 只讀的壓縮數(shù)據(jù)庫 2.3 SQL Server 2005增強  2.3.1 備份增強  2.3.2 還原增強  2.3.3 DBCC CHECKDB增強 2.4 數(shù)據(jù)恢復最佳實踐  2.4.1 備份/還原最佳實踐  2.4.2 數(shù)據(jù)庫及日志最佳實踐  2.4.3 DBCC CHECKDB最佳實踐 2.5 數(shù)據(jù)恢復故障排查場景  2.5.1 系統(tǒng)數(shù)據(jù)庫恢復  2.5.2 恢復資源數(shù)據(jù)庫  2.5.3 創(chuàng)建tempdb故障  2.5.4 重裝操作系統(tǒng) 2.6 用戶數(shù)據(jù)庫不可訪問  2.6.1 數(shù)據(jù)庫被標記為RECOVERY_PENDING  2.6.2 處理延遲事務  2.6.3 數(shù)據(jù)庫被標記為SUSPECT  2.6.4 粘貼數(shù)據(jù)庫故障 2.7 BACKUP/RESTORE故障  2.7.1 BACKUP故障  2.7.2 RESTORE故障 2.8 數(shù)據(jù)庫一致性錯誤  2.8.1 處理數(shù)據(jù)庫一致性運行時錯誤  2.8.2 處理DBCC CHECKDB錯誤  2.8.3 修復與還原  2.8.4 每個錯誤表示什么  2.8.5 解釋  2.8.6 用戶動作  2.8.7 REPAIR_ALLOW_DATA_LOSS真正的意思是什么  2.8.8 進行恢復之前的根本原因分析  2.8.9 如果修復沒有用,應該怎么辦  2.8.10 復制數(shù)據(jù)與修復  2.8.11 找出損壞的根本原因:清單第3章 內(nèi)存 3.1 Windows內(nèi)存管理入門  3.1.1 內(nèi)部的虛擬內(nèi)存——虛擬地址空間  3.1.2 外部虛擬內(nèi)存  3.1.3 內(nèi)部物理內(nèi)存  3.1.4 外部物理內(nèi)存  3.1.5 內(nèi)存壓力  3.1.6 NUMA支持 3.2 SQLOS和SQL Server的內(nèi)存管理  3.2.1 內(nèi)存結(jié)點  3.2.2 內(nèi)存clerk  3.2.3 內(nèi)存對象  3.2.4 內(nèi)存緩存  3.2.5 緩沖池  3.2.6 故障排查第4章 過程緩存 4.1 過程緩存的架構(gòu)  4.1.1 緩存對象的類型  4.1.2 過程緩存的結(jié)構(gòu)  4.1.3 過程緩存和內(nèi)存  4.1.4 非緩存計劃和零成本計劃  4.1.5 計劃的共享  4.1.6 重編譯  4.1.7 參數(shù)化  4.1.8 緩存查找如何工作  4.1.9 緩存計劃復用  4.1.10 刷新過程緩存 4.2 常見緩存相關(guān)問題及解決方案  4.2.1 使用過程緩存來確定代價昂貴的查詢  4.2.2 參數(shù)截取  4.2.3 較差的計劃復用造成較高的編譯時間  4.2.4 由于過度的緩存查找時間導致的高CPU問題  4.2.5 由過程緩存所引起的內(nèi)存壓力 4.3 小結(jié)第5章 查詢處理器 5.1 查詢處理器基礎  5.1.1 編譯—執(zhí)行序列  5.1.2 執(zhí)行計劃  5.1.3 查詢編譯和計劃選擇  5.1.4 特殊的優(yōu)化方法及場景 5.2 常見問題  5.2.1 編譯時間和參數(shù)化  5.2.2 索引化  5.2.3 基數(shù)和開銷估算 5.3 故障排查  5.3.1 診斷  5.3.2 控制 5.4 最佳實踐  5.4.1 使用面向集合的編程模型    5.4.2 提供約束和統(tǒng)計的信息  5.4.3 注意復雜的構(gòu)造  5.4.4 盡可能地避免動態(tài)語言特性 5.5 進階閱讀第6章 服務器崩潰和其他致命故障 6.1 基礎知識  6.1.1 SQL Server 2005服務器恢復內(nèi)幕  6.1.2 SQL Server 2005的增強特性 6.2 致命錯誤與服務器恢復故障排查  6.2.1 服務器啟動故障排查  6.2.2 對服務器致命錯誤進行故障排查  6.2.3 服務器掛起問題的故障排查第7章 Service Broker相關(guān)問題 7.1 Broker總覽   7.1.1 為什么要使用Service Broker  7.1.2 Service Broker的對象和術(shù)語  7.1.3 內(nèi)部架構(gòu) 7.2 主要的診斷工具和方法  7.2.1 傳輸隊列視圖  7.2.2 SQL Profiler——Service Broker跟蹤事件  7.2.3 錯誤日志和NT事件日志 7.3 Broker故障排查實踐  7.4 其他Service Broker診斷工具  7.4.1 視圖  7.4.2 Perfmon  7.4.3 DBCC CHECKDB 7.5 進階閱讀第8章 SQLOS和調(diào)度問題 8.1 SQLOS架構(gòu)  8.1.1 內(nèi)存和CPU結(jié)點  8.1.2 調(diào)度器  8.1.3 任務和worker  8.1.4 SQL Server和SQLOS 8.2 配置和故障排查  8.2.1 結(jié)點配置  8.2.2 網(wǎng)絡連接關(guān)聯(lián)  8.2.3 調(diào)度器  8.2.4 任務與worker  8.2.5 調(diào)度器之間的負載均衡任務  8.2.6 Max Worker Threads配置  8.2.7 Lightweight Pooling配置  8.2.8 Affinity Mask配置  8.2.9 磁盤I/O完成處理  8.2.10 搶占式I/O完成處理  8.2.11 調(diào)度器監(jiān)視器  8.2.12 硬件配置  8.2.13 專用管理員連接 8.3 進階閱讀第9章 tempdb相關(guān)問題 9.1 SQL Server 2005中有何改進  9.1.1 tempdb日志文件的IO動作少了  9.1.2 tempdb數(shù)據(jù)文件自動增長更快  9.1.3 改進tempdb的并行訪問的可擴展性  9.1.4 改進tempdb中多個文件的可擴展性 9.2 tempdb空間是如何使用的  9.2.1 什么是用戶對象  9.2.2 什么是內(nèi)部對象  9.2.3 什么是版本存儲對象 9.3 故障排查實踐  9.3.1 如果tempdb空間不足,你該怎么辦  9.3.2 什么是tempdb頁面閂鎖競爭 9.4 小結(jié)第10章 群集問題 10.1 示例 10.2 工具 10.3 將性能調(diào)整到可接受的水平上  10.3.1 添加結(jié)點  10.3.2 為什么群集SQL Server實例發(fā)生故障轉(zhuǎn)移  10.3.3 為什么故障轉(zhuǎn)移要花這么長時間  10.3.4 故障轉(zhuǎn)移之后沒人可以連接  10.3.5 添加磁盤  10.3.6 替換磁盤  10.3.7 轉(zhuǎn)移數(shù)據(jù)庫 10.4 小結(jié)

章節(jié)摘錄

插圖:2.2.1數(shù)據(jù)庫及文件狀態(tài)在SQL Server 2000中,數(shù)據(jù)庫的狀態(tài)(或者說狀況)是最難以理解的。用戶必須將sysdatabases表中的特殊位解碼,并且何時進行狀態(tài)切換的行為不是始終如一的。SQL Server 2005在消除這個缺點上做得非常好。首先,在sys.databases目錄視圖中,可以找到數(shù)據(jù)庫的描述性狀態(tài)(在一個名為state的列中)。其次,數(shù)據(jù)庫狀態(tài)的意義及行為是易于理解并且始終如一的。例如,當你通過ALTER DATABASE SET OFFLINE來強迫一個數(shù)據(jù)庫離線時,數(shù)據(jù)庫就轉(zhuǎn)到OFFLINE狀態(tài)。在SQL 2000盧并不總是這樣。為了理解這些數(shù)據(jù)庫狀態(tài)的意義,以及一個數(shù)據(jù)庫如何在各個狀態(tài)間切換,請看圖2-1。

媒體關(guān)注與評論

“本書的內(nèi)容是其他任何博客、網(wǎng)站和圖書都沒有的。系統(tǒng)出問題時。它將成為你的救命稻草?!薄  狿inal Dave,微軟MVP“此書得非常好,涵蓋了對大量復雜問題進行故障排查的詳細解析。我認為每一位優(yōu)秀的MSSQL DBA都應該擁有?!  狝mazon.com評論

編輯推薦

《SQL Server求生秘籍》的出版將徹底改變這種局面。微軟技術(shù)大師Henderson邀請了微軟數(shù)據(jù)庫產(chǎn)品開發(fā)和支持團隊的多位資深工程師,各展所長,第一次集中公開了許多以前在微軟內(nèi)部口口相傳的SQL Sewer技術(shù)機密。微軟SQL Server內(nèi)部技術(shù)資料大曝光,來自SQL Server開發(fā)小組和支持部門的夢之隊打造,SQL Server故障排除圣經(jīng)。數(shù)據(jù)庫技術(shù)人員都不免面臨這樣的困境:每隔一段時日,數(shù)據(jù)庫系統(tǒng)就會因為一些奇怪的問題無法正常運作,然而由于缺乏底層信息,他們常常無法應對這些問題。全書由10章組成,每一章都首先精辟地剖析SQL Sewer的一個關(guān)鍵內(nèi)部機制。然后深入探討常見的問題及其解決方案,包括等待與阻塞、內(nèi)存、緩存、查詢處理、Service Broker、tempdb和群集等主題。書中討論了許多底層數(shù)據(jù)結(jié)構(gòu),詳細解釋了大量錯誤日志、棧轉(zhuǎn)儲的含義。很多內(nèi)容都是直接查看SQL Sewer源代碼總結(jié)提煉出來的,參考價值不言而喻。

圖書封面

圖書標簽Tags

評論、評分、閱讀與下載


    SQL Server求生秘籍 PDF格式下載


用戶評論 (總計8條)

 
 

  •   很好一本書,做SQLSERVERDBA的得好好看看,普通開發(fā)人員就算了.里面講的很多東西都很深,需要很多SQLSERVER的知識.贊一個.
  •   原版書面,都是SQLServer2005,譯成中文就成了,2005了。這書是以SQLServer2005的平臺來說的,譯書的人,不清楚SQLServer2000和SQLServer2005有很大的不同嗎。這種錯誤出現(xiàn)于“圖靈叢書”之手,有點不專業(yè)了!書當然很好!
  •   翻譯的不好,內(nèi)容不錯,不易懂.
  •   新買的書連個目錄也沒有,直接從第三頁開始了。
  •   收到完全是舊書,光盤也不見了!
  •   雖然很薄,但質(zhì)量很高
  •   對深入了解SQL Server有幫助。
  •   書的內(nèi)容非常好,很具有實戰(zhàn)性。翻譯上就差一點了。
 

250萬本中文圖書簡介、評論、評分,PDF格式免費下載。 第一圖書網(wǎng) 手機版

京ICP備13047387號-7