- 相關(guān)推薦
mysql dba面試題及答案
1, mysql的復制原理以及流程。
(1)先問(wèn)基本原理流程,3個(gè)線(xiàn)程以及之間的關(guān)聯(lián)。
(2)再問(wèn)一致性,延時(shí)性,數據恢復。
(3)再問(wèn)各種工作遇到的復制bug的解決方法
3,問(wèn)mysql中varchar與char的區別以及var50)中的30代表的涵義。
(1)varchar與char的區別
char是一種固定長(cháng)度的類(lèi)型,varchar則是一種可變長(cháng)度的類(lèi)型
(2)var50)中50的涵義
最多存放50個(gè)字節
(3)int(20)中20的涵義
int(M)中的M indicates the maximum display width (最大顯示寬度)for integer types. The maximum legal display width is 255.
(4)為什么MySQL這樣設計?
4,問(wèn)了innodb的事務(wù)與日志的實(shí)現方式。
(1)有多少種日志
錯誤日志:記錄出錯信息,也記錄一些警告信息或者正確的信息
慢查詢(xún)日志:設置一個(gè)閾值,將運行時(shí)間超過(guò)該值的所有SQL語(yǔ)句都記錄到慢查詢(xún)的日志文件中。
二進(jìn)制日志:記錄對數據庫執行更改的所有操作
查詢(xún)日志:記錄所有對數據庫請求的信息,不論這些請求是否得到了正確的執行。
(2)日志的存放形式
(3)事務(wù)是如何通過(guò)日志來(lái)實(shí)現的,說(shuō)得越深入越好。
隔離性: 通過(guò) 鎖 實(shí)現
原子性、一致性和持久性是通過(guò) redo和undo來(lái)完成的。
5,問(wèn)了mysql binlog的幾種日志錄入格式以及區別
(1)各種日志格式的涵義
(2)適用場(chǎng)景
(3)結合第一個(gè)問(wèn)題,每一種日志格式在復制中的優(yōu)劣。
6,問(wèn)了下mysql數據庫cpu飆升到500%的話(huà)他怎么處理?
(1) 沒(méi)有經(jīng)驗的,可以不問(wèn)
(2)有經(jīng)驗的,問(wèn)他們的處理思路
7,sql優(yōu)化。
(1)explain出來(lái)的各種item的意義
(2)profile的意義以及使用場(chǎng)景。
(3)explain中的索引問(wèn)題。
8, 備份計劃,mysqldump以及xtranbackup的實(shí)現原理,
(1) 備份計劃
(2)備份恢復時(shí)間
(3)備份恢復失敗如何處理
9, 500臺db,在最快時(shí)間之內重啟。
10, 在當前的工作中,你碰到到的最大的mysql db問(wèn)題是?
11, innodb的讀寫(xiě)參數優(yōu)化
(1)讀取參數,global buffer pool以及 local buffer
(2)寫(xiě)入參數
(3)與IO相關(guān)的參數
(4)緩存參數以及緩存的適用場(chǎng)景
12 ,請簡(jiǎn)潔地描述下MySQL中InnoDB支持的四種事務(wù)隔離級別名稱(chēng),以及逐級之間的區別?
SQL標準定義的四個(gè)隔離級別為:
read uncommited
read committed
repeatable read
serializable
Read Uncommitted(讀取未提交內容)
在該隔離級別,所有事務(wù)都可以看到其他未提交事務(wù)的執行結果。本隔離級別很少用于實(shí)際應用,因為它的性能也不比其他級別好多少。讀取未提交的數據,也被稱(chēng)之為臟讀(Dirty Read)。
Read Committed(讀取提交內容)
這是大多數數據庫系統的默認隔離級別(但不是MySQL默認的)。它滿(mǎn)足了隔離的簡(jiǎn)單定義:一個(gè)事務(wù)只能看見(jiàn)已經(jīng)提交事務(wù)所做的改變。這種隔離級別也支持所謂的不可重復讀(Nonrepeatable Read),因為同一事務(wù)的其他實(shí)例在該實(shí)例處理其間可能會(huì )有新的commit,所以同一select可能返回不同結果。
Repeatable Read(可重讀)
這是MySQL的默認事務(wù)隔離級別,它確保同一事務(wù)的多個(gè)實(shí)例在并發(fā)讀取數據時(shí),會(huì )看到同樣的數據行。不過(guò)理論上,這會(huì )導致另一個(gè)棘手的問(wèn)題:幻讀(Phantom Read)。簡(jiǎn)單的說(shuō),幻讀指當用戶(hù)讀取某一范圍的數據行時(shí),另一個(gè)事務(wù)又在該范圍內插入了新行,當用戶(hù)再讀取該范圍的數據行時(shí),會(huì )發(fā)現有新的“幻影” 行。InnoDB和Falcon存儲引擎通過(guò)多版本并發(fā)控制(MVCC,Multiversion Concurrency Control 間隙鎖)機制解決了該問(wèn)題。注:其實(shí)多版本只是解決不可重復讀問(wèn)題,而加上間隙鎖(也就是它這里所謂的并發(fā)控制)才解決了幻讀問(wèn)題。
Serializable(可串行化)
這是最高的隔離級別,它通過(guò)強制事務(wù)排序,使之不可能相互沖突,從而解決幻讀問(wèn)題。簡(jiǎn)言之,它是在每個(gè)讀的數據行上加上共享鎖。在這個(gè)級別,可能導致大量的超時(shí)現象和鎖競爭。
對于不同的事務(wù),采用不同的隔離級別分別有不同的結果。不同的隔離級別有不同的現象。主要有下面3種現在:
1、臟讀(dirty read):一個(gè)事務(wù)可以讀取另一個(gè)尚未提交事務(wù)的修改數據。
2、非重復讀(nonrepeatable read):在同一個(gè)事務(wù)中,同一個(gè)查詢(xún)在T1時(shí)間讀取某一行,在T2時(shí)間重新讀取這一行時(shí)候,這一行的數據已經(jīng)發(fā)生修改,可能被更新了(update),也可能被刪除了()。
3、幻像讀(phantom read):在同一事務(wù)中,同一查詢(xún)多次進(jìn)行時(shí)候,由于其他插入操作()的事務(wù)提交,導致每次返回不同的結果集。
不同的隔離級別有不同的現象,并有不同的鎖定/并發(fā)機制,隔離級別越高,數據庫的并發(fā)性就越差,4種事務(wù)隔離級別分別表現的現象如下表:
隔離級別 | 臟讀 | 非重復讀 | 幻像讀 |
read uncommitted | 允許 | 允許 | 允許 |
read committed | 允許 | 允許 | |
repeatable read | 允許 | ||
serializable |
13,表中有大字段X(例如:text類(lèi)型),且字段X不會(huì )經(jīng)常更新,以讀為為主,請問(wèn)
(1)您 是選擇拆成子表,還是繼續放一起?
拆成子表
(2)寫(xiě)出您這樣選擇的理由?
1 提高檢索效率
14,MySQL中InnoDB引擎的行鎖是通過(guò)加在什么上完成(或稱(chēng)實(shí)現)的?為什么是這樣子的
通過(guò) 行多版本控制
15 MyISAM 與innodb的區別
(1) 問(wèn)5點(diǎn)不同
MyISAM Innodb
事物支持 : 不支持 支持
鎖的粒度: table Row
存儲容量: 沒(méi)有上限 64TB
哈希索引 : 不支持 支持
全文索引: 支持 不支持
外鍵: 不支持 支持
(2) 問(wèn)各種不同mysql版本的2者的改進(jìn)
(3)2者的索引的實(shí)現方式
【mysql dba面試題及答案】相關(guān)文章:
「MySQL」經(jīng)典面試題07-11
競聘面試題及答案07-10
Linux經(jīng)典面試題及答案07-13
經(jīng)典面試題及答案分析07-13
DBA就業(yè)前景?07-14
軟件測試面試題及答案12-30
電工面試題附答案06-28
emba面試題答案06-29
某公司面試題及答案07-11
測試面試題及答案總結07-13