[ERROR]Space id in fsp header but in the page header一列
報錯如下MYSQL不能正常啟動
2017-09-22 10:39:05 21409 [Note] InnoDB: Database was not shutdown normally! 2017-09-22 10:39:05 21409 [Note] InnoDB: Starting crash recovery. 2017-09-22 10:39:05 21409 [Note] InnoDB: Reading tablespace information from the .ibd files... 2017-09-22 10:39:05 21409 [ERROR] InnoDB: Space id in fsp header 1416128883,but in the page header 824195850
我曾經寫過這樣一個文章如下:
InnoDB: Error: space id and page n:o stored in the page?
http://blog.itpub.net/7728585/viewspace-2121548/
但是上面的文章只是人為模擬,實際上在生產情況中嚴重得多,基本是塊的物理順壞,今天又有網友問我這個問題,實際上遇到這種問題一般都涉及到塊的物理損壞了,修復的可能性並不大,我們來看看原始碼拋錯位置:
/**********************************************************************//** Reads the space id from the first page of a tablespace. @return space id, ULINT UNDEFINED if error */ ulint fsp_header_get_space_id( /*====================*/ const page_t* page) /*!< in: first page of a tablespace */ { ulint fsp_id; ulint id; fsp_id = mach_read_from_4(FSP_HEADER_OFFSET + page + FSP_SPACE_ID); id = mach_read_from_4(page + FIL_PAGE_ARCH_LOG_NO_OR_SPACE_ID); DBUG_EXECUTE_IF("fsp_header_get_space_id_failure", id = ULINT_UNDEFINED;); if (id != fsp_id) { ib::error() << "Space ID in fsp header is " << fsp_id << ", but in the page header it is " << id << "."; return(ULINT_UNDEFINED); } return(id); }
- FIL_PAGE_ARCH_LOG_NO_OR_SPACE_ID:PAGE HRADER中儲存了space id在34後4位元組,也就對應了報錯中的but in the page header 824195850
- FSP_SPACE_ID:File space header中儲存了space id在38位元組後4個位元組,也就對應了報錯中的Space id in fsp header 1416128883
File space header是每一個表空間的第一個塊才會有的,儲存的資訊如下:
/* SPACE HEADER ============ File space header data structure: this data structure is contained in the first page of a space. The space for this header is reserved in every extent descriptor page, but used only in the first. */ /*-------------------------------------*/ #define FSP_SPACE_ID 0 /* space id */ #define FSP_NOT_USED 4 /* this field contained a value up to which we know that the modifications in the database have been flushed to the file space; not used now */ #define FSP_SIZE 8 /* Current size of the space in pages */ #define FSP_FREE_LIMIT 12 /* Minimum page number for which the free list has not been initialized: the pages >= this limit are, by definition, free; note that in a single-table tablespace where size < 64 pages, this number is 64, i.e., we have initialized the space about the first extent, but have not physically allocated those pages to the file */ #define FSP_SPACE_FLAGS 16 /* fsp_space_t.flags, similar to dict_table_t::flags */ #define FSP_FRAG_N_USED 20 /* number of used pages in the FSP_FREE_FRAG list */ #define FSP_FREE 24 /* list of free extents */ #define FSP_FREE_FRAG (24 + FLST_BASE_NODE_SIZE) /* list of partially free extents not belonging to any segment */ #define FSP_FULL_FRAG (24 + 2 * FLST_BASE_NODE_SIZE) /* list of full extents not belonging to any segment */ #define FSP_SEG_ID (24 + 3 * FLST_BASE_NODE_SIZE) /* 8 bytes which give the first unused segment id */ #define FSP_SEG_INODES_FULL (32 + 3 * FLST_BASE_NODE_SIZE) /* list of pages containing segment headers, where all the segment inode slots are reserved */ #define FSP_SEG_INODES_FREE (32 + 4 * FLST_BASE_NODE_SIZE) /* list of pages containing segment headers, where not all the segment header slots are reserved */
那麼這個錯誤簡單的說就是某個表空間ibd檔案的第一個塊的34後4位元組和38位元組後4個位元組不能透過檢測,但是要注意這僅僅是這8個位元組一個檢測。實際上這種錯誤基本對應著表空間檔案的物理順壞,一般來說其他位元組也出現了問題,如果沒有備份或者其他雙機手段可能要導致這個表空間的資料丟失。好了我們回到案例。
隨即我問這位朋友是否是獨立表空間,他說是的,然後我們就需要找到到底哪個表空間出了問題。我曾經有一個讀取二進位制檔案的工具,放到百度雲盤:
可以直接讀取這樣的資訊如下:
****************************************************************** This Tool Is Uesed For Find The Data In Binary format(Hexadecimal) Usage:./bcview file blocksize offset cnt-bytes! file: Is Your File Will To Find Data! blocksize: Is N kb Block.Eg: 8 Is 8 Kb Blocksize(Oracle)! Eg: 16 Is 16 Kb Blocksize(Innodb)! offset:Is Every Block Offset Your Want Start! cnt-bytes:Is After Offset,How Bytes Your Want Gets! Edtor QQ:22389860! Used gcc version 4.1.2 20080704 (Red Hat 4.1.2-46) ****************************************************************** ----Current file size is :0.109375 Mb ----Current use set blockszie is 16 Kb ----Current file name is t6.ibd current block:00000000--Offset:00036--cnt bytes:08--data is:001e0000001e0000
我們可以得到資料
current block:00000000--Offset:00036--cnt bytes:08--data is:001e0000001e0000
但是要掃描全部的ibd檔案才能找到是哪個表空間檢測出錯,但是這個哥們shell也是比較好,寫了一個如下的shell來完成:
find /opt/app/mysql5/var/ -iname \*.ibd > a for i in `cat ./a`;do ./bcview $i 16 34 8 | head -15 >> a.log;done
這樣將所有表空間的第一個塊的資訊的34-42位元組資訊都提取出來了,我隨即檢視了一下,找到了報錯的表空間:
current block:00000000--Offset:00034--cnt bytes:08--data is:31203b0a54686973
- 0X54686973 十進位制為1416128883就是報錯的Space id in fsp header 1416128883
- 0X31203b0a 十進位制為1416128883就是報錯的but in the page header 824195850
顯然他們是不相等,正常情況下這8個位元組4位元組4位元組比較是相同的,然後我檢視了這個檔案中塊的checksum也是不相等,這個時候只有2個正常的處理方式:
- 使用備份檔案進行恢復
- 如果這個表不重要可以移除掉ibd檔案保留frm檔案,可以正常啟動,啟動後drop掉這個表
後記
顯然這裡也再次重申了備份的重要性,遇到這樣的錯誤,最安全的方式還是進行資料恢復,當然某些工具可以直接提取資料檔案裡面的資料,但是現有的版本支援並不是太好,而且風險也是特別大。
作者微信
來自 “ ITPUB部落格 ” ,連結:http://blog.itpub.net/7728585/viewspace-2145358/,如需轉載,請註明出處,否則將追究法律責任。
相關文章
- MYSQL Space id in fsp header,but in the page header錯誤MySqlHeader
- InnoDB: Error: space id and page n:o stored in the page?Error
- StreamCorruptedException: invalid stream headerExceptionHeader
- datafilecopy header validation failure problemHeaderAI
- jQuery :headerjQueryHeader
- HTTP headerHTTPHeader
- 關於MYSQL INNODB index page header學習和實驗總結MySqlIndexHeader
- Error parsing HTTP request header--400 bad requestErrorHTTPHeader
- Header V3 DSA signature: NOKEY, key ID e8562897 rpm HeaderHeader
- 20161110Bitmapped File Space Header恢復APPHeader
- http設定headerHTTPHeader
- HTML <header> 標籤HTMLHeader
- HTTP Header 詳解HTTPHeader
- HTTP header介紹HTTPHeader
- Oracle ASM Disk HeaderOracleASMHeader
- 新建分支 header區Header
- oracle10g 資料檔案頭data file header(file header)OracleHeader
- Django出現DisallowedHost at / Invalid HTTP_HOST headerDjangoHTTPHeader
- MAVEN提示invalid LOC header (bad signature)MavenHeader
- header的安全配置指南Header
- ASM DISK HEADER CORRUPTION & REPAIRASMHeaderAI
- alter system dump datafile headerHeader
- X$BH與Buffer HeaderHeader
- PE教程4: Optional HeaderHeader
- The Ultimate (DLL) Header File (轉)Header
- row header format (157)HeaderORM
- Nginx的client_header_buffer_size和large_client_header_buffers學習NginxclientHeader
- invalid stream header: EFBFBDEF 問題解決Header
- HTTP header 欄位解釋HTTPHeader
- proxy_set _header Host $host;Header
- Refused to set unsafe header "cookie"HeaderCookie
- http header中cache設定HTTPHeader
- nginx配置proxy_set_headerNginxHeader
- java 如何暴露header給前端JavaHeader前端
- [20201221]KTFB Bitmapped File Space Header的恢復.txtAPPHeader
- 不是所有 Response 類都有 header () 方法Header
- 在佇列中取不到 header佇列Header
- 通過HTTP Header控制快取HTTPHeader快取