4年程前から稼動しているLinuxシステム(Oracle8i使用)があります。そのシステムでexpしたデータを、別のサーバ(同じくOracle8i)にimpしたいのですが、エラーになってしまいます。
IMP-00003: ORACLE error 1237 encountered
ORA-01237: cannot extend datafile 1
ORA-01110: data file 1: '/u01/app/oracle/oradata/orcl/system01.dbf'
ORA-19502: write error on file "/u01/app/oracle/oradata/orcl/system01.dbf", bloc
kno 202993 (blocksize=8192)
ORA-27072: skgfdisp: I/O error
Linux Error: 9: Bad file descriptor
Additional information: 202993
Import terminated successfully with warnings.
いろいろ調べたら SYSTEM にデータを入れるのは良くないということがわかりましたが、このサーバは本番サーバではないので表の中身を select で見れれば十分なので、このままの構成で行かれればと思います。
ディスク容量が不足しているようですが、DBA Studio で調べてみると、SYSTEM 1,608,576KB(1,570MB)中、800,992KB(782MB)使用中と表示されます。
imp したいファイルは 158,880KB(155.2MB)なので空き容量の部分に余裕で入ると思うのですが、データファイルを拡張しようとしているみたいです。
df コマンドの出力は
/dev/sda6 2909420 2745980 15644 99% /u01
となり、確かにパーティションの空き容量はないのですが、SYSTEM領域の残り800MBの部分にはインポートできないのでしょうか。
No.1
- 回答日時:
この当たりではないかと思うんですが...
試しに、違うパーティションに割り当てた表領域にインポートしてみてください。
参考URL:https://www.ashisuto.co.jp/standard/faq/2002/st6 …
早速の解凍ありがとうございます。
ご指摘のページを拝見しましたが、ソートやUPDATEのときにエラーが出る状態ではないので、一時表領域の問題ではなさそうな気がします。
800MBの空き領域はあきらめ、別パーティションにimpしようと思いデータファイルを作成し下記のようにしてみましたが、同じエラーになってしまいました。
SQL> alter user user1 default tablespace data1;
User altered.
IMP-00003: ORACLE error 1237 encountered
ORA-01237: cannot extend datafile 1
ORA-01110: data file 1: '/u01/app/oracle/oradata/orcl/system01.dbf'
ORA-19502: write error on file "/u01/app/oracle/oradata/orcl/system01.dbf", bloc
kno 202993 (blocksize=8192)
ORA-27072: skgfdisp: I/O error
Linux Error: 9: Bad file descriptor
Additional information: 202993
impコマンドでロードする際の表領域の指定はどのようにすれば良いのでしょうか?
No.2ベストアンサー
- 回答日時:
DBの定義情報わかりますか?(init*.ora)db_block_sizeとかcontrol_filesとかです。
Oracleの場合仮に1ブロック100MBであった場合で
現在99MB分使用している状況だとします。
そこへimpなどで2MB分を投入した場合、当然拡張され、DB上101MBとなりますが、
実ファイル(Linuxのdisk)上では新たに100MB分データが増えますよ。
ですので150MBしか追加しないので大丈夫だと思っていても、
拡張された結果、disk上は1GBの空きが必要だったなんてことがあるということです。
あとdfの結果ですが残り容量が「15644」とありますが単位は何ですか?MB?
やはりこちらが足らないように感じるのですが・・・
この回答への補足
回答ありがとうございます。
/u01/app/oracle/admin/orcl/pfile/initorcl.ora の中の定義情報は以下のようになっています。単位はわかりません。
db_block_size = 8192
control_files = ("/u01/app/oracle/oradata/orcl/control01.ctl", "/u02/app/oracle/oradata/orcl/control02.ctl", "/u03/app/oracle/oradata/orcl/control03.ctl")
Linuxのファイルシステム上の空き領域は15644Kバイト、つまり15Mバイトしかありません。足りないことは十分承知ですが、拡張は予算的にも不可能な状況です。でも表領域には空きがあるようなので、そこに格納できないかと思っています。
DBA Studioで見ると、使用しているSYSTEM表領域は下記のように表示されます。
1,608,576KB(1,570MB)中、800,992KB(782MB)使用中
つまり800Mバイト近くが空き領域になっているはずなので、ここに格納されて欲しいのです。この800Mバイト近い領域は使われずに、必ず実ファイルが拡張されてしまうのでしょうか?
150Mバイトのデータを追加するために1GBの空き容量が必要だとは知りませんでした。そんなにディスクを無駄遣いするのなら、もうOracleは使いません。
No.3
- 回答日時:
No.2です。
一点誤解を与えてしまいそうなので補足します。
> 150Mバイトのデータを追加するために1GBの空き容量が必要だとは知りませんでした。そんなにディスクを無駄遣いするのなら、もうOracleは使いません。
その結論は早計ですよ。1GBというのはあくまでたとえ話でした。
単に追加で150M増やしたいからといってもそれ以上diskを使用することもある
ということです。大げさすぎましたすいません。
DBはなんだかんだでOracleが一番良いと思いますよ。
規模の大きいものはOracle、小さいものはSQLserverというのが大体の主流ではないでしょうか。
ブロック拡張に関してはデフォルト設定のようですのでもともと
たいした規模のDBではないということですね?
テーブルスペース【system】の空き領域が800MBほどということですね。
このsystem表領域は実ファイルでは/u01/app/oracle/oradata/orcl/system01.dbfですが
ファイルサイズは1.5GBくらいでしょうか?
それ以上であれば何らかの理由で既に空き領域が無いことになります。
例えばあるプロック(表領域を細かく刻んだ単位:この場合約8KB単位)が破損していて
使用できないため拡張しようとしていることも考えられます。
通常考えてそれだけの空き容量があればスペース拡張はしないはずです。
一度ブロック破損していないかチェックしてみてはいかがでしょうか?
dbvコマンドです。使用例としては以下の通りです。
※DB停止後
dbv blocksize=8192 FILE=/u01/app/oracle/oradata/orcl/system01.dbf
この回答への補足
回答ありがとうございます。
ご推測のように、それほど大きなデータベースではありません。
system01.dbf は 1,468,014,592バイト(1.4GB) あります。
dbvを実行してみました。
DBVERIFY: Release 8.1.6.1.0 - Production on Fri Nov 18 14:09:07 2005
(c) Copyright 1999 Oracle Corporation. All rights reserved.
DBVERIFY - Verification starting : FILE = /u01/app/oracle/oradata/orcl/system01.dbf
DBVERIFY - Verification complete
Total Pages Examined : 179200
Total Pages Processed (Data) : 78328
Total Pages Failing (Data) : 0
Total Pages Processed (Index): 74099
Total Pages Failing (Index): 0
Total Pages Processed (Other): 25826
Total Pages Empty : 947
Total Pages Marked Corrupt : 0
Total Pages Influx : 0
Index に意外に多くのページが使われていることと、Other に無視できない量のページが使われていることが気になりました。
Other とは何なのでしょうか。
お探しのQ&Aが見つからない時は、教えて!gooで質問しましょう!
似たような質問が見つかりました
- その他(SNS・コミュニケーションサービス) 爆サイやっていたら、下のような文字が出ました! これは何なのでしょうか? nginx error! 1 2023/06/09 12:27
- Windows 10 VirtualBox 7のゲストOSでの物理HDDパーティションのマウント方法 2 2023/05/04 13:01
- UNIX・Linux VirtualBox ゲストOSにPC内蔵HDDのパーティションをマウントする方法は? 2 2023/05/06 22:52
- C言語・C++・C# c言語の問題の説明、各所ごとに 5 2023/07/26 11:03
- MySQL 参考書に従って入力したつもりでしたが、最後はエラーがでました。 1 2022/09/28 03:45
- Excel(エクセル) EXCELの外部データ取得ができない 1 2023/03/23 09:03
- Excel(エクセル) SUMIFSと日付変換 10 2023/04/16 15:38
- Oracle oracleで 10,20, 30, というデータがあるとして ,区切りでデータが何件あるか調べる関 3 2023/03/14 15:56
- その他(プログラミング・Web制作) セレクトボックスで選択された値をコントローラーで使用したい 2 2022/07/26 16:41
- タブレット アンドロイドタブレットのSDカード 3 2022/06/13 12:07
このQ&Aを見た人はこんなQ&Aも見ています
関連するカテゴリからQ&Aを探す
おすすめ情報
このQ&Aを見た人がよく見るQ&A
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
Oracleで空きがあるのにimport...
-
表領域の作成について
-
Oracle バッファ領域に...
-
4GB = 4096MB ではない?
-
なぜ再起動すると空き領域が増...
-
HDDの代替領域のサイズについて
-
「.ora」「.dbf」の違い
-
DBCDで作られた USERS(表領...
-
AccessでORA-01114
-
USBメモリの未割り当て領域につ...
-
DB容量の確認方法
-
ORA-01013のエラーについて経験...
-
CASE文のエラーについて
-
SQL*Plusで、コマンドの返答を...
-
Oracleの起動時に、マウントし...
-
SQLLOADER
-
SQL実行結果の出力を見やすくし...
-
DOSプロンプトとコマンドプロン...
-
ORA-01843: 指定した月が無効で...
-
「ORA-00907: 右カッコがありま...
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
4GB = 4096MB ではない?
-
表領域 TEMPの使用率。
-
Oracle バッファ領域に...
-
新規表領域の作成について
-
フォルダウィンドウのデータフ...
-
DB容量の確認方法
-
sysauxの読み方について
-
表領域の作成について
-
なぜ再起動すると空き領域が増...
-
どうしてpn接合ではp領域とn領...
-
AccessでORA-01114
-
HDの不良クラスタをパーティシ...
-
エクセルVBAでRangeの引数制限?
-
表領域に追加したファイルの削除
-
データファイルの拡張
-
オフラインリカバリが必要なDBF...
-
SQLSERVERでも表領域は作れます...
-
「.ora」「.dbf」の違い
-
表領域の拡張について
-
エンタープライズマネージャ『...
おすすめ情報