個人的にそうなんだろうなあと思っていたことが書いてあって、とても腑に落ちた記事 / how oracle prevent "partial write" | Oracle Community https://t.co/nHcmvh5ZSA
2014-05-18 13:21:43MySQLのinnodb_doublewrite、PostgreSQLのfull_page_writesのような、データブロックが半分しか書かれていない事態を想定した処理は、Oracle DatabaseはALTER TABLESPACE BEGIN BACKUPのときにのみ行う
2014-05-18 13:26:55なのでサーバクラッシュ時にデータブロックが壊れていて、REDOを適用しただけでは直せないことがある。ただその場合Oracle Databaseはチェックサムで破損を検出し、ブロック・メディア・リカバリで該当データファイルだけを速やかに復旧させることができる。復旧はDBAが行う
2014-05-18 13:30:09MySQLにはInnoDBのページ単位でリカバリする機能はないし、そもそもmysqldumpで論理バックアップしか取らないのことも多いので、partial writeによって壊れた場合はフルリストア、リカバリが必要になる
2014-05-18 13:32:50ページが破損するたびにフルリストア、リカバリを行うのは大変なので、普段からinnodb_doublewriteで壊れないようにしている。Oracle Databaseは該当表領域がオフラインになるだけでインスタンスは動き続け、壊れたところだけピンポイントに直せる
2014-05-18 13:34:31MySQL(InnoDB)でページ破損が見つかった場合は、Oracle Databaseと異なりインスタンス自体がダウンする。ただPercona Serverの場合は継続稼働するためのオプションが用意されている http://t.co/cmCajLysDR
2014-05-18 13:41:46MySQL 5.7新機能のatomic writeとそれに対応したデバイス(ioDrive)を組み合わせることでinnodb_doublewriteを不要にできる。個人的にはMySQL Enterprise Backupでブロック・メディア・リカバリができるようになればいいと思う
2014-05-18 13:45:19PostgreSQLについては、ブロックのチェックサムが付いたのが最新のPostgreSQL 9.3からで、デフォルトではOFFという事情がある。デフォルトでは壊れても検出すらできないのでfull_page_writesをOFFにすることは大変危険
2014-05-18 13:48:36PostgreSQLとしては、チェックサムを有効にして、今後Oracle Databaseのようなブロック・メディア・リカバリ機能が提供されれば、full_page_writesをOFFにできる可能性が出てくる
2014-05-18 13:49:56人生の墓場も住めば都ですよ割と。 フォーぜで久々にリアルタイムでライダー鑑賞。やっぱりヒーローは良いですね。MySQLを極めたいと奮闘中。