複製鏈接
請複製以下鏈接發送給好友

數據庫管理員

(從事管理和維護數據庫管理系統的相關工作人員的統稱)

鎖定
數據庫管理員(Database Administrator,簡稱DBA),是從事管理和維護數據庫管理系統(DBMS)的相關工作人員的統稱,屬於運維工程師的一個分支,主要負責業務數據庫從設計、測試到部署交付的全生命週期管理。
DBA的核心目標是保證數據庫管理系統的穩定性、安全性、完整性和高性能。
在國外,也有公司把DBA稱作數據庫工程師(Database Engineer),兩者的工作內容基本相同,都是保證數據庫服務7*24小時的穩定高效運轉,但是需要區分一下DBA和數據庫開發工程師(Database Developer):
1) 數據庫開發工程師的主要職責是設計和開發數據庫管理系統和數據庫應用軟件系統,側重於軟件研發;
2) DBA的主要職責是運維和管理數據庫管理系統,側重於運維管理。
中文名
數據庫管理員
外文名
Database Administrator
簡    稱
DBA
定    義
負責管理和維護數據庫系統的人
相關詞條
數據庫運維運維工程師

數據庫管理員主要職責

數據庫管理員狹義

一般意義上的數據庫管理員是一個負責管理和維護數據庫服務器的人,數據庫管理員負責全面管理和控制數據庫系統,包括數據庫的安裝、監控、備份、恢復等基本工作。數據庫管理員的主要職責有以下幾個方面:
設計數據庫設計,包括字段、表和關鍵字段;資源在輔助存儲設備上是怎樣使用的,怎樣增加和刪除文件及記錄,以及怎樣發現和補救損失。
2.監視監控數據庫的警告日誌,定期做備份刪除。監控數據庫的日常會話情況。碎片、剩餘表空間監控,及時瞭解表空間的擴展情況、以及剩餘空間分佈情況。監視對象的修改。定期列出所有變化的對象安裝和升級數據庫服務器(如Oracle、MicrosoftSQLserver),以及應用程序工具。數據庫設計系統存儲方案,並制定未來的存儲需求計劃。制定數據庫備份計劃,災難出現時對數據庫信息進行恢復。維護適當介質上的存檔或者備份數據。備份和恢復數據庫。聯繫數據庫系統的生產廠商,跟蹤技術信息。
3.備份對數據庫的備份監控和管理數據庫的備份至關重要,對數據庫的備份策略要根據實際要求進行更改,數據的日常備份情況進行監控。
4.修改密碼:規範數據庫用户的管理定期對管理員等重要用户密碼進行修改。對於每一個項目,應該建立一個用户。DBA應該和相應的項目管理人員或者是程序員溝通,確定怎樣建立相應的數據庫底層模型,最後由DBA統一管理,建立和維護。任何數據庫對象的更改,應該由DBA根據需求來操作。
5.SQL語句:對SQL語句的書寫規範的要求一個SQL語句,如果寫得不理想,對數據庫的影響是很大的。所以,每一個程序員或相應的工作人員在寫相應的SQL語句時,應該嚴格按照《SQL書寫規範》一文,最後要有DBA檢查才可以正式運行。
6.最終用户服務和協調:數據庫管理員規定用户訪問權限和為不同用户組分配資源。如果不同用户之間互相牴觸,數據庫管理員應該能夠協調用户以最優化安排。
7.數據庫安全:數據庫管理員能夠為不同的數據庫管理系統用户規定不同的訪問權限,以保護數據庫不被未經授權的訪問和破壞。例如,允許一類用户只能檢索數據,而另一類用户可能擁有更新數據和刪除記錄的權限。 [1] 

數據庫管理員廣義

但是廣義上的DBA職責比這個大得多,需要覆蓋產品從需求設計、測試到交付上線的整個生命週期,在此過程中不僅要負責數據庫管理系統的搭建和運維,更要參與到前期的數據庫設計,中期的數據庫測試和後期的數據庫容量管理和性能優化。
對於初創公司,DBA的工作可能由運維工程師來兼任,從申請域名開始,到服務器上架,配置網絡設備,部署操作系統,安裝數據庫,設計和部署監控,防止漏洞和攻擊等等。而大型公司對DBA工作的要求越來越高,以下從各個維度來看DBA工作的職責。
產品生命週期維度
DBA負責了業務數據庫從設計、測試到部署交付的全生命週期管理 [2]  ,各個階段的職責包括:
1. 產品發佈前
這個階段DBA的職責是數據庫准入,主要包括:
1)產品的業務熟悉;
2)產品數據庫設計評審:包括架構的合理性評估,存儲容量和性能是否滿足需求,是否需要緩存,是否需要冗餘備份等,同時需要提供數據庫schema設計的合理性建議以使產品能夠滿足上線發佈並穩定運行的基本要求;
3)資源評估,包括所需的服務器資源、網絡資源以及資源的分佈等,同時把關產品對資源預算申請的合理性,控制服務成本;
4)資源就位,將申請的服務器及基礎環境/域名準備就位。
2. 產品發佈
這個階段DBA負責數據庫發佈的具體工作,將具體的數據庫安裝部署和初始化完成後並對外提供服務。對於已在線數據庫的升級也屬於發佈範疇,這個時候的產品發佈一般要保障在線發佈,在不中斷對外服務的情況下完成數據庫的升級。對於大型複雜的變更也存在中止服務發佈完成後再重新提供服務的情況,但這種情況需要DBA通過儘可能的技術手段來避免。
3. 產品運行維護
這個階段的工作重點包括:
1)監控:對數據庫服務運行的狀態進行實時的監控,包括數據庫會話、數據庫日誌、數據文件碎片、表空間監控、用户訪問監控等,隨時發現數據庫服務的運行異常和資源消耗情況;輸出重要的日常數據庫服務運行報表以評估數據庫服務整體運行狀況,發現數據庫隱患;
2)備份:制定和實施數據庫備份計劃,災難出現時對數據庫信息進行恢復,維護適當介質上的存檔或者備份數據。對數據庫的備份策略要根據實際要求進行更改,數據的日常備份情況進行監控。
3)安全審計:為不同的數據庫管理系統用户規定不同的訪問權限,以保護數據庫不被未經授權的訪問和破壞。例如,允許一類用户只能檢索數據,而另一類用户可能擁有更新數據和刪除記錄的權限。
4)故障處理:對數據庫服務出現的任何異常進行及時處理,儘可能避免問題的擴大化甚至中止服務。這之前DBA需要針對各類服務異常,如機房/網絡故障、程序bug等問題制定處理的預案,問題出現時可以自動或手動執行預案達到止損的目的。
5)容量管理:包括數據庫規模擴張後的資源評估、擴容、機房遷移、流量調度等規劃和具體實施。
4. 數據庫性能優化
產品對外提供服務最重要的一點是用户體驗,用户體驗中非常重要的是產品的可用性和響應速度。而如何用最合理的資源支持產品提供高可用和高速度的用户體驗,這也是DBA的重要職責。

數據庫管理員技術分工

產品的整個生命週期裏數據庫管理員的職責重要而廣泛,這催生了各個縱向的運維技術方向,凡是關係到數據庫質量、效率、成本、安全等方面的工作,及涉及到的技術、組件,主要包括:
  • 數據庫監控技術:包括監控平台的研發、應用,服務監控準確性、實時性、全面性的保障。
  • 數據庫故障管理:包括服務的故障預案設計,預案的自動化執行,故障的總結並反饋到產品/系統的設計層面進行優化以提高產品的穩定性。
  • 數據庫容量管理:測量服務的容量,規劃服務的機房建設,擴容、遷移等工作。
  • 數據庫性能優化:從各個方向,包括SQL優化、參數優化、應用優化、客户端優化等,提高數據庫的性能和響應速度,改善用户體驗。
  • 數據庫安全保障:包括數據庫的訪問安全、防攻擊、權限控制等。
  • 數據庫自動部署:部署平台/工具的研發,及平台/工具的使用,做到安全、高效的發佈服務。
  • 數據庫集羣管理:包括數據庫的服務器管理、分佈式集羣管理等。
  • 數據庫模型設計:包括數據庫邏輯和物理模型的設計,如何實現性能最優,架構可擴展,服務可運維等。

數據庫管理員能力要求

數據庫管理員以技術為基礎,通過技術保障數據庫提供更高質量的服務。DBA工作的職責及在業務中的位置決定了DBA需要具備更加廣博的知識和深入的技術能力。在數據庫環境的管理與維護中,技術任務可歸結成許多不同的分類。下面列出了一名DBA應掌握的一些技術(排名不分先後)。
1.理解數據備份/恢復與災難恢復
恢復已損壞的數據庫是每一個DBA應掌握的最重要的技能。DBA需要完全理解數據庫所有可能的備份與恢復方法,以及不同備份方法與不同恢復策略的對應關係。此外,DBA還需要與業務部門合作,一起確認業務需求,明確用户能夠容忍的數據丟失底線。此外,業務用户還需要確定在系統故障情況下,他們的業務能夠維持多長時間。理解這些需求可以幫助DBA開發出一個滿足業務用户要求的備份/恢復方法。一個優秀的DBA要定期測試備份與恢復流程,保證他們有能力恢復業務數據,滿足企業所規定的業務數據丟失與恢復要求。
2.工具集的使用
所謂工具集,指是的他們要有一組用於執行不同DBA任務的腳本。這個工具集應該包含不同的小代碼片段,它們可以快速診斷問題或執行一個特定的任務。這些工具腳本應該按DBA的活動類型歸類,如備份、索引維護、性能優化、容量管理等。由於總是會執行新任務、發現新問題或找到其他人開發的好用腳本,因此一個優秀的DBA會不斷地給這個工具集增加新腳本。此外,他還應該瞭解網上哪裏能夠找到一些免費的工具和腳本。一個好的DBA知道什麼時候可以利用其他人編寫的腳本,從而節省自己的時間和改進自己的工具集。
3.知道如何快速尋找答案
數據庫每天會面臨各種各樣故障的挑戰,從硬件到網絡,從性能壓力到程序bug,DBA都要從容應對,一一排除。即使是數據庫大牛,也不可能是無所不知的,因此每個DBA一方面需要不斷修煉自己,積累操作系統、網絡、硬件、存儲系統、分佈式計算等理論基礎,另一方面還要有快速尋找新問題解決方法的能力。如果一個數據庫實例不能按預期方式運轉,那麼快速尋找新問題的解決方法也是一個重要能力。一個好的DBA知道如何快速地在網上查找一個未知問題的解決方法。此外,他們也可能已經知道了一些非常不錯的網站,也知道業界專家會提供一些好建議,同時知道什麼時候應該忽略一些不好的建議。你可能想象不到,確實有一些建議不值得參考。
4.知道如何監控和優化數據庫性能
對於任何數據庫產品,性能都尤其重要,它會直接影響產品的響應速度和用户體驗。對於一個DBA來説,性能優化一般需要佔用50%的工作時間,因此DBA需要知道如何監控和優化數據性能。
以SQL Server舉例,性能是一個關鍵的問題,因此DBA需要知道如何修復故障和監控性能問題。有許多第三方性能監控工具可以幫助DBA優化性能。如果DBA只使用第三方工具,而不會使用SQL Server自帶的原生工具來監控性能,那麼相信很快就會出現問題。雖然使用第三方工具來監控性能也很不錯,但是DBA一定要理解SQL自帶的一些原生工具,如SQL Server Profiler、Database Engine Tuning Advisor、Dynamic ManagementViews、系統/擴展的存儲過程、Extended Events等。許多第三方工具實際上在使用這些底層的原生工具。因此,理解這些自帶的原生工具將有利於增強DBA使用第三方工具的經驗。
5.研究新版本
在技術領域中,沒有什麼是一成不變的。每隔兩三年,主流數據庫廠商都會發佈一個大版本的更新。DBA應該緊跟新版本所作的修改,它們可能有許多變化方法,最好的方法是儘早介入這個過程。測試版開放後馬上下載和安裝,儘快掌握第一手使用經驗。一名好的DBA總是走在學習排頭兵,總是會第一時間安裝和測試新版本。這樣他們就可以儘早理解新特性,然後提出一些合理的新建議,幫助組織更好地利用新版本數據庫。
6.理解代碼最佳實踐方法
DBA應該瞭解如何編寫高效的代碼。有許多糟糕的編碼實踐方法會導致拙劣的性能。一名好的DBA要能夠理解和識別這些糟糕的編碼實踐方法,知道如何修改這些爛代碼,讓它們變成高效代碼。此外,他們還要記錄下寫代碼的最佳實踐方法,並且將這些實踐方法分享給其他人。
7.持續不斷地學習
數據庫及其組件涉及面非常廣。DBA很難理解一個技術的方方面面。DBA需要持續學習如何管理數據庫。這個學習過程有很多方法。其中之一就是參加正式培訓。但是,並非人人都有這樣充裕的時間和金錢,也並非人人都能夠放下手頭工作專門出去參加正式的培訓。但是,還有許多其他方法可以獲得培訓,而且大多數還是免費的。一名好的DBA一定要訂閲一些定期發佈數據庫新技巧和新文章的社區網站。此外,他還應該加入一些用户組織,可以在週末參加一些當地的免費沙龍活動。
8.數據庫安全性
安全性是一個熱門話題。DBA應該完全掌握如何實現數據庫的安全訪問。他們應該理解操作系統身份驗證和數據庫身份驗證的區別,以及它們各自的使用場合。他們應該理解如何使用數據庫角色來管理不同類型用户的安全配置。他們應該理解連接數據庫的端口與協議。此外,他們還應該理解如何加密整個數據庫,或者加密一個數據庫中一個表的某一個字段,同時理解關於加密數據的各種問題。
9.數據庫設計
決定數據庫性能的一個關鍵問題是數據庫設計。DBA需要理解關於數據庫設計的各個方面。他們要能夠理解設計好壞的區別。他們需要理解為什麼使用正確的外鍵約束、主鍵、檢查約束和使用數據類型能夠保持數據庫的數據完整性和實現高效的數據查詢與更新。
10.索引設計
數據庫索引是提高應用程序檢索和更新數據速度的重要環節。DBA需要知道索引的工作原理。他們應該知道聚簇索引和非聚簇索引的區別,知道這些索引的物理存儲方式。DBA應該知道如何在執行計劃中使用這些索引。他們應該理解如何找到索引的使用統計、理解索引碎片及如何發現丟失的索引。他們應該知道如何維護索引,以及索引統計信息對於查詢引擎的重要作用。
11.容量監控與規劃
數據庫往往要使用大量的資源,包括CPU、內存、I/O及磁盤空間。DBA應該理解如何監控數據庫所需要的不同主機資源的用量。他們應該能夠理解這些資源在不同時間的使用情況,以及利用歷史使用數據來規劃未來的容量需求。在監控過程中,DBA應該能夠預見到容量規劃會在將來什麼時候出現問題,然後採取必要的措施保持數據庫不會因為容量限制而出現中斷。
12.數據庫許可證
不同的產品有許多不同的許可證授權方式。而且,同一款產品本身又有許多不同的版本。DBA應該理解所負責的數據庫版本的不同授權模式。他們應該能夠提供指導如何通過合理購買授權來減少數據庫總擁有成本,以及如何合理利用授權方法來降低未來版本的升級成本。
13.儘可能實現自動化
DBA每天都需要執行許多的日常任務。其中一些任務需要每天執行,而另一些則每週、每月或每年執行。一名好的DBA需要理解如何高效地安排自己的時間。其中一種方法是建立工作流程,這些日常任務的自動執行。通過實現日常任務的自動化執行,DBA就可以用更多的時間去關注於數據庫環境管理中遇到的嚴重問題。 [3] 

數據庫管理員職業性格

DBA需要跟各種人員打交道,這些人員可能是銷售商、用户、開發人員或者管理人員。這説明:DBA必須具有下面的個性特點:
  • 自信心:足夠的自信心能夠幫助DBA在重要緊急時刻果斷下決定,而不是不知所措地看着事故發生
  • 好奇心:幾乎所有的數據庫系統都在不停地更新。但並不是所有的更新都有技術文檔。對於好的DBA來説,好奇心是必需的。沒有好奇心和求知慾的DBA總是等待有人告訴他們答案。而一個求知慾強的DBA將安裝最新版本的數據庫系統,並立即開始搜尋那些哪怕是細微的功能和性能上的差異和增強,從而改進自己的工作。應試時一個必然問及的問題是:你手頭有哪些參考資料?你如何使用它們?毫無疑問,如果你只回答了數據庫的文檔,或者你甚至沒有讀過他們,你的"股票市值"將大大下降。好奇心會驅使DBA們理解數據字典(Data Dictionary)、管理工具(Tools)或者其他支持包(Packages)。
  • 堅韌的意志力和沉着的心態:DBA常常會碰到棘手的問題。尋找答案是一個需要堅韌意志力、可以經受摔打的個性特點。同時面對緊急情況時要能處亂不驚,保持平和的心態冷靜處理問題。
  • 自我驅動:自我驅動對每個人都是很重要的,對DBA尤其如此。DBA要能想辦法使問題出現,而不是等待問題的出現。自驅力強的DBA常常設法取得或者自己寫一些必要的腳本(Script)來監控包括數據表大小(Table Size)、表空間使用(Tablespace Usage)等項目,這些項目如果被忽視,他們將遇到麻煩。應試的時候DBA們常常被問及在PL/SQL、SQL或者SQL*PLUS方面的經驗,這些問題將把你從從來沒有編寫過自己需要的腳本的那些DBA們區分開。
  • 良好的溝通能力、具有團隊合作精神:DBA的工作需要跨部門、跨工種接觸很多工程師,善於溝通、團隊協作能夠起到良好作用。很多時候,開發者、管理者、用户,他們會提出毫無道理的需求,DBA們需要老練地引導、修正它們的要求,説服他們。
  • 工作認真細緻,勤于思考:最後説説注意細節,這種性格傾向非常重要。注意細節的DBA們衣着整潔,有自己的日程安排,在應試前對應聘的單位做過調查。注意細節的DBA們深入瞭解數據庫的內核,並能理解視圖、表之間的關係。
  • 時間管理能力:數據庫運維的工作非常繁瑣,因此需要將碎片化的時間充分利用起來。

數據庫管理員職業等級

DBA的等級並不是很嚴格的。按照對數據庫的掌握情況,我簡單地分成三個等級:初級Primary、中級Intermediate和高級Senior。
初級DBA又稱為DBBS,是英文Database Baby Sitter的縮寫。初級DBA常常是兼職的,他們往往同時是程序員或者兼任其他的工作。初級DBA往往把個人簡歷寫得很棒,參與了很多和數據庫有關的項目或工作。但是,這些項目或者工作往往是:第三方軟件供應商已經安裝並配置了數據庫,他們只做一些監控的工作。他們能處理一些簡單的問題,但大多數時候他們嚮應用軟件供應商求救。初級DBA更喜歡圖形化的數據庫管理或者監控工具,他們喜歡Access這樣的桌面數據庫簡單易用,並把這些小型數據庫的經驗簡單地應用到大型數據庫相關的工作中。
初級DBA是最好區分的。而中級DBA和高級DBA就不太好區分。他們的差別在於經驗的不同和個性特點、能力方面的差異。中級DBA比較多,他們可以勝任高級DBA的大部分工作,包括:
1、數據庫安裝;
2、數據庫配置和管理;
3、權限設置和安全管理;
4、監控和性能調節;
5、備份和恢復;
6、解決一般的問題;
中級DBA往往從業一年左右,熟悉某種操作系統環境下的數據庫。因為對中級DBA來講,Windows NT和Unix是有很大差別的。中級DBA對SQL比較熟悉,他們自己購買了幾本數據庫方面的書籍,並深入鑽研。中級DBA往往同時兼任數據庫程序員,他們的工作對性能、穩定性、安全性的追求基本上不是很高,往往配合高級DBA做一些例行工作。
高級DBA在國內是非常少的。他們能夠熟練閲讀數據庫方面的英文資料,並且都熟悉很多種操作平台下的幾種大型數據庫。他們知道各種不同數據庫在不同環境下的優勢和劣勢,並能在數據庫平台和數據庫環境的選擇方面做出決策。他們一般通曉系統架構和數據庫設計,並能對數據庫進行各種級別的優化。高級DBA一般都配有助手,他們更偏向做決策和計劃。高級DBA往往在銀行業、保險業、在線交易等對穩定性、安全性、性能都要求比較高的關鍵業務處理領域大顯身手。
很多時候,是否取得數據庫專家認證證書並不是很重要。很多數據庫廠商的培訓只要你去了都會獲得證書。有很多的公司提供商業化的培訓,他們的服務質量也有好有劣。所以證書並不是特別地有意義。

數據庫管理員行業競爭力

1. 薪酬競爭力
1)影響因素:經驗和能力決定DBA的等級,熟悉的數據庫系統決定DBA的領域,個性特點和潛力決定你的升值空間。
2)縱向對比:DBA作為專項領域的高質量人才,薪酬競爭力較高,市場需求旺盛,尤其是中高階DBA,往往緊缺程度高於軟件研發工程師。
3)第三方薪酬調查報告,僅供參考:
《2013年數據庫工程師薪酬調查報告 [4] 
《Database Administrator Salary [5] 
2. 市場需求
1)數據庫運維行業的市場價值:參考ITOM(IT Operation Management) 2013年的市場規模是190億美金
2)人員需求:由於業務規模較大,中大型公司比較緊缺中高階DBA,而初創公司由於其新生的業務特點,比較緊缺初級和中級DBA。

數據庫管理員職業前景

數據庫作為整個系統的一部分,它的表現直接受服務器、操作系統、存儲、網絡、應用程序中SQL語句的質量、數據庫設計的質量、以及其它諸多因素的影響,這些因素加在一起非常複雜,經驗起着非常重要的作用。因此一個好的DBA除了知識作為基礎,經驗的多寡、見識的薄廣,往往決定了是否合格與優秀。
優秀的DBA不僅關心自己運維的數據庫系統的原理和發展,而且緊跟業界數據庫前沿技術,並關注數據庫領域的頂級會議。其中包括國際著名的數據庫三大會議SIGMOD、VLDB、ICDE,還有知名數據庫公司Percona主辦的Percona Live和Oracle主辦的Open World,以及國內知名的DBA盛會中國數據庫技術大會(DTCC)等。
從另外一個角度説,DBA工作領域對實踐經驗和獨立工作能力要求較高,沒有經過大量的動手實踐是很難勝任DBA相關工作的 [6]  。正是由於上述原因,其職場現狀是DBA職位不易進入,而用人單位很難找到合適的從業人員,人員缺口非常大。
也正是由於上述原因,隨着工作年限的增長,DBA的經驗在增加,就像醫生一樣,其價值會越來越高,可以逐步成長為資深DBA、系統架構師、信息主管(CIO)等等,而不會出現許多軟件開發從業人員在一定年齡後面臨的轉行問題。
另外,從職業前景看,從事DBA有着更多的職場機遇 [7]  。一般而言,系統中的軟硬件都是IBM、HP、Oracle等業界一流廠商提供的,在與廠商談判、合作、測試、實施、維護、優化等等過程中,會產生許多極佳的職場機遇,這一點是從事開發工作很難比擬的。
從DBA的工資統計數據看,隨着工作經驗的積累,DBA工資的增長幅度會遠大於其它的計算機方向。
從工作的穩定性上看,系統的複雜性和經驗的重要性已經決定了DBA職位的不可替代性。
從知識的積累、更新和替代角度看,數據庫的根基始終沒變,變的是不斷增強的功能和不斷擴展的應用範圍。因此,在不同時期所學的知識和獲得的經驗是疊加和累積的關係。
因此, DBA職業是一個高挑戰和高回報的職業,有一定能力的和聰明的技術人員應該挑戰自我,進入這個被二十多年事實不斷證明的越來越有前景的職業 [8] 
參考資料