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.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 とは何なのでしょうか。
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コマンドでロードする際の表領域の指定はどのようにすれば良いのでしょうか?
お探しのQ&Aが見つからない時は、教えて!gooで質問しましょう!
このQ&Aを見た人はこんなQ&Aも見ています
-
あるあるbotに投稿したけど採用されなかったあるある募集
あるあるbotに投稿したけど採用されなかったあるあるをこちらに投稿してください
-
フォロワー20万人のアカウントであなたのあるあるを披露してみませんか?
あなたが普段思っている「これまだ誰も言ってなかったけど共感されるだろうな」というあるあるを教えてください
-
映画のエンドロール観る派?観ない派?
映画が終わった後、すぐに席を立って帰る方もちらほら見かけます。皆さんはエンドロールの最後まで観ていきますか?
-
海外旅行から帰ってきたら、まず何を食べる?
帰国して1番食べたくなるもの、食べたくなるだろうなと思うもの、皆さんはありますか?
-
天使と悪魔選手権
悪魔がこんなささやきをしていたら、天使のあなたはなんと言って止めますか?
-
importについて
Oracle
-
Data Pump で大量データインポートの際のUNDO表領域、TEMP表領域不足エラー解消法のついて
Oracle
関連するカテゴリからQ&Aを探す
おすすめ情報
- ・漫画をレンタルでお得に読める!
- ・街中で見かけて「グッときた人」の思い出
- ・「一気に最後まで読んだ」本、教えて下さい!
- ・幼稚園時代「何組」でしたか?
- ・激凹みから立ち直る方法
- ・1つだけ過去を変えられるとしたら?
- ・【あるあるbot連動企画】あるあるbotに投稿したけど採用されなかったあるある募集
- ・【あるあるbot連動企画】フォロワー20万人のアカウントであなたのあるあるを披露してみませんか?
- ・映画のエンドロール観る派?観ない派?
- ・海外旅行から帰ってきたら、まず何を食べる?
- ・誕生日にもらった意外なもの
- ・天使と悪魔選手権
- ・ちょっと先の未来クイズ第2問
- ・【大喜利】【投稿~9/7】 ロボットの住む世界で流行ってる罰ゲームとは?
- ・推しミネラルウォーターはありますか?
- ・都道府県穴埋めゲーム
- ・この人頭いいなと思ったエピソード
- ・準・究極の選択
- ・ゆるやかでぃべーと タイムマシンを破壊すべきか。
- ・歩いた自慢大会
- ・許せない心理テスト
- ・字面がカッコいい英単語
- ・これ何て呼びますか Part2
- ・人生で一番思い出に残ってる靴
- ・ゆるやかでぃべーと すべての高校生はアルバイトをするべきだ。
- ・初めて自分の家と他人の家が違う、と意識した時
- ・単二電池
- ・チョコミントアイス
このQ&Aを見た人がよく見るQ&A
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
4GB = 4096MB ではない?
-
sysauxの読み方について
-
表領域の作成について
-
DB容量の確認方法
-
フォルダウィンドウのデータフ...
-
エクセルのグラフ作成にて―項目...
-
半導体デバイス(バイポーラnpn)...
-
Oracleで空きがあるのにimport...
-
表領域 TEMPの使用率。
-
仮想メモリ領域固定によるHDDへ...
-
「.ora」「.dbf」の違い
-
HDDの代替領域のサイズについて
-
増設したHDDに、新たにDtoD領域...
-
データファイルの拡張
-
UNDO表領域の拡張について
-
なぜ再起動すると空き領域が増...
-
ORA-01013のエラーについて経験...
-
CASE文のエラーについて
-
PL/SQLのコンパイルエラーにつ...
-
Oracleの起動時に、マウントし...
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
4GB = 4096MB ではない?
-
表領域の作成について
-
なぜ再起動すると空き領域が増...
-
フォルダウィンドウのデータフ...
-
データファイルの拡張
-
新規表領域の作成について
-
sysauxの読み方について
-
HDの不良クラスタをパーティシ...
-
表領域 TEMPの使用率。
-
Oracle バッファ領域に...
-
空のDVDの見分け方
-
DB容量の確認方法
-
エクセルVBAでRangeの引数制限?
-
「.ora」「.dbf」の違い
-
表領域に追加したファイルの削除
-
AccessでORA-01114
-
どうしてpn接合ではp領域とn領...
-
表領域の拡張について
-
エンタープライズマネージャ『...
-
SQLSERVERでも表領域は作れます...
おすすめ情報