Восстановление таблиц INNDB

MySQL/PostgreSQL/SQLite/Oracle/M$SQL/....

Модератор: terminus

Правила форума
Убедительная просьба юзать теги [code] при оформлении листингов.
Сообщения не оформленные должным образом имеют все шансы быть незамеченными.
Аватара пользователя
kozak
сержант
Сообщения: 240
Зарегистрирован: 2007-07-20 15:22:54
Откуда: Запорізька Січ

Восстановление таблиц INNDB

Непрочитанное сообщение kozak » 2008-12-02 18:33:52

После сбоя на сервере был поврежден жесткий диск, на котором размещались файлы таблиц INNODB (Users.ibd, Users.frm и db.opt).

После сбоя накрылся файл Users.ibd. После проверки HDD fsck'м в папке "lost+found" удалось найти Users.ibd, но после его возвращения в "родную" директорию таблица никак не хочет отображаться... Других BACKUP'ов нет... (((

Таблица Users - клиенты компании за последние 6 месяцев.

NEED HELP!!!
Діла добрих оновляться, Діла злих згинуть. Т. Г. Шевченко.

Хостинговая компания Host-Food.ru
Хостинг HostFood.ru
 

Услуги хостинговой компании Host-Food.ru

Хостинг HostFood.ru

Тарифы на хостинг в России, от 12 рублей: https://www.host-food.ru/tariffs/hosting/
Тарифы на виртуальные сервера (VPS/VDS/KVM) в РФ, от 189 руб.: https://www.host-food.ru/tariffs/virtualny-server-vps/
Выделенные сервера, Россия, Москва, от 2000 рублей (HP Proliant G5, Intel Xeon E5430 (2.66GHz, Quad-Core, 12Mb), 8Gb RAM, 2x300Gb SAS HDD, P400i, 512Mb, BBU):
https://www.host-food.ru/tariffs/vydelennyi-server-ds/
Недорогие домены в популярных зонах: https://www.host-food.ru/domains/

zg
полковник
Сообщения: 5845
Зарегистрирован: 2007-12-07 13:51:33
Откуда: Верх-Нейвинск

Re: Восстановление таблиц INNDB

Непрочитанное сообщение zg » 2008-12-02 18:38:26

на вскидку

Код: Выделить всё

zg# ls /usr/local/bin/ | grep inno
innochecksum
zg#

http://dev.mysql.com/doc/refman/5.0/en/ ... cksum.html

Код: Выделить всё

4.6.1. innochecksum — Offline InnoDB File Checksum Utility
innochecksum prints checksums for InnoDB files.
может чего напишет

Аватара пользователя
kozak
сержант
Сообщения: 240
Зарегистрирован: 2007-07-20 15:22:54
Откуда: Запорізька Січ

Re: Восстановление таблиц INNDB

Непрочитанное сообщение kozak » 2008-12-02 19:06:55

Делаем так:

Код: Выделить всё

bash-3.1# innochecksum -d /mnt/mass0/mysql/test/Users.ibd

...
file -d= 9437184 bytes (576 pages)...
checking pages in range 0 to 575
page 0: log sequence number: first = 1575557589; second = 1575557589
page 0: old style: calculated = 2344395615; recorded = 2344395615
page 0: new style: calculated = 1529347311; recorded = 1529347311
page 1: log sequence number: first = 1575560857; second = 1575560857
page 1: old style: calculated = 1583079948; recorded = 1583079948
page 1: new style: calculated = 903018481; recorded = 903018481
page 2: log sequence number: first = 1575557589; second = 1575557589
page 2: old style: calculated = 2172061152; recorded = 2172061152
page 2: new style: calculated = 2385590456; recorded = 2385590456
page 3: log sequence number: first = 1575528218; second = 1575528218
page 3: old style: calculated = 4059698346; recorded = 4059698346
page 3: new style: calculated = 1471387112; recorded = 1471387112
page 4: log sequence number: first = 1575459863; second = 1575459863

...

page 573: old style: calculated = 1371122432; recorded = 0
page 573: new style: calculated = 1575996416; recorded = 0
page 574: log sequence number: first = 0; second = 0
page 574: old style: calculated = 1371122432; recorded = 0
page 574: new style: calculated = 1575996416; recorded = 0
page 575: log sequence number: first = 0; second = 0
page 575: old style: calculated = 1371122432; recorded = 0
page 575: new style: calculated = 1575996416; recorded = 0
record = 0 начался с 83 строчки, причем я проверял рабочие ibd файлы - там тоже recorded = 0 присутствует! ((

Х.З.
Діла добрих оновляться, Діла злих згинуть. Т. Г. Шевченко.

zg
полковник
Сообщения: 5845
Зарегистрирован: 2007-12-07 13:51:33
Откуда: Верх-Нейвинск

Re: Восстановление таблиц INNDB

Непрочитанное сообщение zg » 2008-12-02 19:21:39

Innodb по ходу сам может восстанавливаться при старте http://dev.mysql.com/doc/refman/5.0/fr/ ... -0-13.html

Код: Выделить всё

If innodb_force_recovery=6, do not let InnoDB do repair of corrupt pages based on the doublewrite buffer.
Собственно как проявляется ошибка, мускул не стартует или не даёт работать с таблицей?

Аватара пользователя
kozak
сержант
Сообщения: 240
Зарегистрирован: 2007-07-20 15:22:54
Откуда: Запорізька Січ

Re: Восстановление таблиц INNDB

Непрочитанное сообщение kozak » 2008-12-02 19:28:46

Стартует, но при первом обращении апача к таблице появляется "Failed to execute_query".

В логах:

Код: Выделить всё

081202 18:26:08081202 18:26:08 [ERROR] Cannot find table database/Users from the internal data dictionary
of InnoDB though the .frm file for the table exists. Maybe you
have deleted and recreated InnoDB data files but have forgotten
to delete the corresponding .frm files of InnoDB tables, or you
have moved .frm files to another database?
See http://dev.mysql.com/doc/refman/5.1/en/innodb-troubleshooting.html
how you can resolve the problem.
Діла добрих оновляться, Діла злих згинуть. Т. Г. Шевченко.

zg
полковник
Сообщения: 5845
Зарегистрирован: 2007-12-07 13:51:33
Откуда: Верх-Нейвинск

Re: Восстановление таблиц INNDB

Непрочитанное сообщение zg » 2008-12-02 19:56:28

VladB писал(а):Стартует
гуд, это хороший признак -)))

Мануал говорит, что надо чекать http://dev.mysql.com/doc/refman/5.1/en/check-table.html

Код: Выделить всё

CHECK TABLE tbl_name [, tbl_name] ... [option] ...

option = {FOR UPGRADE | QUICK | FAST | MEDIUM | EXTENDED | CHANGED}
До кучи, вроде как с пятой версии к InnoDB можно также применять и repair http://dev.mysql.com/doc/refman/5.0/en/ ... table.html

Код: Выделить всё

REPAIR [LOCAL | NO_WRITE_TO_BINLOG] TABLE
    tbl_name [, tbl_name] ... [QUICK] [EXTENDED] [USE_FRM]

Аватара пользователя
kozak
сержант
Сообщения: 240
Зарегистрирован: 2007-07-20 15:22:54
Откуда: Запорізька Січ

Re: Восстановление таблиц INNDB

Непрочитанное сообщение kozak » 2008-12-02 20:06:59

Делаем раз:

Код: Выделить всё

mysql> use privataccess;
Database changed
mysql> show tables;
+------------------------+
| Tables_in_database |
+------------------------+
| CoTypes                |
| Counter                |
| Customers              |
| Dealers                |
| Groups                 |
| Messages               |
| Relations              |
| Sources                |
| Specialities           |
| Users                  |
+------------------------+
10 rows in set (0.00 sec)
Делаем 2:

Код: Выделить всё

mysql> CHECK TABLE Users;
+----------------+-------+----------+------------------------------------------+
| Table              | Op    | Msg_type | Msg_text                                 |
+----------------+-------+----------+------------------------------------------+
| database.Users | check | Error    | Table 'database.Users' doesn't exist |
| database.Users | check | error    | Corrupt                                  |
+----------------+-------+----------+------------------------------------------+
2 rows in set (0.00 sec)
То же самое и для REPAIR TABLE Users;

Сейчас смотрю http://code.google.com/p/innodb-tools/...
Діла добрих оновляться, Діла злих згинуть. Т. Г. Шевченко.

zg
полковник
Сообщения: 5845
Зарегистрирован: 2007-12-07 13:51:33
Откуда: Верх-Нейвинск

Re: Восстановление таблиц INNDB

Непрочитанное сообщение zg » 2008-12-02 21:45:26

если получится, отпишись, будем знать куда ткнуть :smile: если чё

Аватара пользователя
Alex Keda
стреляли...
Сообщения: 35429
Зарегистрирован: 2004-10-18 14:25:19
Откуда: Made in USSR
Контактная информация:

Re: Восстановление таблиц INNDB

Непрочитанное сообщение Alex Keda » 2008-12-02 23:10:17

извините что оффотопик...
вы уже перешли в категорию админов которые "уже делают бэкапы", или наконец серьёзно задумались о переходе в неё?
Убей их всех! Бог потом рассортирует...

zg
полковник
Сообщения: 5845
Зарегистрирован: 2007-12-07 13:51:33
Откуда: Верх-Нейвинск

Re: Восстановление таблиц INNDB

Непрочитанное сообщение zg » 2008-12-02 23:25:51

продолжая тему оффтопика - ценные данные никогда не потеряются, теряются только никому ненужные. Как только данные становятся ценными, их бекапят каждый день и не по разу. :smile:

Но сама тема восстановления InnoDB в принципе интересная.

Аватара пользователя
kozak
сержант
Сообщения: 240
Зарегистрирован: 2007-07-20 15:22:54
Откуда: Запорізька Січ

Re: Восстановление таблиц INNDB

Непрочитанное сообщение kozak » 2008-12-03 17:02:41

VladB писал(а):Сейчас смотрю http://code.google.com/p/innodb-tools/...
Ну... можно продолжить...

innodb-tools - как на мой взгляд очень мощный и простой инструмент для работы с поврежденными файлами .idb

Все очень просто как 1-2-3.

1. Сначала, на основе существующей поврежденной таблицы автоматически создаем скрипт "table_defs.h" с помощью "create_defs.pl";
2. Затем утилитой "page_parser" разбиваем поврежденный файл .idb на несколько страниц;
3. В дебаг-режиме выполняем "constraints_parser -4|5 -V -f <путь_к_одной_из_страниц_.page>"

Если в дебаг-режиме восстановление проходит успешно и никаких ошибок нет, можно запускать "constraints_parser" без флага "-V" (дебаг) и наблюдать за ходом восстановления вашей таблицы.

Уверен, что что-то пропустил, поэтому ссылаюсь на автора: http://code.google.com/p/innodb-tools/w ... overyHowto.
Діла добрих оновляться, Діла злих згинуть. Т. Г. Шевченко.

zg
полковник
Сообщения: 5845
Зарегистрирован: 2007-12-07 13:51:33
Откуда: Верх-Нейвинск

Re: Восстановление таблиц INNDB

Непрочитанное сообщение zg » 2008-12-03 17:11:41

VladB писал(а):Все очень просто как 1-2-3.
то есть восстановил?

Аватара пользователя
kozak
сержант
Сообщения: 240
Зарегистрирован: 2007-07-20 15:22:54
Откуда: Запорізька Січ

Re: Восстановление таблиц INNDB

Непрочитанное сообщение kozak » 2008-12-03 17:25:14

нет :-o

еще работаю над этим...
Діла добрих оновляться, Діла злих згинуть. Т. Г. Шевченко.

Аватара пользователя
kozak
сержант
Сообщения: 240
Зарегистрирован: 2007-07-20 15:22:54
Откуда: Запорізька Січ

Re: Восстановление таблиц INNDB

Непрочитанное сообщение kozak » 2008-12-03 17:26:45

VladB писал(а):Все очень просто как 1-2-3.
это на счет innodb-tools... :smile:
Діла добрих оновляться, Діла злих згинуть. Т. Г. Шевченко.

zg
полковник
Сообщения: 5845
Зарегистрирован: 2007-12-07 13:51:33
Откуда: Верх-Нейвинск

Re: Восстановление таблиц INNDB

Непрочитанное сообщение zg » 2008-12-03 17:35:33

VladB писал(а):это на счет innodb-tools... :smile:
ну если не трудно, по результатам отпишись :smile: а то всяко в жизни бывает ;-)

Аватара пользователя
LHC
мл. сержант
Сообщения: 127
Зарегистрирован: 2008-09-10 11:02:35
Откуда: Москва
Контактная информация:

Re: Восстановление таблиц INNDB

Непрочитанное сообщение LHC » 2008-12-03 18:50:52

Сорри и мне за оффтопик. Я всегда знал, что mysqldump - это круто, а сейчас убедился в этом еще раз.
Если хочешь, чтобы дело было сделано правильно, сделай его сам!

zg
полковник
Сообщения: 5845
Зарегистрирован: 2007-12-07 13:51:33
Откуда: Верх-Нейвинск

Re: Восстановление таблиц INNDB

Непрочитанное сообщение zg » 2008-12-03 18:53:19

LHC писал(а):Сорри и мне за оффтопик. Я всегда знал, что mysqldump - это круто, а сейчас убедился в этом еще раз.
дамп круто, но таблицы тоже надо уметь восстанавливать. С майисамом проблем нет, а вот с InnoDB есть и большие.

Аватара пользователя
Alex Keda
стреляли...
Сообщения: 35429
Зарегистрирован: 2004-10-18 14:25:19
Откуда: Made in USSR
Контактная информация:

Re: Восстановление таблиц INNDB

Непрочитанное сообщение Alex Keda » 2008-12-03 23:28:48

ф топку иннодб.
отрубаю в my.cnf и больше про них не вспоминаю.
Убей их всех! Бог потом рассортирует...

zg
полковник
Сообщения: 5845
Зарегистрирован: 2007-12-07 13:51:33
Откуда: Верх-Нейвинск

Re: Восстановление таблиц INNDB

Непрочитанное сообщение zg » 2008-12-03 23:42:16

lissyara писал(а):ф топку иннодб.
продуктивно :smile:

Аватара пользователя
ProFTP
подполковник
Сообщения: 3388
Зарегистрирован: 2008-04-13 1:50:04
Откуда: %&й
Контактная информация:

Re: Восстановление таблиц INNDB

Непрочитанное сообщение ProFTP » 2008-12-04 5:20:03

lissyara писал(а):ф топку иннодб.
отрубаю в my.cnf и больше про них не вспоминаю.
трансакция?
Pеrl FAQ
perl -e 'print join"",map $$_[rand@$_],([0..9,'a'..'z','A'..'Z'])x30'
ИзображениеИзображение

Аватара пользователя
Alex Keda
стреляли...
Сообщения: 35429
Зарегистрирован: 2004-10-18 14:25:19
Откуда: Made in USSR
Контактная информация:

Re: Восстановление таблиц INNDB

Непрочитанное сообщение Alex Keda » 2008-12-04 8:11:16

ф топку.
Убей их всех! Бог потом рассортирует...

Аватара пользователя
ProFTP
подполковник
Сообщения: 3388
Зарегистрирован: 2008-04-13 1:50:04
Откуда: %&й
Контактная информация:

Re: Восстановление таблиц INNDB

Непрочитанное сообщение ProFTP » 2008-12-04 8:17:16

потом будешь спрашиваешь почему не работает или почему деньги не пришли :-D

для форума или cms все равно, но вот для каталога или для продукции какой-то - только DBD или инодб, SQLite по-моиму тоже есть трансакция

там можно разделить СУБД на примари и секондери: сессии и логи в MyISA, а все остальное в DBD
Pеrl FAQ
perl -e 'print join"",map $$_[rand@$_],([0..9,'a'..'z','A'..'Z'])x30'
ИзображениеИзображение

Аватара пользователя
Alex Keda
стреляли...
Сообщения: 35429
Зарегистрирован: 2004-10-18 14:25:19
Откуда: Made in USSR
Контактная информация:

Re: Восстановление таблиц INNDB

Непрочитанное сообщение Alex Keda » 2008-12-04 8:24:21

покочану и покочерыжке.
либо ты обновил таблицу, либо не обновил.
это одинаково верно и для того типа и для другого.
и транзакции тебе не помогут.
=========
такие вещщи надо делать проще а не сложней - тогда не надо будет извратов всех этих.
Убей их всех! Бог потом рассортирует...

Аватара пользователя
ProFTP
подполковник
Сообщения: 3388
Зарегистрирован: 2008-04-13 1:50:04
Откуда: %&й
Контактная информация:

Re: Восстановление таблиц INNDB

Непрочитанное сообщение ProFTP » 2008-12-04 8:37:37

там бывает таблиц больше 10

елси надо обновить 3 таблицы или 2

ты обновил 1 таблицу и сервак повис, дальше что? получиться ерунда, тебе потом руками надо будет исправлять, а если пользователей штук 10000 ? 8)
или одновременно 1000 сидит


если 1 обновилась, а все остальное нет, то идет откат обратно...

Код: Выделить всё

use strict;
use DBI qw(:sql_types);

my $dbh = DBI->connect( 'dbi:Oracle:orcl',
                        'jeffrey',
                        'jeffspassword',
                        {
                          RaiseError => 1,
                          AutoCommit => 0
                        }
                      ) || die "Database connection not made: $DBI::errstr";

my @records = (
                [ 0, "Larry Wall",      "Perl Author",  "555-0101" ],
                [ 1, "Tim Bunce",       "DBI Author",   "555-0202" ],
                [ 2, "Randal Schwartz", "Guy at Large", "555-0303" ],
                [ 3, "Doug MacEachern", "Apache Man",   "555-0404" ] 
              );

my $sql = qq{ INSERT INTO employees VALUES ( ?, ?, ?, ? ) };
my $sth = $dbh->prepare( $sql );


for( @records ) {
  eval {
    $sth->bind_param( 1, @$_->[0], SQL_INTEGER );
    $sth->bind_param( 2, @$_->[1], SQL_VARCHAR );
    $sth->bind_param( 3, @$_->[2], SQL_VARCHAR );
    $sth->bind_param( 4, @$_->[3], SQL_VARCHAR );
    $sth->execute();
    $dbh->commit();
  };

  if( $@ ) {
    warn "Database error: $DBI::errstr\n";
    $dbh->rollback(); #just die if rollback is failing
  }
}

$sth->finish();
$dbh->disconnect();

Код: Выделить всё

    if ($dd{'mailbox'} $dd{'mailbox'} > 0) {
      my $sth = $dbh->prepare('SELECT mailbox
                         FROM mailbox
                         WHERE domain = ?
                             ');
    $sth->execute($domain);
             $sth->finish();
      my $n=0; my @mailboxs=();
   while ($mailbox_del = $sth->fetchrow_array() ) {
          $mailboxs[$n++]=$mailbox_del;
          }
       
    my $sth = $dbh->prepare('INSERT INTO delete_mailbox
              (domain,mailbox,created)
              VALUES (?,NOW())
                             ');
     
       eval {
       for ($i=0;$i<@mailboxs;$i++)
       {
         $id=$i+1;
          $sth->bind_param($id, $mailboxs[0]);
          $sth->execute();
         }       
       
        $dbh->do("DELETE FROM mailbox
                         WHERE domain = $domain");
       
        $dbh->commit();
                             ');
       if ($@) {
       warn "Transaction aborted $@";
       eval {$dbh->rollback()};
       $sth->finish();
       $dbh->disconnect();
       exit;
       }
     }

     if ($dd{'alias'} && $dd{'alias'} > 0) {
             my $sth = $dbh->prepare('DELETE FROM alias
                         WHERE domain = ?
                             ');
            $sth->execute($domain);
             $sth->finish();
                 }
      }  $dbh->disconnect();     
                
Pеrl FAQ
perl -e 'print join"",map $$_[rand@$_],([0..9,'a'..'z','A'..'Z'])x30'
ИзображениеИзображение

zg
полковник
Сообщения: 5845
Зарегистрирован: 2007-12-07 13:51:33
Откуда: Верх-Нейвинск

Re: Восстановление таблиц INNDB

Непрочитанное сообщение zg » 2008-12-04 9:09:04

lissyara писал(а):покочану и покочерыжке.
:ROFL: жесть аргумент :-D
lissyara писал(а):либо ты обновил таблицу, либо не обновил.
суть транзакций - объединять несколько запросов в один, и если произойдёт коллизия, то сделать откат всех объединённых запросов, во избежание нарушения целостности базы данных. Хотя я думаю, ты и так это знаешь -)))
lissyara писал(а):такие вещщи надо делать проще а не сложней - тогда не надо будет извратов всех этих.
все они дураки, что парятся над иннодб, один ты умный :"": Лис, не обижайся, но всё-таки открой тайну - сколько банковских систем ты написал, для управления многомиллонными счетами? InnoDB - это всё таки дань банковским системам в первую очередь.