TOP比較データ> Oracleのプロセス構造

徹底比較!! Oracle & PostgreSQL

第2回:アーキテクチャ比較  プロセス構造の違い
著者:ミラクル・リナックス  高橋 強   2004/11/24
前のページ  1  2   
Oracleのプロセス構造

  次に、Oracleデータベースについて説明します。図2は、Oracleデータベースの基本的なプロセス構造を図にしたものです。PostgreSQLと比べるとかなり複雑ですが、基本的なアーキテクチャは同様に、クライアント・サーバ型です。

  PostgreSQLとの大きな違いは、作業の分担がプロセス毎になされている点でしょう。PostgreSQLは、postmasterとその分身postgresというプロセスがほとんどを一人で受け持ってしまいます。それに対してOracleでは、それぞれ異なる役割を持ったプロセスが複数存在し、分担して作業をこなします。PostgreSQLは統合型、Oracleは専門特化型といえるかも知れません。


図2. Oracleデータベースのプロセスとファイルの構造

  Oracleのサーバ上で稼動するプロセスの役割は

バックグラウンド・プロセス
データ・ファイルへの書き込みを担当するdbwrやログ・ファイルへの書き込みを行うlgwr、プロセスを監視するpmon,smonなどがあり、総称してバックグラウンド・プロセスと呼ばれます。

サーバ・プロセス
ユーザ・プロセスと通信し、実際にSQLを実行します。

ユーザ・プロセス
SQL*Plusなどのクライアント・アプリケーション

といったところが代表的なものです。


起動してからの動作

  では、Oracleの起動からユーザ・アプリケーションが処理を実行するまでを見てみましょう。最初にバックグラウンド・プロセス(群)の起動とSGA(システム・グローバル・エリア)と呼ばれるメモリ領域を共有メモリ上に確保します。この二つを合わせて、Oracleでは「インスタンス」と呼びます。

  PostgreSQLでpostmasterを起動する際は pg_ctl というOS上のコマンドを実行しますが、Oracleの場合は SQL*Plusを起動して、その中でstartup コマンドを実行してインスタンス(バックグラウンド・プロセス+SGA)を起動します。この辺りの起動方法の違いもアーキテクチャの違いを感じる部分です。

  インスタンスを起動した時点で、ローカルサーバ内で起動されるクライアント・プロセスからは接続可能な状態になりますが、ネットワーク経由の接続の為には、リスナー(tnslsnr)と呼ばれる別のプロセスを起動する必要があります。tnslsnrプロセスは起動されると、TCP/IPポート(デフォルトでは1521)をListenし、クライアントからの接続要求を待ちます。

  ユーザがクライアント側でSQL*Plusなどを起動して、リスナーに対して接続要求を発行します。リスナーはインスタンスに対して要求を通知して、インスタンス側で認証した後、新たにサーバ・プロセスを生成します。リスナーは生成されたサーバ・プロセスへの情報をクライアント側へ返し、その後はクライアント・プロセスとサーバ・プロセスが直接通信し、処理を実行できます。

  この場合、クライアント・プロセスとサーバ・プロセスとは一対一で対応しています。(専用サーバ構成といいます。) Oracleでは同時接続ユーザ数が多い場合、共有サーバ構成を使用することでサーバ側で起動するプロセス数を抑える事もできます。ひとつのサーバ・プロセスを複数のクライアント・プロセスが共有して使用する事で、プロセス数とメモリ空間を節約できる大規模データベースを構成する為の機能です。

  クライアントとサーバ間の通信にはOracle Netというプログラムを使用します。
(SQL*NetとかNet8と呼ばれていた時期もあります。)


プロセス構造の違い

表1. PostgreSQLとOracleの仕組み対応表(プロセス編)

役割 PostgreSQL Oracle
ユーザ側(アプリケーション)プロセス フロントエンド ユーザ・プロセス
サーバ側プロセス バックエンド バックグラウンド・プロセス+サーバ・プロセス+リスナー
接続要求処理用プロセス postmaster リスナー
ユーザ作業用プロセス postgres バックグラウンド・プロセス+サーバ・プロセス
データ用バッファ 共有メモリーバッファ システム・グローバル領域(SGA)
C/S間通信 libpqプロトコル Oracle Net(Net8,SQL*Net)

上記は、PostgreSQLをベースとして、対応するOracle側の用語を挙げた物で、両者が同一の処理しかしない訳ではありません。


前のページ  1  2   



著者プロフィール
ミラクル・リナックス株式会社  高橋 強
1993年某SIベンダへ入社後、Oracle、DB関連のコンサルティング、チューニング、社内案件の技術支援などを10年ほど担当。2004年ミラクル・リナックス株式会社へ入社。


INDEX
第2回:アーキテクチャ比較  プロセス構造の違い
  PostgreSQLのプロセス構造
Oracleのプロセス構造