-
-
Notifications
You must be signed in to change notification settings - Fork 153
Innodb Page Compression #21
Comments
Here is some information on the page compression, https://mariadb.com/kb/en/innodb-page-compression/ |
stream_parser cannot handle compressed pages. It doesn't understand that format and a size of a page is different (less than 16k). |
Well, I modified(hacked it with an axe) your stream_parser and it seems to now support mariadb's innodb page compression. Previously out of a 36MB file 372 pages were uncompressed and resulted in about 5.5MB of data extracted... now with this page compression support added I'm able to get another 1345 pages extracted resulting in 27MB data extracted... there appears to also be some other "mysql" compression pages as well which were skipped until I find some information on that. However, now I ran into the issue |
Score! Was able to extract the data I needed only lost 0.001% (hand full of rows), but those wont be worth my time recovering... they are probably there just in that mysql compression format instead of the mariadb page compression format. Few problems I ran into generating the data with c_parser
I'll removed my debugging junk I threw in and I'll attach the updated files here... you may want to organize the code a little differently, I was all about getting it done as fast as possible |
Attached at the modified files, needs zlib, it should be easy to add other compression support just need the references and add the call to the libraries decompress function. I rarely write c/c++ so may need to fix a data type here or there, not sure it matters it works! After I removed my forced debug for the c_parser it doesn't seg fault on the debug print... anyway see attached, merge if you would like. |
Thank you for your contribution! |
@artfiedler I'm trying to compile your modified code, but it's failing with Edit: Turns out it didn't help my case. The parsed data is still missing innodb pages and even the parsed rows have weird values for some columns (usually the first few are fine).
I suppose my data is corrupted beyond recovery. |
I believe I copied zlib.h into the libs folder
…Sent from my Windows 10 device
From: Branislav Makan
Sent: Wednesday, February 24, 2021 9:36 AM
To: twindb/undrop-for-innodb
Cc: Arthur Fiedler; Mention
Subject: Re: [twindb/undrop-for-innodb] Innodb Page Compression (#21)
@artfiedler I'm trying to compile your modified code, but it's failing with fatal error: zlib/zlib.h: No such file or directory even after I installed the zlib-devel library. Do I need to do something else to compile this beside running make?
—
You are receiving this because you were mentioned.
Reply to this email directly, view it on GitHub, or unsubscribe.
|
hey, buddy, I tried,compressed table cannot work |
- Handles compressed pages (based on twindb#21) - Additional logging
It seems one of the ibd files I'm looking to recover (I altered the table thinking I was doing a "create like", so some columns got dropped) has a mix of compressed pages and uncompressed. I'm able to extract X number or rows that I can visibility see in the ibd file that I believe was before I set the page compression on a year ago. However everything since then is not being pulled out, I believe its because of this page compression, I see in the 36mb file a bunch of compressed looking text (believe zlib) however the extracted data results in 5.5mb or so
Does this tool support decompressing pages? Will it?
The text was updated successfully, but these errors were encountered: