注釈
このコマンドは実験的な機能です。
バージョン 5.0.5 で追加.
io_flush はメモリー上のすべての変更を明示的にディスクに書き出します。通常、明示的に io_flush を使う必要はありません。なぜなら、OSが自動的に書き出してくれるからです。また、OSが書き出した方が効率的だからです。
いくつか明示的に io_flush を使う必要があるケースがあります。1つは、システムが不意にクラッシュすることがよくあるケースです。もう1つは、Groongaプロセスを通常の終了プロセスで終了できない可能性があるケースです。(通常の終了プロセスとは、例えば、 shutdown を使った終了プロセスです。)これらのケースでは、Groongaデータベースに変更を加えた後に io_flush を使うとよいです。以下はGroongaデータベースに変更を加えるコマンドのリストです。
もし、 select の scorer パラメーターをカラムの値を変更するために使っているなら、 select もこのリストに入ります。
io_flush は重い処理になる可能性があることに注意してください。もし、メモリー上に多くの変更があるなら、それらをディスクに書き出す処理は重い処理になります。
io_flush には必須のパラメーターはありません。 io_flush には2つの省略可能なパラメーターがあります。:
io_flush [target_name=null]
[recursive=yes]
引数無しで実行するとメモリー上のすべての変更をディスクに書き出すことができます。
実行例:
io_flush
# [[0, 1337566253.89858, 0.000355720520019531], true]
もし変更点を把握しているなら、書き出し対象を狭めることができます。以下はコマンドと書き出し対象の対応表です。
コマンド |
書き出し対象 |
io_flush の引数 |
---|---|---|
テーブルとそのテーブルのカラム。 カラムの中に参照カラムがある場合、参照されているテーブルも書き出し対象になる。 インデックスが張られているカラムがある場合、対応するインデックスカラムとそのインデックスカラムのテーブルも書き出し対象になる。 |
テーブルとそのテーブルのカラム: io_flush --target_name TABLE_NAME
参照されているテーブル: io_flush --target_name REFERENCED_TABLE_NAME --recursive no
インデックスカラムのテーブル: io_flush --target_name TABLE_NAME_OF_INDEX_COLUMN --recursive no
インデックスカラム: io_flush --target_name TABLE_NAME_OF_INDEX_COLUMN.INDEX_COLUMN
|
|
truncate | テーブルとそのテーブルのカラム。 カラムの中に参照カラムがある場合、参照されているテーブルも書き出し対象になる。 インデックスが張られているカラムがある場合、対応するインデックスカラムとそのインデックスカラムのテーブルも書き出し対象になる。 データベースも書き出し対象。 |
テーブルとそのテーブルのカラム: io_flush --target_name TABLE_NAME
参照されているテーブル: io_flush --target_name REFERENCED_TABLE_NAME --recursive no
インデックスカラムのテーブル: io_flush --target_name TABLE_NAME_OF_INDEX_COLUMN --recursive no
インデックスカラム: io_flush --target_name TABLE_NAME_OF_INDEX_COLUMN.INDEX_COLUMN
データベース: io_flush --recursive no
|
table_create | 処理対象のテーブルとデータベース。 |
テーブル: io_flush --target_name TABLE_NAME
データベース: io_flush --recursive no
|
データベース。 |
データベース: io_flush --recursive no
|
|
column_create | 処理対象のカラムとデータベース。 |
テーブル: io_flush --target_name TABLE_NAME.COLUMN_NAME
データベース: io_flush --recursive no
|
データベース。 |
データベース: io_flush --recursive no
|
|
データベース。 |
データベース: io_flush --recursive no
|
このセクションではすべての引数について説明します。
必須の引数はありません。
いくつか省略可能な引数があります。
書き出し対象オブジェクトの名前を指定します。書き出し対象オブジェクトはデータベース、テーブル、カラムのどれかです。
このパラメーターを省略すると、データベースが書き出し対象オブジェクトになります。
実行例:
io_flush
# [[0, 1337566253.89858, 0.000355720520019531], true]
テーブル名を指定すると、そのテーブルが書き出し対象オブジェクトになります。
実行例:
table_create Users TABLE_HASH_KEY ShortText
# [[0, 1337566253.89858, 0.000355720520019531], true]
io_flush --target_name Users
# [[0, 1337566253.89858, 0.000355720520019531], true]
カラム名を指定すると、そのカラムが書き出し対象オブジェクトになります。
実行例:
column_create Users age COLUMN_SCALAR UInt8
# [[0, 1337566253.89858, 0.000355720520019531], true]
io_flush --target_name Users.age
# [[0, 1337566253.89858, 0.000355720520019531], true]
書き出し対象オブジェクトの子オブジェクトも書き出し対象にするかどうかを指定します。
データベースの子オブジェクトはすべてのテーブルとすべてのカラムです。
テーブルの子オブジェクトはそのテーブルのすべてのカラムです。
カラムの子オブジェクトはありません。
recursive の値は yes または no でなければいけません。 yes は指定した書き出し対象オブジェクトとその子オブジェクトすべてを書き出し対象オブジェクトにするという意味です。 no は指定した書き出し対象オブジェクトのみを書き出し対象オブジェクトにするという意味です。
次の io_flush はデータベースとすべてのテーブルとすべてのカラムのすべての変更を書き出します。
実行例:
io_flush --recursive yes
# [[0, 1337566253.89858, 0.000355720520019531], true]
次の io_flush はデータベースの変更だけを書き出します。
実行例:
io_flush --recursive no
# [[0, 1337566253.89858, 0.000355720520019531], true]
他の値(つまり、 yes でも no でもない値)を指定した場合、または recursive パラメーターを指定しない場合は yes が使われます。
recursive 引数の値が不正なので、次のケースでは yes が使われます。
実行例:
io_flush --recursive invalid
# [[0, 1337566253.89858, 0.000355720520019531], true]
recursive パラメーターが指定されていないので、次のケースでは yes が使われます。
実行例:
io_flush
# [[0, 1337566253.89858, 0.000355720520019531], true]