●顧問級專家教你找出資料庫真正的效能瓶頸,讓系統更符合使用者需求。
●詳解DBA必備實作技術:工具程式應用、索引及查詢效能、交易及鎖定管理。
●分析系統設計應注意之事項、程式撰寫之建議、各資料庫物件使用方式優劣。
-本書內容-
完整涵蓋企業資料庫管理最經典且實用的課題,適合SQL Server DBA閱讀。書中提供了效能調校或錯誤處理的建議與提示,並藉由作者多年的顧問經驗,定義、找尋與解決效能調校之疑問,透過實務案例協助DBA建立正確的觀念、充分瞭解系統架構。在Big Data時代協助企業在資料革命中領先,成為新贏家!
■ 從SQL Server架構開始介紹,深入探究SQL Server的運作原理,如:軟硬體存取特徵、索引、資料存取介面、交易與鎖定等。
■ 檢視與模擬SQL Server與效能相關之議題,破解DBA日常所面臨的問題,並提供最適方案。
■ 詳解系統設計應注意之事項,包含:前端應用程式設計如系統架構、ADO.NET等對效能之影響、程式撰寫之建議,同時解析各資料庫物件使用方式的優劣。
Microsoft SQL Server 已是世界上應用最普遍的大型資料庫之一,在許多系統中都有它的蹤跡,就我們所觸及的系統:數tera的資料量、全球近億筆記錄需要在多國多伺服器間複寫、在一般硬體上每秒鐘新增上千筆記錄、同時上線存取SQL Server的人數達數千人、以上百個SQL Server伺服器為骨幹,負責龐大企業集團時刻的營運…凡此種種,皆彰顯了SQL Server無比的運算力。
而每個使用資料庫的人,都可能面臨到資料累積、使用人數增加、應用面向擴增、當初系統設計或程式撰寫不良等各種原因,導致效能變差。讓使用者無法忍受系統回應的時間,待處理的工作長期停滯在系統的佇列中,甚至是程式無法執行、系統崩潰、資料大亂。然而資訊系統已經是一般企業不可或缺的競爭力之一,而資料庫系統又往往是資訊系統的核心,跑不動的資料庫絕對是莫大的傷害。
資料庫管理師(DBA)或系統開發人員在發生效能問題的初期,大都沒有方向,不知如何解決問題。市面上有一堆書籍教人如何利用SQL Server建立資料庫,或是以.NET等程式語言存取資料庫。其實,資料庫一下子就建好了,經過個把月,程式也寫完了,但今後數年都需要對資料庫及系統進行效能調校。
本書嘗試定義、找尋與解決問題。深入探究SQL Server的運作原理,如:索引、資料存取介面、交易與鎖定等等。我們將檢視與模擬SQL Server運行時與效能相關的議題,透過工具來探索問題的來龍去脈。例如,大量的使用者同時存取時,系統上有太多的鎖定/被鎖定/死結(lock/block/deadlock),其形成原因、如何追蹤、如何解決,諸如此種大部分資料庫管理師可能天天面臨的問題。
作者簡介:
胡百敬 Byron Hu
現任恆逸資深講師,集英信誠資深合夥顧問
擔任微軟、永豐餘、中興工程等企業顧問。擁有多年n-Tier架構暨物件導向式系統分析及設計、資料庫分析設計、Microsoft .NET開發與商業智慧系統分析設計等實作經驗,並參與許多大型專案開發,主講微軟全省百場以上大型研討會,也是一位活躍於IT媒體的專欄作家。具 MCT、MCAD、MCSD 國際認證執照,並獲選為微軟最有價值專家(MVP)。
著作:
■ SQL Server 2012 SSIS整合服務|悅知文化
■ SQL Server 2012 T-SQL 資料庫設計|悅知文化
■軟體測試實戰–Visual Studio & Team Foundation Server|悅知文化
■ SQL Server 2008 資料庫開發實戰|悅知文化
■ SQL Server 2008 管理實戰-進階維護篇|悅知文化
■ SQL Server 2008 T-SQL 資料庫設計|悅知文化
■ SQL Server 2008 SSIS 整合服務|悅知文化
■ SQL Server 2008 管理實戰-營運管理篇|悅知文化
■ SQL Server 2008 Reporting Services報表服務|悅知文化
Blog:byronhu.spaces.live.com/
周妙謙 Miao Chou
現任元信達資料庫管理師
曾任職於光電、製造業及教育機構,擁有跨產業多項資訊專案建置與系統整合經驗。對資訊技術具高度熱忱,樂於學習新知,在SQL Server、Microsoft .NET開發等資訊專業領域皆有深入研究。
著作:
■ SQL Server 2012 T-SQL 資料庫設計|悅知文化
姚巧玫 Sandy Yao
現任日盛金控資訊處營運管理部專案襄理
SQL Server/BI/Reporting Service開發與系統架構、Microsoft .NET開發等專業知識皆有深入的研究。對於SQL 有10年以上的使用經驗,樂於分享技術知識,曾獲選為微軟最有價值專家(MVP)。
著作:
■ SQL Server 2012 SSIS整合服務|悅知文化
■ SQL Server 2008 資料庫開發實戰|悅知文化
■ SQL Server 2008 管理實戰-進階維護篇|悅知文化
■ SQL Server 2008 T-SQL 資料庫設計|悅知文化
■ SQL Server 2008 SSIS 整合服務|悅知文化
■ SQL Server 2008 管理實戰-營運管理篇|悅知文化
劉承修 Stephen Liu
現任集英信誠資深顧問Chalet Tech Consultant of Database Management
曾任日盛金控資訊處營運管理部專案襄理。專長為資料庫管理流程設計、效能調校、高可用性設計、安全性設計及資訊安全法規遵循;專案管理、ITSM。擁有PMP、ITIL、ISO 27001主導稽核員(Lead Auditor)、MCSE、MCSA、MCDBA、MCTS、MCITP、OCA、OCP、CCNA等國際認證。
著作:
■ SQL Server 2012管理實戰|悅知文化
■ SQL Server 2008 管理實戰-進階維護篇|悅知文化
目錄
第01篇 效能調教與SQL Server 概觀
第01章 效能調教概觀
01-01 什麼是效能調教
01-01 什麼是效能調教
01-02 建立效能的基準線
01-03 效能調校的步驟–DETECT
第02章 SQL Server架構簡介
02-01 SQL Server架構
02-02 各項硬體使用剖析
第02篇 監控與工具程式
第03章 效能監控概論
03-01 監控系統運行效能
03-02 監控資料庫運行效能
03-03 監控資料庫效能工具
03-04 運用效能監控完成負載容量管理
第04章 外部監控工具
04-01 效能監視器
04-02 IIS Log分析
04-03 Internet Explorer 11的F12開發人員工具
04-04 Wireshark
第05章 效能調教常用的SQL工具
05-01 活動監視器Activity Monitor
05-02 Management Studio的報表和儀表板
05-03 Performance Dashboard Reports
05-04 效能資料收集分析與管理資料倉儲
05-05 公用程式控制點
05-06 SQL Profiler概觀
05-07 擴充事件
第06章 動態管理檢視及函數
06-01 使用權限
06-02 動態管理物件的分類
06-03 SQL Server執行個體當下狀況
06-04 SQL Server執行個體累積執行狀況
第03篇 資料庫設計
第07章 資料庫設計
07-01 資料庫設計
07-02 使用分割資料表切割和平行運作
07-03 TEMPDB系統資料庫之規劃
07-04 交易記錄
07-05 備份與還原
07-06 大量資料載入
第08章 索引
08-01 索引概觀
08-02 索引維護
08-03 統計資訊
08-04 使用索引調教的工具來提升查詢
第09章 資源管理員
09-01 認識資源管理員
09-02 觀察資源管理員的運作與使用注意事項
09-03 實作練習:使用資源管理員
第04篇 應用程式設計
第10章 T-SQL語法
10-01 有效的查詢參數
10-02 其他注意事項
10-03 善用新的DML語法
10-04 SQL Server提供的公共變數
第11章 執行計畫
11-01 透過SQL Server Management Studio檢視執行計畫
11-02 分析耗資源的運算子
11-03 多工緩衝處理
11-04 編譯與快取執行計畫
11-05 影響計畫重用的因素
11-06 執行計畫與Execution Context
11-07 觀察執行計畫的使用
11-08 小心評估執行計畫
11-09 各階段的最佳化執行計畫
第12章 交易與鎖定
12-01 鎖定
12-02 資料列版本控制
12-03 交易
12-04 死結
12-05 觀察與分析系統的鎖定狀況
12-06 鎖定的原因及相關處理
第13章 前端應用程式設計
13-01 程式架構
13-02 使用者端與SQL伺服器的互動
13-03 資料快取
13-04 錯誤處理
附錄A SQL Server 2014強化對記憶體的使用
A-01 記憶體最佳化相關技術
A-02 建立資料庫與記憶體最佳化物件
A-03 資料記錄與索引
A-04 更新資料與交易管理
A-05 管理
A-06 轉換
附錄B 資料庫主機效能調校計畫
第01篇 效能調教與SQL Server 概觀
第01章 效能調教概觀
01-01 什麼是效能調教
01-01 什麼是效能調教
01-02 建立效能的基準線
01-03 效能調校的步驟–DETECT
第02章 SQL Server架構簡介
02-01 SQL Server架構
02-02 各項硬體使用剖析
第02篇 監控與工具程式
第03章 效能監控概論
03-01 監控系統運行效能
03-02 監控資料庫運行效能
03-03 監控資料庫效能工具
03-04 運用效能監控完成負載容量管理
第04章 外部監控工具
04-01 效能監視器
04-02 IIS Log分析
04-03 Internet Explorer 11的F1...