Linux環境用のOracle ACFSコマンドライン・ツール
このトピックでは、Linux環境用のOracle ACFSコマンドの概要を示します。
表16-1に、Linux環境用のOracle ACFSコマンドと簡単な説明を示します。表16-1に示すコマンドは、Oracle ACFSをサポートする追加オプションによって拡張されています。その他のLinuxファイルシステム・コマンドはすべて、Oracle ACFS用の変更なしで動作します。
たとえば、Oracle ACFSにより、基本のオペレーティング・システム・プラットフォームに備わっているマウント・オプションに、Oracle ACFS固有のマウント・オプション・セットが追加されます。ファイルシステム・マウント・オプションの完全なセットとして、Linuxプラットフォームのマウント・オプションとともに、Oracle ACFS固有のオプションも確認する必要があります。
Oracle ACFSファイルシステムではないOracle ADVMボリューム上のファイルシステム(ext3
など)は、表16-1に示したのと同じLinuxコマンドで該当するタイプのファイルシステム用のファイル固有のオプションを使用して管理します。表16-1のLinuxコマンドで使用可能なオプションについては、man
ページを参照できます。
注意:
Security-Enhanced Linux (SELinux)を強制モードでOracle ACFSと併用している場合、Oracle ACFSファイルシステムがSELinuxデフォルト・コンテキストでマウントされていることを確認してください。コンテキスト・マウント・オプションの詳細は、Linuxベンダーのドキュメントを参照してください。
fsck
目的
Oracle ACFSファイルシステムをチェックおよび修復します。
構文および説明
fsck -t acfs -h /dev/null fsck [-a|-f] [-v] -t acfs [-n|-y] [-x file_name] volume_device
fsck
-t
acfs
-h
/dev/null
は、使用方法のテキストを表示して終了します。
表16-2に、fsck
コマンドで使用可能なオプションを示します。
表16-2 Linux fsckコマンドのオプション
オプション | 説明 |
---|---|
|
ファイルシステムを自動的に修正することを指定します。 |
|
ファイルシステムのチェックまたは修正を完了せずに、ファイルシステムを強制的にマウント可能な状態にします。 |
|
verboseモードを指定します。操作が発生すると、進捗状況が表示されます。verboseモードで実行すると、パフォーマンスに影響を及ぼす場合があります。 |
|
使用方法のヘルプ・テキストを表示して終了します。 |
|
すべてのプロンプトに対してnoと答えます。 |
|
すべてのプロンプトに対してyesと答えます。 |
|
|
|
プライマリOracle ADVMボリューム・デバイスを指定します。 |
fsck
は、既存のOracle ACFSをチェックおよび修復します。このコマンドは、ディスマウント済のファイルシステムでのみ実行できます。fsck
を実行するにはroot
権限が必要です。fsck
を機能させるには、Oracle ACFSドライバをロードする必要があります。
デフォルトでは、fsck
はエラーがないかチェックし、エラーを報告するのみです。-a
フラグは、fsck
にファイルシステムでのエラーの修正を指示するために指定する必要があります。修復操作中にfsck
を中断しないでください。
場合によっては、fsck
では、ファイルシステムのチェックに進む前に、質問に対する答えを要求されます。次の場合があります。
-
fsck
により、ファイルシステム上で別のfsck
が進行中であることが検出された場合 -
fsck
により、Oracle ACFSドライバがロードされていないことが検出された場合 -
ファイルシステムがOracle ACFSではない可能性がある場合
チェック・モードでは、fsck
では不完全な終了のために完全に処理されていないトランザクション・ログがある場合にも要求されます。非対話モードで実行するには、-y
または-n
オプションを含めて、質問に対してyesまたはnoと答えます。
fsck
では、ファイルシステムをチェックする前に、作業ファイルを作成します。これらの作業ファイルは、領域が使用可能な場合、/usr/tmp
に作成されます。/tmp
は、/usr/tmp
が存在しない場合に使用されます。tmp
ディレクトリで使用可能な領域が不十分な場合、fsck
では、現在の作業ディレクトリに書込みを試みます。fsck
で作成するファイルは、およそチェック対象のファイルシステムを32Kで割ったサイズです。そのようなファイルは多くても3つ割り当てられます。たとえば、チェックされている2GBのファイルシステムによって、fsck
では/usr/tmp
ディレクトリに1つから3つの64Kの作業ファイルが生成されます。これらのファイルは、fsck
の終了後に削除されます。
fsck
でファイルシステムで(親ディレクトリ内の破損などにより)名前または目的の場所を特定できないファイルまたはディレクトリが検出された場合、fsck
を修正モードで実行していると、そのオブジェクトは/lost+found
ディレクトリに配置されます。セキュリティ上の理由で、Linuxではroot
ユーザーのみが/lost+found
内のファイルを読み取ることができます。内容に基づいてファイルの元の名前および場所を管理者が後で特定できた場合は、そのファイルを目的の場所に移動またはコピーできます。
/lost+found
ディレクトリ内のファイル名の書式は、次のとおりです。
parent.id.file.id.time-in-sec-since-1970 parent.id.dir.id.time-in-sec-since-1970
id
フィールドは、ファイルシステムでのファイルおよびディレクトリそれぞれのOracle ACFSの内部数値識別子です。
acfsutil
info
id
id
mount_point
を使用すると、parent.
id
に関連付けられたディレクトリの特定を試みることができます。このディレクトリは、削除されたオブジェクトの元の場所とみなされます。acfsutil
info
の詳細は、「acfsutil info file」を参照してください。
親ディレクトリが不明な場合は、親のid
フィールドをUNKNOWN
と設定します。
注意:
/lost+found
ディレクトリの内容は、スナップショットから表示できません。
例
次の例は、Oracle ACFSファイルシステムのチェックおよび修復の方法を示しています。
例16-2 fsckコマンドの使用方法
# /sbin/fsck -a -y -t acfs /dev/asm/volume1-123
mkfs
目的
Oracle ACFSファイルシステムを作成します。
構文および説明
mkfs -t acfs -h mkfs [-v] [-f] -t acfs [-i {512 | 4096}] [-n name ] [-a accelerator_volume] [-c release_version] volume_device [size]
mkfs
-t
acfs
-h
は使用方法のテキストを表示して終了します。
表16-3に、mkfs
コマンドで使用可能なオプションを示します。
表16-3 Linux mkfsコマンドのオプション
オプション | 説明 |
---|---|
|
Linuxでのファイルシステムのタイプを指定します。 |
|
verboseモードを指定します。操作が発生すると、進捗状況が表示されます。 |
|
512バイトまたは4096バイトのメタデータ・ブロック・サイズでファイルシステムを指定します。 |
|
ファイルシステムの名前を指定します。名前は最大64文字です。 |
|
forceオプションを指定します。このアクションで、ボリューム・デバイスに既存のOracle ACFSがあっても、ファイルシステムが作成されます。ただし、フィアル・システムがディスマウントされている場合にかぎります。このオプションは、元のファイルシステム上の構造を上書きします。慎重に使用してください。 |
|
使用方法のヘルプ・テキストを表示して終了します。 |
|
指定したデバイスでファイルシステムが消費するサイズを指定します。量は、 このオプションを指定しない場合、デバイス全体が消費されます。 |
|
Oracle ACFSによって重要なメタデータの格納に使用されるセカンダリOracle ACFSアクセラレータ・ボリュームを指定します。 |
|
release_versionの値に設定されたOracle ACFSリリースの互換性でOracle ACFSファイルシステムを作成します。 |
|
フォーマットする既存のOracle ADVMデバイス・ファイルを指定します。このデバイスはプライマリ・ボリュームです。 |
mkfs
は、Oracle ACFSファイルシステムのマウントに必要なディスク上の構造を作成するために使用できます。mkfs
コマンドは、ファイルシステムの作成に使用される従来のLinuxコマンドです。mkfs
の実行に成功すると、V$ASM_VOLUME
ビューのUSAGE
列にはACFS
と表示されます。Oracle ADVMボリュームは、ASMCMD volcreate
コマンドを使用して作成されます。volcreate
コマンドの詳細は、「volcreate」を参照してください。
-c release_version
オプションで指定する値は、ディスク・グループのCOMPATIBLE.ADVM
値以上にする必要があり、実行中のOracle Grid Infrastructureリリースのバージョン以下にする必要があります。—c release_version
を指定しないと、COMPATIBLE.ADVM
値が使用されます。互換性は、設定するとダウングレードできません。—c release_version
オプションは、ディスク・グループのCOMPATIBLE.ADVM
およびCOMPATIBLE.ASM
の更新ができない、または望ましくない状況で、互換性の向上が必要なOracle ACFS機能を使用する場合に使用できます。Oracle ACFSの互換性を更新すると、以前のOracle Grid Infrastructureリリースを使用してファイルシステムをマウントできなくなります。既存のファイルシステムの互換性を変更するには、「acfsutil compat set」を参照してください。Oracle ASMディスク・グループの互換性属性の詳細は、「ディスク・グループの互換性」を参照してください。
最小ファイルシステム・サイズは、512バイトのメタデータ・ブロック・サイズ・フォーマットの場合は200 MB、4 KBのメタデータ・ブロック・サイズ・フォーマットの場合は512 MBです。
mkfs
が正常に機能するには、Oracle ACFSドライバをロードする必要があります。
root
権限は必要ありません。ボリューム・デバイス・ファイルの所有者が、このコマンドを実行できます。
Oracle ACFSアクセラレータ・ボリューム
アクセラレータ・ボリュームを使用すると、Oracle ACFSメタデータへのアクセスおよび更新にかかる時間が短縮され、パフォーマンスが向上する可能性があります。アクセラレータ・ボリュームは、プライマリ・ボリュームのストレージよりも大幅に高速なストレージを使用してディスク・グループに作成する必要があります。アクセラレータ・ボリュームは、mkfs
コマンドの-a
オプションを使用して作成します。詳細は、「Oracle ACFSアクセラレータ・ボリューム」を参照してください。
4 KBのセクター/メタデータ
次に、COMPATIBLE.ADVM
ディスク・グループ属性値に基づいた-i
オプションおよびメタデータ・ブロック・サイズの使用についてまとめます。
-
COMPATIBLE.ADVM
が12.2
以上に設定されている場合、メタデータ・ブロック・サイズはデフォルトで4096
バイトです。 -
COMPATIBLE.ADVM
が12.2
未満に設定されている場合、ブロック・サイズは512バイトに設定されます。 -
COMPATIBLE.ADVM
が12.2
未満に設定されているのに、論理セクター・サイズが512バイトでない場合、コマンドは失敗します。
ユーザー・データIOでは、標準ユーザーIOリクエストに対して512バイトの小規模な転送が引き続きサポートされます。ファイルシステムのOracle ADVMボリュームの論理ディスク・セクター・サイズが4 Kの場合、最良のパフォーマンスを得るには、ユーザー直接IOリクエストを4 Kファイル・オフセットに揃えて、4 KBの倍数の長さにする必要があります。4 Kメタデータ・ブロック・サイズ・フォーマットでのみ、論理ディスク・セクターが4 KのADVMボリュームがサポートされます。
論理ディスク・サイズが4096のOracle ADVMボリュームをフォーマットしたり、-i 4096
オプションを使用して論理ディスク・セクター・サイズが512バイトのOracle ADVMボリュームをフォーマットするには、COMPATIBLE.ADVM
値を12.2
以上に設定する必要があります。
例
Oracle ACFSファイルシステムを作成する前に、まずOracle ADVMボリューム・デバイスが使用可能かどうか確認します。ASMCMD volinfo
コマンドを使用すれば、ボリュームおよびボリューム・デバイスの情報を表示できます。次に例を示します。
ASMCMD [+] > volinfo -a ... Volume Name: VOLUME1 Volume Device: /dev/asm/volume1-123 State: ENABLED ...
volcreate
コマンドおよびvolinfo
コマンドの詳細は、「ASMCMDによるOracle ADVMの管理」を参照してください。
このコマンドでは、ボリューム・デバイス・ファイルにOracle ACFSファイルシステムを作成します。
例16-3 mkfsコマンドの使用方法
$ /sbin/mkfs -t acfs /dev/asm/volume1-123
例16-4 mkfsコマンドを使用したアクセラレータ・ボリュームの作成
このコマンドでは、アクセラレータ・ボリュームを使用してOracle ACFSファイルシステムを作成します。
$ /sbin/mkfs -t acfs -a /dev/asm/volume2-130 /dev/asm/volume1-127
mount
目的
Oracle ACFSファイルシステムをマウントします。
構文および説明
mount -h mount [-v] -n -t acfs [-o options] volume_device mount_point mount
mount
-h
は使用方法のテキストを表示して終了します。
表16-4に、mount
コマンドで使用可能なオプションを示します。
表16-4 Linux mountコマンドのオプション
オプション | 説明 |
---|---|
|
使用方法のヘルプ・テキストを表示して終了します。 |
|
Linuxでのファイルシステムのタイプを指定します。 |
|
verboseモードを指定します。操作が発生すると、進捗状況が表示されます。 |
|
|
|
オプションは
|
|
|
|
このファイルシステムがマウントされるディレクトリを指定します。 |
mount
は、ディレクトリの名前であるマウント・ポイントでOracle ACFS階層にファイルシステムをアタッチします。マウントは、mountコマンドが発行されたノードで起こります。ファイルシステムがこのノードでディスマウントの状態でない場合、mountコマンドはエラーを戻します。
マウント失敗の原因をmount
mountコマンドに戻すことは、いつでもできるわけではありません。これが起こると、Oracle ACFSは失敗の原因をシステム・コンソールおよび関連付けられたシステム・ログ・ファイルに書き込みます。
mount
の実行に成功すると、V$ASM_VOLUME
ビューのMOUNTPATH
フィールドに、ファイルシステムがマウントされたディレクトリ名が表示されます。
Oracle ACFSファイルシステムは1つのマウント・ポイントにのみマウントされます。同じマウント・ポイント名をすべてのクラスタ・メンバーで使用する必要があります。
mount
コマンドをパラメータなしで実行すると、マウント済のすべてのファイルシステムがリストされます。
mount
を実行するにはroot
権限が必要です。
例
1つ目の例は、マウント・ポイント/acfsmounts/acfs1
にvolume1-123
をマウントする方法を示しています。2つ目の例は、登録済のOracle ACFSファイルシステムをすべてマウントする方法を示しています。all
オプションを指定する場合、デバイスおよびディレクトリは必須ですが、使用しないのでダミー名(none
)を入力します。
例16-5 mountコマンドの使用方法
# /bin/mount -t acfs /dev/asm/volume1-123 /acfsmounts/acfs1 # /bin/mount -t acfs -o all none none
umount
目的
Oracle ACFSファイルシステムをディスマウントします。
構文および説明
umount -h umount [-v] -l -n volume_device |mount_point umount -a -l -n [-t acfs]
umount
-h
は使用方法のテキストを表示して終了します。
表16-5に、umount
コマンドで使用可能なオプションを示します。
表16-5 Linux umountコマンドのオプション
オプション | 説明 |
---|---|
|
使用方法のヘルプ・テキストを表示して終了します。 |
|
Linuxでのファイルシステムのタイプを指定します。 |
|
verboseモードを指定します。操作が発生すると、進捗状況が表示されます。 |
|
このノードのすべてのOracle ACFSファイルシステムをディスマウントすることを指定します。 |
|
遅延アンマウントを指定します。Oracle ACFSファイルシステムがディスマウントされますが、ファイルシステムへのすべての参照のクリーンアップはシステムがビジーでなくなったときに発生します。 |
|
|
|
|
|
このファイルシステムがマウントされるディレクトリを指定します。 |
umount
は、現在のノード上のファイルシステム階層からOracle ACFSをデタッチします。
umount
コマンドは、ファイルシステムが完全にアンマウントされるまで、オペレーティング・システム・プロンプトに制御を戻しません。
ファイルシステムがビジーである場合、umount
は失敗します。
umount
コマンドを実行するには、root
権限が必要です。
例
次の例は、Oracle ACFSファイルシステムのディスマウント方法を示しています。1つ目の例では、ボリューム・デバイス・ファイルを使用し、2つ目の例ではファイルシステムを使用しています。
例16-6 umountコマンドの使用方法
# /bin/umount /dev/asm/volume1-123 # /bin/umount /acfsmounts/acfs1