1 / 33

升級 SQL Server 2000/2005 至 SQL Server 2008

升級 SQL Server 2000/2005 至 SQL Server 2008. 升級資料庫. 胡百敬 http://byronhu.spaces.live.com/ 資深講師 恆逸教育訓練中心 ( 精誠資訊 ). 議程. 升級到 SQL Server 2008 << 資料庫篇 >> 升級計畫 升級方式 升級時停機時間考量 資料庫相容層級 相容性測試. 升級計劃 --Best Practice. 執行 Upgrade Advisor 確認必須事先處理的事項 完成備份作業 減少升級變數 Server Level -- 版本,語言

beau-mckay
Télécharger la présentation

升級 SQL Server 2000/2005 至 SQL Server 2008

An Image/Link below is provided (as is) to download presentation Download Policy: Content on the Website is provided to you AS IS for your information and personal use and may not be sold / licensed / shared on other websites without getting consent from its author. Content is provided to you AS IS for your information and personal use only. Download presentation by click this link. While downloading, if for some reason you are not able to download a presentation, the publisher may have deleted the file from their server. During download, if you can't get a presentation, the file might be deleted by the publisher.

E N D

Presentation Transcript


  1. 升級SQL Server 2000/2005至 SQL Server 2008 升級資料庫 胡百敬 http://byronhu.spaces.live.com/ 資深講師 恆逸教育訓練中心(精誠資訊)

  2. 議程 • 升級到 SQL Server 2008 <<資料庫篇>> • 升級計畫 • 升級方式 • 升級時停機時間考量 • 資料庫相容層級 • 相容性測試

  3. 升級計劃--Best Practice • 執行 Upgrade Advisor 確認必須事先處理的事項 • 完成備份作業 • 減少升級變數 • Server Level --版本,語言 • Database Level –單一或多個資料庫 • 架構性改變--32 bit 到 64 bit,移到容錯叢集 • 規劃停機時間 • 選擇適當的升級方式 • 確認軟硬體需求 SQL Server 2008 線上叢書\使用者入門\初始安裝

  4. 升級規劃考慮事項

  5. 定義 • Upgrade (直接升級,in-place upgrade) • 直接透過安裝作業進行升級,保留原始資料 • 執行個體的名稱不變 • 在安裝過程中自動執行 • Migration (平行移轉,side-by-side migration) • 先執行一個全新的安裝作業 • 新舊執行個體可以同時存在 • 透過複製的作業從原本執行個體資料庫複製到新的執行個體中 • 需要較多手動作業處理

  6. 直接升級 • 直接透過安裝作業進行升級,保留原始資料 • 在安裝過程中自動執行 SQL Server 2008 Instance: MyInstance SQL Server 2000/2005 Instance: MyInstance

  7. 直接升級 Point of no return Instance仍然正常運作 附加資源資料庫 將服務重新導向新的環境 安裝SQL Server 2008 環境 重啟 服務 執行升級 所需的scripts 安裝 必要元件 升級 完成 升級 開始 啟動服務 於single-user 模式 停止 服務 停止 服務 開始升級所有的 資料庫 移除舊的環境 檢查系統環境設定是否正確 Instance 停止運作 Instance 回復正常運作 從此步驟開始部分資料庫就可以開始使用

  8. 平行移轉 • 先執行一個全新的安裝作業 • 新舊執行個體可以同時存在 • 透過複製的作業從原本執行個體複製到新的執行個體中 SQL Server 2000/2005 Instance: MyInstance SQL Server 2008 Instance: MyNEWInstance 比較與確認

  9. 直接升級的分析 • 直接升級(in-place upgrade) • 會將系統中該執行個體所有的元件都一起升級,不會有 DB 升成 2008,而 AS 還留在舊版 • 資淺的 DBA 就可執行 • 優點 • 安裝程式直接支援,簡單、快速 • 比較適用於單純的系統移轉 • 不用額外另購新的硬體設備 • 應用程式不用改變,使用一樣的執行個體名稱 • 缺點 • 所有的元件、DB 都一起升級 • 缺少 DBA 主動控制 • 升級過程中,系統停止對外服務 • 32 bit 不能升成 64 bit,DTS、通知服務直接升級也可能有問題 • Rollback 時,需要重建舊環境,並還原升級前備份的 DB

  10. 平行移轉的分析 • 平行移轉(side-by-side migration) • 在同一台機器上可以同時執行 2008、2005、2000 等執行個體 • 需要資深的 DBA • 優點 • 移轉的過程中 DBA 有較多控制權,且可獨立地對各資料物件一對一地移轉,個別進行驗證與測試 • 移轉過程中原執行個體仍可以繼續提供服務,系統整體停機時間比較短 • 可比較兩個系統的執行結果,以確認相容性 • 缺點 • 需要DBA較多手動執行移轉 • 可能需要額外的硬體或是相關資源 • 需要額外的磁碟空間 • 更改伺服器名稱 • 應用程式需要重新導向到新的執行個體名稱 • 修改連線字串 • 若要維持同時運作,需要考慮資料同步

  11. 平行移轉時,需要手動移轉的物件 • 資料庫檔案 • 建在 Master 等系統資料庫內的物件 • SSASCube • 各種伺服器設定 • 安全設定 • Agent 服務的工作 • SSIS 封裝

  12. 升級時停機時間考量 • 可手動先安裝.NET Framework 3.5 SP1 及 SQL Server Native Client • 升級時安裝程式自動升級 logins、passwords 和 permissions • 升級時所有資料庫均會是 offline • 最好依 upgrade advisor 建議先修正可縮短安裝後測試時間 • 如採用平行移轉,可利用 SQL 2008 的部分還原,將Primary Filegroup 先還原,再還原其他的 Filegroup • 為減少當機時間,可讓 SQL 2000/2005 DB 保持線上運作,先還原到 SQL 2008 with norecovery,備份 2000/2005 最後一個交易記錄,再 Restore 到 2008 with Recovery

  13. 升級前的準備工作 -- 環境準備 • 符合 SQL Server 2008 最低硬體與軟體需求 • 處理器 : Pentium 3+、1 GHz+ 建議 2 GHz + • 記憶體 : 512 MB+ 建議 2 GB 以上 • 作業系統 : Windows Server 2003 + SP2、Windows Server 2008 • 使用者端的工具,如 SSMS、BIDS 等,都需要 IE 6 SP1+ • 版本差異 • 資料庫版本(Enterprise  Enterprise ) • 跨語系升級(English任何國別語言的版本,反之不可) • 平台(Windows 2000Windows 2003/Windows 2008) • 驅動程式(如JDBC for SQL Server 2005 下載:Microsoft SQL Server 2008 Feature Packhttp://www.microsoft.com/downloads/details.aspx?displaylang=zh-tw&FamilyID=c6c3e9ef-ba29-4a43-8d69-a2bed18fe73c) • 可升級的 SQL Server 版本 • SQL Server 2000 Service Pack 4、SQL Server 2005 Service Pack 2 • 執行 Upgrade Advisor 進行評估作業並檢視報表 • 備份舊有的資料庫,且確定備份資料可用,擬定升級失敗的還原計畫

  14. 升級與移轉的工具 • 分析工具 Upgrade Advisor • 可直接利用 SQL Server 2008 安裝程式單獨安裝 • 適用所有的元件 • 使用 SQL Server 2008 安裝程式直接升級 • 資料庫主體 • 分析服務 • 報表服務 • 一對一移轉精靈 • 分析服務 • 資料轉換服務轉到 SSIS

  15. 升級資料庫引擎元件可運用的技術 • 直接升級 • SQL Server 安裝精靈 • 平行移轉 • 複製資料庫精靈 • 卸離資料庫/附加資料庫 • 卸離 SQL Server 2000/2005 資料庫(sp_detach_db) • 在SQL Server 2008 中進行附加作業(… FOR ATTACH) • 備份資料庫/還原資料庫 • 直接在 SQL Server 2008 中還原前版的備份檔案 • SQL Server 7.0 之前的版本 • 先升級到 2000/2005 • Integration Services(SSIS)匯入和匯出精靈 • 使用 BCP.exe

  16. SQL Server 2008 安裝精靈 • 安裝全新的 SQL Server 2008 執行個體 • 可與 SQL Server 2000/2005 並存 • 將 SQL Server 2000/2005 升級為 SQL Server 2008

  17. 卸離資料庫/附加資料庫 • 可以使用卸離與附加,可將資料庫SQL Server 2000/2005 進行升級;但有下列限制: • 無法附加 master、model 或 msdb 資料庫 • 注意事項 • sp_detach_db(卸離) • 依預設,會執行 UPDATE STATISTICS 來更新統計值 • 若不更新統計值,請指定:@skipchecks='true‘ • sp_attach_db(附加) • 請改用 CREATE DATABASE 陳述式搭配 FOR ATTACHT、FORATTACH_REBUILD_LOG 選項 • 資料庫擁有者 附加資料庫時,可以變更資料庫擁有者

  18. 備份資料庫/還原資料庫 • 可利用SQL Server 2000/2005 的備份檔來進行還原升級;但有下列限制: • 無法還原 master、model 或 msdb 資料庫 • 注意事項 • SQL Server 2008 使用與之前版本不同的預設路徑,請記得搭配使用:MOVE 選項 • 資料庫擁有者 • 還原資料庫時,可以變更資料庫擁有者

  19. 升級後的作業流程 • 執行 Upgrade Advisor 報表中所有的後續作業 • 更正相關資料 • 重新建置記錄檔傳送 • 執行應用程式測試 • 驗證日常維護工作的正常運行 • 系統正式上線 • 監控系統的運行

  20. 執行 Upgrade Advisor 報表中所有的後續作業 • 執行 Upgrade Advisor 報表中所有的後續作業 • 例如 • 更新統計資訊 • 重建部分Cube • 資料轉換服務與SSIS的移轉 • 更改資料庫相容版本(10.0) • 重新設定交易記錄傳送(log shipping) • 進行升級測試 • 啟動應用程式 • 檢視代理程式的工作與資料庫維護計畫作業 • 監控系統活動與效能

  21. 更正相關資料 • 執行 DBCC UPDATEUSAGE • 更正任何無效的資料列或頁面計數 • Ex. DBCC UPDATEUSATE(Northwind) • 執行 sp_updatestats • 更新統計資料,執行最佳化查詢效能 • Ex. Exec sp_updatestats • 重建、重新擴展全文檢索目錄 • 因為升級過程中會停用全文檢索 • 設定 『SQL Server 介面區組態』Policy • 減少系統的可攻擊介面區 • 調整資料庫的相容性層級為:100 • 若 2000 的資料庫有使用 APPLY、PIVOT、TABLESAMPLE 或 UNPIVOT 等關鍵字時

  22. 資料庫相容性層級 • 60 = SQL Server 6.0 (不支援) • 65 = SQL Server 6.5 (不支援) • 70 = SQL Server 7.0 (不支援) • 80 = SQL Server 2000 • 90 = SQL Server 2005 • 100 = SQL Server 2008 • 先將不相容的物件修改完,可將相容層級改為 100,才可使用SQL 2008 的新功能 • ALTER DATABASE database_name SET COMPATIBILITY_LEVEL = { 80 | 90 | 100 } • 各相容性層級的差異請參考線上說明: ms-help://MS.SQLCC.v10/MS.SQLSVR.v10.zh-CHT/s10de_6tsql/html/ca5fd220-d5ea-4182-8950-55d4101a86f6.htm

  23. 測試作業 • 測試項目 • 準備測試 • 建立測試系統 • 注意事項 • 測試系統的升級 • 升級後的測試

  24. 準備測試 • 確定功能 • 新架構下的效能與穩定 • 新架構本身的功能是否正常 • 確定應用程式的存取 • 舊有功能是否都可以使用 • 是否可以用到新功能 • 評估需求 • 有用到哪些功能 • Database Engine、Analysis Services、Reporting Services、SSIS(DTS)、Replication… • 評估資源 • 可否建立獨立的測試環境 • 了解可用的工具

  25. 建置應用程式相容性分析環境(2) • 使用 SQL Server Upgrade Assistant(SSUA) • 『Capture Playback』功能與『Compare Trace Files』功能 • 下載網址: • http://www.scalabilityexperts.com/

  26. 建立測試系統 • 建立系統某個時間點的複製品 • DBCC CHECKDB • Full Database Backups • 紀錄資料庫在某個時間點的活動 • SQLProfiler • 儘量錄製完整的系統活動,但不要大量重複的動作 • 不影響線上系統的情況下測試與分析 • 並未取代任何測試,若你系統原本就有測試,例如:整合測試,壓力測試等 Test case 與 script 都可以加入測試

  27. 注意事項 • 安全 • 資料的安全 • 獨立的系統 • 安裝正確的 SQL 版本 • 測試環境儘量與正式環境相同

  28. 升級後 – 用Playback Report Viewer比較結果 • 執行Run Trace Replay比較SQL Server 2000/2005 與 2008 的執行結果 Successful replays Successful replays Replay Error

  29. 測試系統的升級 • 升級你的測試系統 • 透過 Playback 建立儘量正確的複製過程 • 使用與正式系統相同的方式升級或轉移 • Setup 或 Restore/Attach? • 觀察升級的行為,以此為正式升級的模擬 • 升級將會花掉多久的時間? • 在升級過程中是否發生了未預期的狀況? • 是否所有的資料庫都能成功升級? • 是否需要/能夠改變資料庫的相容層級?

  30. 升級後的測試 • 測試使用該伺服器 • 執行 test suites、應用程式、ad-hoc tests • 檢察各應用程式的 log,以確定各服務的行為 • 檢查相關服務的 logs • 若錯誤的型態、頻率有變化,可能代表有其他的問題

  31. 大型資料庫升級考量 • Backup /Restore 所需花的時間 • 測試環境無法完全複製線上環境,以致無法顯示所有可能的狀況 • 如執行平行移轉,需重複存放資料,空間夠不夠 • 如空間夠,可透過如 SAN 等硬體節省備份還原時間

  32. SQL 相關資訊 • SQL Server 2008 Upgrade Technical Reference Guide • http://www.microsoft.com/downloads/details.aspx?FamilyID=66d3e6f5-6902-4fdd-af75-9975aea5bea7&displaylang=en • SQL Server 2008 Books Online • 檢視不支援(移除)功能 • http://www.microsoft.com/downloads/details.aspx?FamilyID=19db0b42-a5b2-456f-9c5c-f295cdd58d7a&DisplayLang=en • SQL Server Home Page • http://www.microsoft.com/sql/、 http://www.microsoft.com/taiwan/sql • Application and Compatibility Content & Tools • Application Compatibility Blog http://blog.scalabilityexperts.com • Scalability Experts - Upgrade Assistancehttp://www.scalabilityexperts.com • SQL Server 2008 Upgrade Advisorhttp://www.microsoft.com/sql

More Related