JP3620385B2 - データベース容量監視装置およびデータベース容量監視方法 - Google Patents
データベース容量監視装置およびデータベース容量監視方法 Download PDFInfo
- Publication number
- JP3620385B2 JP3620385B2 JP36381499A JP36381499A JP3620385B2 JP 3620385 B2 JP3620385 B2 JP 3620385B2 JP 36381499 A JP36381499 A JP 36381499A JP 36381499 A JP36381499 A JP 36381499A JP 3620385 B2 JP3620385 B2 JP 3620385B2
- Authority
- JP
- Japan
- Prior art keywords
- database
- extent
- table area
- maximum size
- capacity
- Prior art date
- Legal status (The legal status is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the status listed.)
- Expired - Fee Related
Links
Images
Landscapes
- Information Retrieval, Db Structures And Fs Structures Therefor (AREA)
Description
【0001】
【発明の属する技術分野】
本発明は、データベースの空き容量を監視するデータベース容量監視装置およびデータベース容量監視方法に関し、特にデータベースの表領域に配置されているセグメント毎にデータの増加に伴い随時新たなエクステントを割り当てることによりデータを書き込むデータベースの空き容量を監視するデータベース容量監視装置およびデータベース容量監視方法に関する。
【0002】
【従来の技術】
従来、データベースでは、限られた記憶容量の中で効率良く運用するために、データベースの各表領域毎に最低限の記憶容量を設定し、各表領域に設定された記憶容量が不足してきた場合に新たな記憶容量を設定するようにしており、Oracle(Oracle Corporationの登録商標)に則したデータベースの場合、データベースの表領域の各セグメントにおいて、各セグメントの中のOracleが書き込むデータが増加し、各セグメントに割り当てられている連続するデータが書き込まれる最小単位のデータブロックの集まりであるエクステントが満杯になると、満杯になったセグメントに対して新たなエクステントが割り当てられる。
【0003】
このようなデータベースにおいては、データベースの各表領域毎の空き容量と表領域の各セグメントのエクステントの数の変化とを監視することで、データベースの状況を監視していた。
【0004】
【発明が解決しようとする課題】
しかしながら、従来技術では、データベースの表領域の各セグメントに対して新たに割り当てられるエクステントサイズ、すなわちエクステントに新たに割り当てられる記憶容量が各セグメント毎に異なっているため、データベースの各表領域毎の空き容量と表領域の各セグメントのエクステントの数の変化とを監視するのみでは、データベースの表領域の各セグメントに対する新たなエクステントの割り当てに際する記憶容量不足を事前に察知することができないという問題点があった。
【0005】
本発明は斯かる問題点を鑑みてなされたものであり、その目的とするところは、データベースの表領域の各セグメントに対する新たなエクステントの割り当ての際の記憶容量不足を事前に察知することで障害を未然に防ぐことができ、システム全体の可用性を高め、信頼性も向上することができるデータベース容量監視装置およびデータベース容量監視方法を提供する点にある。
【0006】
【課題を解決するための手段】
本発明は上記課題を解決すべく、以下に掲げる構成とした。
請求項1記載の発明の要旨は、データベースの表領域に設定されている記憶容量の空き容量を監視するデータベース容量監視装置であって、前記データベースの前記表領域の連続した前記空き容量の最大サイズを算出する空き容量算出手段と、前記データベースの前記表領域に配置されているセグメント毎の次に割り当てられるエクステントの中の最大サイズを抽出するエクステントサイズ抽出手段と、前記空き容量算出手段により算出された前記データベースの前記表領域の連続した前記空き容量の最大サイズと前記エクステントサイズ抽出手段により抽出された前記データベースの前記表領域に配置されている前記セグメント毎の次に割り当てられる前記エクステントの中の最大サイズとを比較する容量比較手段と、該容量比較手段による前記データベースの前記表領域の連続した前記空き容量の最大サイズと前記データベースの前記表領域に配置されている前記セグメント毎の次に割り当てられる前記エクステントの中の最大サイズとの比較結果を出力する比較結果出力手段とを具備することを特徴とするデータベース容量監視装置に存する。
また請求項2記載の発明の要旨は、前記比較結果出力手段は、前記データベースの前記表領域の連続した前記空き容量の最大サイズよりも前記データベースの前記表領域に配置されている前記セグメント毎の次に割り当てられる前記エクステントの中の最大サイズが大きくなった場合に警告メッセージを出力させることを特徴とする請求項1記載のデータベース容量監視装置に存する。
また請求項3記載の発明の要旨は、前記データベースの前記表領域に配置されている前記セグメントに対して前記エクステントが新たに割り当てられたことを検知するエクステント割り当て検知手段を具備し、該エクステント割り当て検知手段により前記データベースの前記表領域に配置されている前記セグメントに対して前記エクステントが新たに割り当てられたことが検知されたときに前記空き容量算出手段と前記エクステントサイズ抽出手段とを起動させることを特徴とする請求項1又は2記載のデータベース容量監視装置に存する。
また請求項4記載の発明の要旨は、前記データベースの前記表領域が複数ある場合には、前記空き容量算出手段は、新たに前記エクステントが割り当てられた前記セグメントの配置されている前記データベースの前記表領域のみの連続した前記空き容量の最大サイズを算出させることを特徴とする請求項1乃至3のいずれかに記載のデータベース容量監視装置に存する。
また請求項5記載の発明の要旨は、前記エクステントサイズ抽出手段により抽出された前記データベースの前記表領域に配置されている前記セグメント毎の次に割り当てられる前記エクステントの中の最大サイズを記憶するエクステントサイズ記憶手段を具備し、前記データベースの前記表領域に新たな前記セグメントが作成されるまでは、前記エクステントサイズ抽出手段を起動させず、前記容量比較手段において前記空き容量算出手段により算出された前記データベースの前記表領域の連続した前記空き容量の最大サイズと前記エクステントサイズ記憶手段に記憶された前記データベースの前記表領域に配置されている前記セグメント毎の次に割り当てられる前記エクステントの中の最大サイズとを比較させることを特徴とする請求項1乃至4のいずれかに記載のデータベース容量監視装置に存する。
また請求項6記載の発明の要旨は、データベースの表領域に設定されている記憶容量の空き容量を監視するデータベース容量監視方法であって、前記データベースの前記表領域の連続した前記空き容量の最大サイズを算出し、前記データベースの前記表領域に配置されているセグメント毎の次に割り当てられるエクステントの中の最大サイズを抽出し、前記算出した前記データベースの前記表領域の連続した前記空き容量の最大サイズと前記抽出した前記データベースの前記表領域に配置されている前記セグメント毎の次に割り当てられる前記エクステントの中の最大サイズとを比較し、前記データベースの前記表領域の連続した前記空き容量の最大サイズと前記データベースの前記表領域に配置されている前記セグメント毎の次に割り当てられる前記エクステントの中の最大サイズとの比較結果を出力することを特徴とするデータベース容量監視方法に存する。
また請求項7記載の発明の要旨は、前記データベースの前記表領域の連続した前記空き容量の最大サイズよりも前記データベースの前記表領域に配置されている前記セグメント毎の次に割り当てられる前記エクステントの中の最大サイズが大きくなった場合に警告メッセージを出力することを特徴とする請求項6記載のデータベース容量監視方法に存する。
また請求項8記載の発明の要旨は、前記データベースの前記表領域に配置されている前記セグメントに対して前記エクステントが新たに割り当てられたことを検知し、該検知により前記データベースの前記表領域に配置されている前記セグメントに対して前記エクステントが新たに割り当てられたことを検知したときに、前記データベースの前記表領域の連続した前記空き容量の最大サイズの算出と前記データベースの前記表領域に配置されている前記セグメント毎の次に割り当てられる前記エクステントの中の最大サイズの抽出とを実行することを特徴とする請求項6又は7記載のデータベース容量監視方法に存する。
また請求項9記載の発明の要旨は、前記データベースの前記表領域が複数ある場合に、新たに前記エクステントが割り当てられた前記セグメントの配置されている前記データベースの前記表領域のみの連続した前記空き容量の最大サイズを算出することを特徴とする請求項6乃至8のいずれかに記載のデータベース容量監視方法に存する。
また請求項10記載の発明の要旨は、前記抽出した前記データベースの前記表領域に配置されている前記セグメント毎の次に割り当てられる前記エクステントサイズの中の最大サイズを記憶し、前記データベースの前記表領域に新たな前記セグメントが作成されるまでは、前記データベースの前記表領域に配置されているセグメント毎の次に割り当てられるエクステントの中の最大サイズの抽出を実行しないで、前記算出した前記データベースの前記表領域の連続した前記空き容量の最大サイズと前記記憶した前記データベースの前記表領域に配置されている前記セグメント毎の次に割り当てられる前記エクステントサイズの中の最大サイズとを比較することを特徴とする請求項6乃至9のいずれかに記載のデータベース容量監視方法に存する。
また請求項11記載の発明の要旨は、請求項6乃至10のいずれかに記載のデータベース容量監視方法を実行可能なプログラムが記憶されている記憶媒体に存する。
【0007】
【発明の実施の形態】
以下、本発明の実施の形態を図面に基づいて詳細に説明する。
【0008】
図1は、本発明に係るデータベース容量監視装置の実施の形態の構成を示すブロック図である。
【0009】
本実施の形態は、データベース1の各表領域の連続未使用領域を算出する空き容量算出部2と、空き容量算出部2により算出されたデータベース1の各表領域の連続未使用領域の容量を記憶する空き容量記憶部3と、データベース1の各表領域に配置されている各セグメント毎の次に割り当てられるエクステントサイズの最大のサイズを抽出するエクステント抽出部4と、エクステント抽出部4により抽出された次に割り当てられるエクステントサイズの最大のサイズを記憶するエクステント記憶部5と、空き容量記憶部3に記憶された連続未使用領域の容量とエクステント記憶部5に記憶された次に割り当てられるエクステントのサイズの最大のサイズとをデータベース1の各表領域毎に比較する容量比較部6と、容量比較部6による比較結果を出力する出力部7とからなる。
【0010】
空き容量算出部2は、Oracleのデータディクショナリのdba_free_spaceを参照することで、各表領域の最大のバイト数を抽出し、連続未使用領域、すなわち連続した空き容量の最大のサイズを各表領域毎に算出し、算出した各表領域毎の連続未使用の最大のサイズを空き容量記憶部3に記憶する。
【0011】
エクステント抽出部4は、Oracleのデータディクショナリのdba_segmentsを参照することで、各表領域に配置されている各セグメント毎の次エクステントサイズ、すなわち次に割り当てられるエクステントサイズの最大のサイズを各表領域毎に抽出し、抽出した各表領域毎の次エクステントサイズの最大のサイズをエクステント記憶部5に記憶する。
【0012】
容量比較部6は、空き容量記憶部3に記憶された各表領域毎の連続未使用の最大のサイズとエクステント記憶部5に記憶された各表領域毎の次エクステントサイズの最大のサイズとを各表領域毎に比較し、各表領域毎の比較結果を出力部7により出力する。なお、比較結果の出力に際し、新たなエクステントが割り付けられる際に容量不足となる可能性があるのは、空き容量記憶部3に記憶された連続未使用の最大のサイズよりもエクステント記憶部5に記憶された次エクステントサイズの最大のサイズが大きくなる場合であるため、各表領域毎の全ての比較結果を出力しないで、空き容量記憶部3に記憶された連続未使用の最大のサイズよりもエクステント記憶部5に記憶された次エクステントサイズの最大のサイズが大きくなった表領域のみを指定した警告メッセージを出力するようにするとより効率的である。
【0013】
次に、本実施の形態の動作を図2を参照して詳細に説明する。
図2は、本発明に係るデータベース容量監視装置の実施の形態の動作を説明するためのフローチャートである。
【0014】
本実施の形態のデータベース容量監視装置は、所定の時間毎に自動的に起動される様になっており、起動の時間間隔は、図示しない入力部により指定できる。
【0015】
本実施の形態のデータベース容量監視装置は、起動されるとまず空き容量算出部2は、Oracleのデータディクショナリのdba_free_spaceを参照し、各表領域毎の最大のバイト数をmax(bytes)で抽出することで各表領域毎の連続未使用領域の最大のサイズを算出し(S1)、算出した各表領域毎の連続未使用領域の最大のサイズを空き容量記憶部3に記憶する。具体的には、データディクショナリのdba_free_spaceを参照してSQR(構造化照会言語)であるselect max(free_space) from dba_free_spaceを実行することにより、各表領域毎の連続未使用領域の最大のサイズを算出する。
【0016】
次にエクステント抽出部4は、Oracleのデータディクショナリのdba_segmentsを参照して、各表領域に配置されている各セグメント毎の次エクステントサイズ、すなわち次に割り当てられるエクステントサイズの最大のサイズを各表領域毎に抽出し(S2)、抽出した各表領域毎の次エクステントサイズの最大のサイズをエクステント記憶部5に記憶する。具体的には、データディクショナリのdba_segmentsを参照してSQR(構造化照会言語)であるselect max(next_extent) from dba_segmentを実行することにより、各表領域毎の次エクステントサイズの最大のサイズを抽出する。
【0017】
次に容量比較部6は、空き容量記憶部3に記憶された各表領域毎の連続未使用の最大のサイズとエクステント記憶部5に記憶された各表領域毎の次エクステントサイズの最大のサイズとを各表領域毎に比較し(S3)、空き容量記憶部3に記憶された各表領域毎の連続未使用領域の最大のサイズよりもエクステント記憶部5に記憶された各表領域毎の次エクステントサイズの最大のサイズが大きくなった表領域に対して警告メッセージをディプレイ等からなる出力部7から出力し(S4)、全ての表領域において空き容量記憶部3に記憶された各表領域毎の連続未使用領域の最大のサイズがエクステント記憶部5に記憶された各表領域毎の次エクステントサイズの最大のサイズよりも大きい場合には、処理動作を終了する。
【0018】
以上説明したように、本実施の形態によれば、各表領域毎の連続未使用領域の最大のサイズと各表領域毎の次エクステントサイズの最大のサイズとを各表領域毎に比較することにより、データベースの表領域の各セグメントに対する新たなエクステントの割り当ての際の記憶容量不足を事前に察知することで障害を未然に防ぐことができ、システム全体の可用性を高め、信頼性も向上することができるという効果を奏する。
【0019】
また、本実施の形態では、所定時間毎に起動するように構成したが、データベースの表領域に配置されているセグメントに対して新たにエクステントが割り当てられたことを検知する図示しないエクステント割り当て検知部を設け、エクステント割り当て検知部によりデータベースの表領域に配置されているセグメントに対して新たにエクステントが割り当てられたことを検知した際に起動するように構成することもできる。すなわち、データベースの表領域に配置されているセグメントに対して新たにエクステントが割り当てられた場合には、データベースの表領域の連続未使用領域が変化するため、変化したタイミングでデータベースの表領域の連続未使用領域と次エクステントサイズの最大のサイズとを比較することにより、確実にデータベースの表領域の各セグメントに対する新たなエクステントの割り当ての際の記憶容量不足を事前に察知することができる。
【0020】
また、本実施の形態をデータベースの表領域に配置されているセグメントに対して新たにエクステントが割り当てられたときに起動するように構成した場合には、セグメントに対して新たにエクステントが割り当てられたデータベースの表領域のみの連続未使用領域を算出すれば良く、データベースの全ての表領域の連続未使用領域を算出する必要はない。
【0021】
さらに、本実施の形態では、起動毎にデータベースの各表領域毎に次エクステントサイズの最大のサイズを抽出するように構成したが、エクステントサイズは、セグメントを作成するときに定義したNEXTパラメータにより指定するものであるため、新たなセグメントが作成されない限り、エクステント記憶部5に記憶された次エクステントサイズの最大のサイズを更新する必要がなく、新たなセグメントが作成された場合のみ、データベースの各表領域毎に次エクステントサイズの最大のサイズを抽出するように構成しても良い。
【0022】
なお、本発明が上記各実施形態に限定されず、本発明の技術思想の範囲内において、各実施形態は適宜変更され得ることは明らかである。また、上記構成部材の数、位置、形状等は上記実施の形態に限定されず、本発明を実施する上で好適な数、位置、形状等にすることができる。なお、各図において、同一構成要素には同一符号を付している。
【0023】
【発明の効果】
本発明のデータベース容量監視装置およびデータベース容量監視方法は、各表領域毎の連続未使用の最大のサイズと各表領域毎の次エクステントサイズの最大のサイズとを各表領域毎に比較することにより、データベースの表領域の各セグメントに対する新たなエクステントの割り当ての際の記憶容量不足を事前に察知することで障害を未然に防ぐことができ、システム全体の可用性を高め、信頼性も向上することができるという効果を奏する。
【図面の簡単な説明】
【図1】本発明に係るデータベース容量監視装置の実施の形態の構成を示すブロック図である。
【図2】本発明に係るデータベース容量監視装置の実施の形態の動作を説明するためのフローチャートである。
【符号の説明】
1 データベース
2 空き容量算出部
3 空き容量記憶部
4 エクステント抽出部
5 エクステント記憶部
6 容量比較部
7 出力部
【発明の属する技術分野】
本発明は、データベースの空き容量を監視するデータベース容量監視装置およびデータベース容量監視方法に関し、特にデータベースの表領域に配置されているセグメント毎にデータの増加に伴い随時新たなエクステントを割り当てることによりデータを書き込むデータベースの空き容量を監視するデータベース容量監視装置およびデータベース容量監視方法に関する。
【0002】
【従来の技術】
従来、データベースでは、限られた記憶容量の中で効率良く運用するために、データベースの各表領域毎に最低限の記憶容量を設定し、各表領域に設定された記憶容量が不足してきた場合に新たな記憶容量を設定するようにしており、Oracle(Oracle Corporationの登録商標)に則したデータベースの場合、データベースの表領域の各セグメントにおいて、各セグメントの中のOracleが書き込むデータが増加し、各セグメントに割り当てられている連続するデータが書き込まれる最小単位のデータブロックの集まりであるエクステントが満杯になると、満杯になったセグメントに対して新たなエクステントが割り当てられる。
【0003】
このようなデータベースにおいては、データベースの各表領域毎の空き容量と表領域の各セグメントのエクステントの数の変化とを監視することで、データベースの状況を監視していた。
【0004】
【発明が解決しようとする課題】
しかしながら、従来技術では、データベースの表領域の各セグメントに対して新たに割り当てられるエクステントサイズ、すなわちエクステントに新たに割り当てられる記憶容量が各セグメント毎に異なっているため、データベースの各表領域毎の空き容量と表領域の各セグメントのエクステントの数の変化とを監視するのみでは、データベースの表領域の各セグメントに対する新たなエクステントの割り当てに際する記憶容量不足を事前に察知することができないという問題点があった。
【0005】
本発明は斯かる問題点を鑑みてなされたものであり、その目的とするところは、データベースの表領域の各セグメントに対する新たなエクステントの割り当ての際の記憶容量不足を事前に察知することで障害を未然に防ぐことができ、システム全体の可用性を高め、信頼性も向上することができるデータベース容量監視装置およびデータベース容量監視方法を提供する点にある。
【0006】
【課題を解決するための手段】
本発明は上記課題を解決すべく、以下に掲げる構成とした。
請求項1記載の発明の要旨は、データベースの表領域に設定されている記憶容量の空き容量を監視するデータベース容量監視装置であって、前記データベースの前記表領域の連続した前記空き容量の最大サイズを算出する空き容量算出手段と、前記データベースの前記表領域に配置されているセグメント毎の次に割り当てられるエクステントの中の最大サイズを抽出するエクステントサイズ抽出手段と、前記空き容量算出手段により算出された前記データベースの前記表領域の連続した前記空き容量の最大サイズと前記エクステントサイズ抽出手段により抽出された前記データベースの前記表領域に配置されている前記セグメント毎の次に割り当てられる前記エクステントの中の最大サイズとを比較する容量比較手段と、該容量比較手段による前記データベースの前記表領域の連続した前記空き容量の最大サイズと前記データベースの前記表領域に配置されている前記セグメント毎の次に割り当てられる前記エクステントの中の最大サイズとの比較結果を出力する比較結果出力手段とを具備することを特徴とするデータベース容量監視装置に存する。
また請求項2記載の発明の要旨は、前記比較結果出力手段は、前記データベースの前記表領域の連続した前記空き容量の最大サイズよりも前記データベースの前記表領域に配置されている前記セグメント毎の次に割り当てられる前記エクステントの中の最大サイズが大きくなった場合に警告メッセージを出力させることを特徴とする請求項1記載のデータベース容量監視装置に存する。
また請求項3記載の発明の要旨は、前記データベースの前記表領域に配置されている前記セグメントに対して前記エクステントが新たに割り当てられたことを検知するエクステント割り当て検知手段を具備し、該エクステント割り当て検知手段により前記データベースの前記表領域に配置されている前記セグメントに対して前記エクステントが新たに割り当てられたことが検知されたときに前記空き容量算出手段と前記エクステントサイズ抽出手段とを起動させることを特徴とする請求項1又は2記載のデータベース容量監視装置に存する。
また請求項4記載の発明の要旨は、前記データベースの前記表領域が複数ある場合には、前記空き容量算出手段は、新たに前記エクステントが割り当てられた前記セグメントの配置されている前記データベースの前記表領域のみの連続した前記空き容量の最大サイズを算出させることを特徴とする請求項1乃至3のいずれかに記載のデータベース容量監視装置に存する。
また請求項5記載の発明の要旨は、前記エクステントサイズ抽出手段により抽出された前記データベースの前記表領域に配置されている前記セグメント毎の次に割り当てられる前記エクステントの中の最大サイズを記憶するエクステントサイズ記憶手段を具備し、前記データベースの前記表領域に新たな前記セグメントが作成されるまでは、前記エクステントサイズ抽出手段を起動させず、前記容量比較手段において前記空き容量算出手段により算出された前記データベースの前記表領域の連続した前記空き容量の最大サイズと前記エクステントサイズ記憶手段に記憶された前記データベースの前記表領域に配置されている前記セグメント毎の次に割り当てられる前記エクステントの中の最大サイズとを比較させることを特徴とする請求項1乃至4のいずれかに記載のデータベース容量監視装置に存する。
また請求項6記載の発明の要旨は、データベースの表領域に設定されている記憶容量の空き容量を監視するデータベース容量監視方法であって、前記データベースの前記表領域の連続した前記空き容量の最大サイズを算出し、前記データベースの前記表領域に配置されているセグメント毎の次に割り当てられるエクステントの中の最大サイズを抽出し、前記算出した前記データベースの前記表領域の連続した前記空き容量の最大サイズと前記抽出した前記データベースの前記表領域に配置されている前記セグメント毎の次に割り当てられる前記エクステントの中の最大サイズとを比較し、前記データベースの前記表領域の連続した前記空き容量の最大サイズと前記データベースの前記表領域に配置されている前記セグメント毎の次に割り当てられる前記エクステントの中の最大サイズとの比較結果を出力することを特徴とするデータベース容量監視方法に存する。
また請求項7記載の発明の要旨は、前記データベースの前記表領域の連続した前記空き容量の最大サイズよりも前記データベースの前記表領域に配置されている前記セグメント毎の次に割り当てられる前記エクステントの中の最大サイズが大きくなった場合に警告メッセージを出力することを特徴とする請求項6記載のデータベース容量監視方法に存する。
また請求項8記載の発明の要旨は、前記データベースの前記表領域に配置されている前記セグメントに対して前記エクステントが新たに割り当てられたことを検知し、該検知により前記データベースの前記表領域に配置されている前記セグメントに対して前記エクステントが新たに割り当てられたことを検知したときに、前記データベースの前記表領域の連続した前記空き容量の最大サイズの算出と前記データベースの前記表領域に配置されている前記セグメント毎の次に割り当てられる前記エクステントの中の最大サイズの抽出とを実行することを特徴とする請求項6又は7記載のデータベース容量監視方法に存する。
また請求項9記載の発明の要旨は、前記データベースの前記表領域が複数ある場合に、新たに前記エクステントが割り当てられた前記セグメントの配置されている前記データベースの前記表領域のみの連続した前記空き容量の最大サイズを算出することを特徴とする請求項6乃至8のいずれかに記載のデータベース容量監視方法に存する。
また請求項10記載の発明の要旨は、前記抽出した前記データベースの前記表領域に配置されている前記セグメント毎の次に割り当てられる前記エクステントサイズの中の最大サイズを記憶し、前記データベースの前記表領域に新たな前記セグメントが作成されるまでは、前記データベースの前記表領域に配置されているセグメント毎の次に割り当てられるエクステントの中の最大サイズの抽出を実行しないで、前記算出した前記データベースの前記表領域の連続した前記空き容量の最大サイズと前記記憶した前記データベースの前記表領域に配置されている前記セグメント毎の次に割り当てられる前記エクステントサイズの中の最大サイズとを比較することを特徴とする請求項6乃至9のいずれかに記載のデータベース容量監視方法に存する。
また請求項11記載の発明の要旨は、請求項6乃至10のいずれかに記載のデータベース容量監視方法を実行可能なプログラムが記憶されている記憶媒体に存する。
【0007】
【発明の実施の形態】
以下、本発明の実施の形態を図面に基づいて詳細に説明する。
【0008】
図1は、本発明に係るデータベース容量監視装置の実施の形態の構成を示すブロック図である。
【0009】
本実施の形態は、データベース1の各表領域の連続未使用領域を算出する空き容量算出部2と、空き容量算出部2により算出されたデータベース1の各表領域の連続未使用領域の容量を記憶する空き容量記憶部3と、データベース1の各表領域に配置されている各セグメント毎の次に割り当てられるエクステントサイズの最大のサイズを抽出するエクステント抽出部4と、エクステント抽出部4により抽出された次に割り当てられるエクステントサイズの最大のサイズを記憶するエクステント記憶部5と、空き容量記憶部3に記憶された連続未使用領域の容量とエクステント記憶部5に記憶された次に割り当てられるエクステントのサイズの最大のサイズとをデータベース1の各表領域毎に比較する容量比較部6と、容量比較部6による比較結果を出力する出力部7とからなる。
【0010】
空き容量算出部2は、Oracleのデータディクショナリのdba_free_spaceを参照することで、各表領域の最大のバイト数を抽出し、連続未使用領域、すなわち連続した空き容量の最大のサイズを各表領域毎に算出し、算出した各表領域毎の連続未使用の最大のサイズを空き容量記憶部3に記憶する。
【0011】
エクステント抽出部4は、Oracleのデータディクショナリのdba_segmentsを参照することで、各表領域に配置されている各セグメント毎の次エクステントサイズ、すなわち次に割り当てられるエクステントサイズの最大のサイズを各表領域毎に抽出し、抽出した各表領域毎の次エクステントサイズの最大のサイズをエクステント記憶部5に記憶する。
【0012】
容量比較部6は、空き容量記憶部3に記憶された各表領域毎の連続未使用の最大のサイズとエクステント記憶部5に記憶された各表領域毎の次エクステントサイズの最大のサイズとを各表領域毎に比較し、各表領域毎の比較結果を出力部7により出力する。なお、比較結果の出力に際し、新たなエクステントが割り付けられる際に容量不足となる可能性があるのは、空き容量記憶部3に記憶された連続未使用の最大のサイズよりもエクステント記憶部5に記憶された次エクステントサイズの最大のサイズが大きくなる場合であるため、各表領域毎の全ての比較結果を出力しないで、空き容量記憶部3に記憶された連続未使用の最大のサイズよりもエクステント記憶部5に記憶された次エクステントサイズの最大のサイズが大きくなった表領域のみを指定した警告メッセージを出力するようにするとより効率的である。
【0013】
次に、本実施の形態の動作を図2を参照して詳細に説明する。
図2は、本発明に係るデータベース容量監視装置の実施の形態の動作を説明するためのフローチャートである。
【0014】
本実施の形態のデータベース容量監視装置は、所定の時間毎に自動的に起動される様になっており、起動の時間間隔は、図示しない入力部により指定できる。
【0015】
本実施の形態のデータベース容量監視装置は、起動されるとまず空き容量算出部2は、Oracleのデータディクショナリのdba_free_spaceを参照し、各表領域毎の最大のバイト数をmax(bytes)で抽出することで各表領域毎の連続未使用領域の最大のサイズを算出し(S1)、算出した各表領域毎の連続未使用領域の最大のサイズを空き容量記憶部3に記憶する。具体的には、データディクショナリのdba_free_spaceを参照してSQR(構造化照会言語)であるselect max(free_space) from dba_free_spaceを実行することにより、各表領域毎の連続未使用領域の最大のサイズを算出する。
【0016】
次にエクステント抽出部4は、Oracleのデータディクショナリのdba_segmentsを参照して、各表領域に配置されている各セグメント毎の次エクステントサイズ、すなわち次に割り当てられるエクステントサイズの最大のサイズを各表領域毎に抽出し(S2)、抽出した各表領域毎の次エクステントサイズの最大のサイズをエクステント記憶部5に記憶する。具体的には、データディクショナリのdba_segmentsを参照してSQR(構造化照会言語)であるselect max(next_extent) from dba_segmentを実行することにより、各表領域毎の次エクステントサイズの最大のサイズを抽出する。
【0017】
次に容量比較部6は、空き容量記憶部3に記憶された各表領域毎の連続未使用の最大のサイズとエクステント記憶部5に記憶された各表領域毎の次エクステントサイズの最大のサイズとを各表領域毎に比較し(S3)、空き容量記憶部3に記憶された各表領域毎の連続未使用領域の最大のサイズよりもエクステント記憶部5に記憶された各表領域毎の次エクステントサイズの最大のサイズが大きくなった表領域に対して警告メッセージをディプレイ等からなる出力部7から出力し(S4)、全ての表領域において空き容量記憶部3に記憶された各表領域毎の連続未使用領域の最大のサイズがエクステント記憶部5に記憶された各表領域毎の次エクステントサイズの最大のサイズよりも大きい場合には、処理動作を終了する。
【0018】
以上説明したように、本実施の形態によれば、各表領域毎の連続未使用領域の最大のサイズと各表領域毎の次エクステントサイズの最大のサイズとを各表領域毎に比較することにより、データベースの表領域の各セグメントに対する新たなエクステントの割り当ての際の記憶容量不足を事前に察知することで障害を未然に防ぐことができ、システム全体の可用性を高め、信頼性も向上することができるという効果を奏する。
【0019】
また、本実施の形態では、所定時間毎に起動するように構成したが、データベースの表領域に配置されているセグメントに対して新たにエクステントが割り当てられたことを検知する図示しないエクステント割り当て検知部を設け、エクステント割り当て検知部によりデータベースの表領域に配置されているセグメントに対して新たにエクステントが割り当てられたことを検知した際に起動するように構成することもできる。すなわち、データベースの表領域に配置されているセグメントに対して新たにエクステントが割り当てられた場合には、データベースの表領域の連続未使用領域が変化するため、変化したタイミングでデータベースの表領域の連続未使用領域と次エクステントサイズの最大のサイズとを比較することにより、確実にデータベースの表領域の各セグメントに対する新たなエクステントの割り当ての際の記憶容量不足を事前に察知することができる。
【0020】
また、本実施の形態をデータベースの表領域に配置されているセグメントに対して新たにエクステントが割り当てられたときに起動するように構成した場合には、セグメントに対して新たにエクステントが割り当てられたデータベースの表領域のみの連続未使用領域を算出すれば良く、データベースの全ての表領域の連続未使用領域を算出する必要はない。
【0021】
さらに、本実施の形態では、起動毎にデータベースの各表領域毎に次エクステントサイズの最大のサイズを抽出するように構成したが、エクステントサイズは、セグメントを作成するときに定義したNEXTパラメータにより指定するものであるため、新たなセグメントが作成されない限り、エクステント記憶部5に記憶された次エクステントサイズの最大のサイズを更新する必要がなく、新たなセグメントが作成された場合のみ、データベースの各表領域毎に次エクステントサイズの最大のサイズを抽出するように構成しても良い。
【0022】
なお、本発明が上記各実施形態に限定されず、本発明の技術思想の範囲内において、各実施形態は適宜変更され得ることは明らかである。また、上記構成部材の数、位置、形状等は上記実施の形態に限定されず、本発明を実施する上で好適な数、位置、形状等にすることができる。なお、各図において、同一構成要素には同一符号を付している。
【0023】
【発明の効果】
本発明のデータベース容量監視装置およびデータベース容量監視方法は、各表領域毎の連続未使用の最大のサイズと各表領域毎の次エクステントサイズの最大のサイズとを各表領域毎に比較することにより、データベースの表領域の各セグメントに対する新たなエクステントの割り当ての際の記憶容量不足を事前に察知することで障害を未然に防ぐことができ、システム全体の可用性を高め、信頼性も向上することができるという効果を奏する。
【図面の簡単な説明】
【図1】本発明に係るデータベース容量監視装置の実施の形態の構成を示すブロック図である。
【図2】本発明に係るデータベース容量監視装置の実施の形態の動作を説明するためのフローチャートである。
【符号の説明】
1 データベース
2 空き容量算出部
3 空き容量記憶部
4 エクステント抽出部
5 エクステント記憶部
6 容量比較部
7 出力部
Claims (11)
- データベースの表領域に設定されている記憶容量の空き容量を監視するデータベース容量監視装置であって、
前記データベースの前記表領域の連続した前記空き容量の最大サイズを算出する空き容量算出手段と、
前記データベースの前記表領域に配置されているセグメント毎の次に割り当てられるエクステントの中の最大サイズを抽出するエクステントサイズ抽出手段と、
前記空き容量算出手段により算出された前記データベースの前記表領域の連続した前記空き容量の最大サイズと前記エクステントサイズ抽出手段により抽出された前記データベースの前記表領域に配置されている前記セグメント毎の次に割り当てられる前記エクステントの中の最大サイズとを比較する容量比較手段と、
該容量比較手段による前記データベースの前記表領域の連続した前記空き容量の最大サイズと前記データベースの前記表領域に配置されている前記セグメント毎の次に割り当てられる前記エクステントの中の最大サイズとの比較結果を出力する比較結果出力手段とを具備することを特徴とするデータベース容量監視装置。 - 前記比較結果出力手段は、前記データベースの前記表領域の連続した前記空き容量の最大サイズよりも前記データベースの前記表領域に配置されている前記セグメント毎の次に割り当てられる前記エクステントの中の最大サイズが大きくなった場合に警告メッセージを出力させることを特徴とする請求項1記載のデータベース容量監視装置。
- 前記データベースの前記表領域に配置されている前記セグメントに対して前記エクステントが新たに割り当てられたことを検知するエクステント割り当て検知手段を具備し、
該エクステント割り当て検知手段により前記データベースの前記表領域に配置されている前記セグメントに対して前記エクステントが新たに割り当てられたことが検知されたときに前記空き容量算出手段と前記エクステントサイズ抽出手段とを起動させることを特徴とする請求項1又は2記載のデータベース容量監視装置。 - 前記データベースの前記表領域が複数ある場合には、前記空き容量算出手段は、新たに前記エクステントが割り当てられた前記セグメントの配置されている前記データベースの前記表領域のみの連続した前記空き容量の最大サイズを算出させることを特徴とする請求項1乃至3のいずれかに記載のデータベース容量監視装置。
- 前記エクステントサイズ抽出手段により抽出された前記データベースの前記表領域に配置されている前記セグメント毎の次に割り当てられる前記エクステントの中の最大サイズを記憶するエクステントサイズ記憶手段を具備し、
前記データベースの前記表領域に新たな前記セグメントが作成されるまでは、前記エクステントサイズ抽出手段を起動させず、前記容量比較手段において前記空き容量算出手段により算出された前記データベースの前記表領域の連続した前記空き容量の最大サイズと前記エクステントサイズ記憶手段に記憶された前記データベースの前記表領域に配置されている前記セグメント毎の次に割り当てられる前記エクステントの中の最大サイズとを比較させることを特徴とする請求項1乃至4のいずれかに記載のデータベース容量監視装置。 - データベースの表領域に設定されている記憶容量の空き容量を監視するデータベース容量監視方法であって、
前記データベースの前記表領域の連続した前記空き容量の最大サイズを算出し、
前記データベースの前記表領域に配置されているセグメント毎の次に割り当てられるエクステントの中の最大サイズを抽出し、
前記算出した前記データベースの前記表領域の連続した前記空き容量の最大サイズと前記抽出した前記データベースの前記表領域に配置されている前記セグメント毎の次に割り当てられる前記エクステントの中の最大サイズとを比較し、
前記データベースの前記表領域の連続した前記空き容量の最大サイズと前記データベースの前記表領域に配置されている前記セグメント毎の次に割り当てられる前記エクステントの中の最大サイズとの比較結果を出力することを特徴とするデータベース容量監視方法。 - 前記データベースの前記表領域の連続した前記空き容量の最大サイズよりも前記データベースの前記表領域に配置されている前記セグメント毎の次に割り当てられる前記エクステントの中の最大サイズが大きくなった場合に警告メッセージを出力することを特徴とする請求項6記載のデータベース容量監視方法。
- 前記データベースの前記表領域に配置されている前記セグメントに対して前記エクステントが新たに割り当てられたことを検知し、
該検知により前記データベースの前記表領域に配置されている前記セグメントに対して前記エクステントが新たに割り当てられたことを検知したときに、前記データベースの前記表領域の連続した前記空き容量の最大サイズの算出と前記データベースの前記表領域に配置されている前記セグメント毎の次に割り当てられる前記エクステントの中の最大サイズの抽出とを実行することを特徴とする請求項6又は7記載のデータベース容量監視方法。 - 前記データベースの前記表領域が複数ある場合に、新たに前記エクステントが割り当てられた前記セグメントの配置されている前記データベースの前記表領域のみの連続した前記空き容量の最大サイズを算出することを特徴とする請求項6乃至8のいずれかに記載のデータベース容量監視方法。
- 前記抽出した前記データベースの前記表領域に配置されている前記セグメント毎の次に割り当てられる前記エクステントサイズの中の最大サイズを記憶し、
前記データベースの前記表領域に新たな前記セグメントが作成されるまでは、前記データベースの前記表領域に配置されているセグメント毎の次に割り当てられるエクステントの中の最大サイズの抽出を実行しないで、前記算出した前記データベースの前記表領域の連続した前記空き容量の最大サイズと前記記憶した前記データベースの前記表領域に配置されている前記セグメント毎の次に割り当てられる前記エクステントサイズの中の最大サイズとを比較することを特徴とする請求項6乃至9のいずれかに記載のデータベース容量監視方法。 - 請求項6乃至10のいずれかに記載のデータベース容量監視方法を実行可能なプログラムが記憶されている記憶媒体。
Priority Applications (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
JP36381499A JP3620385B2 (ja) | 1999-12-22 | 1999-12-22 | データベース容量監視装置およびデータベース容量監視方法 |
Applications Claiming Priority (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
JP36381499A JP3620385B2 (ja) | 1999-12-22 | 1999-12-22 | データベース容量監視装置およびデータベース容量監視方法 |
Publications (2)
Publication Number | Publication Date |
---|---|
JP2001175513A JP2001175513A (ja) | 2001-06-29 |
JP3620385B2 true JP3620385B2 (ja) | 2005-02-16 |
Family
ID=18480263
Family Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
JP36381499A Expired - Fee Related JP3620385B2 (ja) | 1999-12-22 | 1999-12-22 | データベース容量監視装置およびデータベース容量監視方法 |
Country Status (1)
Country | Link |
---|---|
JP (1) | JP3620385B2 (ja) |
Families Citing this family (1)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
WO2018069998A1 (ja) | 2016-10-12 | 2018-04-19 | 富士通株式会社 | 処理単位サイズ算出プログラム、処理単位サイズ算出方法及び処理単位サイズ算出装置 |
Family Cites Families (2)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
JPH0276042A (ja) * | 1988-09-13 | 1990-03-15 | Nec Corp | ファイル管理方式 |
JPH06231015A (ja) * | 1993-02-06 | 1994-08-19 | Fuji Xerox Co Ltd | データベースシステム領域拡張装置 |
-
1999
- 1999-12-22 JP JP36381499A patent/JP3620385B2/ja not_active Expired - Fee Related
Also Published As
Publication number | Publication date |
---|---|
JP2001175513A (ja) | 2001-06-29 |
Similar Documents
Publication | Publication Date | Title |
---|---|---|
CN108845910B (zh) | 大规模微服务系统的监控方法、装置及存储介质 | |
CN102308559B (zh) | 一种用于集群计算机系统的投票仲裁方法及装置 | |
CN108334396B (zh) | 一种数据处理方法和装置、资源组的创建方法和装置 | |
CN105095001A (zh) | 分布式环境下虚拟机异常恢复方法 | |
CN102982087A (zh) | 一种检测数据库数据一致性的方法、装置及数据库系统 | |
CN109407976B (zh) | 一种分布式存储方法及分布式存储装置 | |
CN108776579A (zh) | 一种分布式存储集群扩容方法、装置、设备及存储介质 | |
CN109445927A (zh) | 一种存储集群的任务管理方法及装置 | |
CN105302697A (zh) | 一种密集数据模型数据库的运行状态监控方法及系统 | |
CN104980515A (zh) | 一种云存储系统中消息分发处理方法和装置 | |
CN110674149B (zh) | 业务数据处理方法、装置、计算机设备和存储介质 | |
JP3620385B2 (ja) | データベース容量監視装置およびデータベース容量監視方法 | |
CN101515242B (zh) | 一种查找改写内存的任务的方法和系统 | |
CN106708746B (zh) | 一种在线内存碎片整理方法和装置 | |
JPWO2010113212A1 (ja) | メモリリーク監視装置、及び方法 | |
CN102629231A (zh) | 一种检测任务堆栈的方法 | |
CN102650959A (zh) | 一种检测内存单元的方法及设备 | |
CN107729182B (zh) | 数据存储和访问的方法及装置 | |
CN105068891A (zh) | 一种修复eMMC文件的方法及终端 | |
CN106708657A (zh) | 一种元数据管理方法及装置、分布式文件系统 | |
CN108228828A (zh) | 数据表处理方法及装置 | |
CN103744742A (zh) | 一种内存坏块的修复方法 | |
CN108255710B (zh) | 一种脚本的异常检测方法及其终端 | |
CN115576737A (zh) | 异常检测方法、装置、电子设备及存储介质 | |
CN111628895B (zh) | 一种配置数据同步方法、装置、设备及可读存储介质 |
Legal Events
Date | Code | Title | Description |
---|---|---|---|
TRDD | Decision of grant or rejection written | ||
A01 | Written decision to grant a patent or to grant a registration (utility model) |
Free format text: JAPANESE INTERMEDIATE CODE: A01 Effective date: 20041026 |
|
A61 | First payment of annual fees (during grant procedure) |
Free format text: JAPANESE INTERMEDIATE CODE: A61 Effective date: 20041108 |
|
R150 | Certificate of patent or registration of utility model |
Free format text: JAPANESE INTERMEDIATE CODE: R150 |
|
FPAY | Renewal fee payment (event date is renewal date of database) |
Free format text: PAYMENT UNTIL: 20071126 Year of fee payment: 3 |
|
FPAY | Renewal fee payment (event date is renewal date of database) |
Free format text: PAYMENT UNTIL: 20081126 Year of fee payment: 4 |
|
LAPS | Cancellation because of no payment of annual fees |