Autonomous DatabaseでのOracle Javaの使用

Autonomous DatabaseはOracle JVMをサポートしています。Oracle JVMは、Pure Javaアプリケーションを実行する標準的なJava互換環境です。

Oracle JVMは、標準のJLSおよびJVM仕様と互換性があります。標準Javaバイナリ形式および標準Java APIをサポートします。また、Oracle Databaseは、実行時の動的クラス・ロードなど、標準のJava言語セマンティクスに準拠しています。

Oracle Javaの詳細は、『Oracle DatabaseにおけるJavaの使用について』を参照してください。

Oracle Javaの有効化

DBMS_CLOUD_ADMIN.ENABLE_FEATUREを使用して、Autonomous DatabaseでOracle Javaを有効にします。

  1. DBMS_CLOUD_ADMIN.ENABLE_FEATUREを実行します。
    BEGIN
       DBMS_CLOUD_ADMIN.ENABLE_FEATURE(
           feature_name => 'JAVAVM' );
    END;
    /

    これにより、Oracle JavaをAutonomous Databaseインスタンスにインストールするリクエストが開始されます。

    詳細は、ENABLE_FEATUREプロシージャを参照してください。

  2. Autonomous Databaseインスタンスを再起動します。

    詳細は、Autonomous Databaseの再起動を参照してください。

Autonomous Databaseインスタンスを再起動すると、データベースの起動後しばらくJavaインストールが続行されます。Oracle JVMが有効でインストールが完了していることを確認するには、Oracle Javaバージョンの確認を参照してください。

Oracle Javaバージョンの確認

Autonomous DatabaseインスタンスのOracle Javaに関する情報で、Oracle Javaバージョンおよびコンポーネント・レジストリを確認できます。

  1. Oracle Javaのコンポーネント・レジストリ・ステータスおよびバージョンを確認します。
    SELECT status, version FROM DBA_REGISTRY
       WHERE comp_id = 'JAVAVM';
    
    STATUS VERSION
    ------ ---------- 
    VALID  19.0.0.0.0 

    Oracle Javaがインストールされていない場合、この問合せでは行が表示されません。

    Oracle Javaがロードされている場合、この問合せにはステータスLOADINGが表示されます。次に例を示します。

    STATUS  VERSION 
    ------- ------- 
    LOADING null    
  2. Oracle Java JDKバージョンを確認します。
    SELECT dbms_java.get_jdk_version FROM DUAL;
    
    GET_JDK_VERSION 
    --------------- 
    1.8.0_411       

    Oracle Javaがインストールされていない場合、この問合せではエラー・メッセージが表示されます。

Autonomous DatabaseへのJavaクラスおよびJARファイルのロード

クライアント側のloadjavaオプションを使用して、Autonomous Databaseインスタンス上のOracle JVMにJavaクラスおよびJARファイルをロードできます。

クライアント側の loadjavaオプションは、次のようにサポートされています。

  1. JDKによってJARファイルが開きます。
  2. クライアント側は、Autonomous Databaseとの通信チャネルを開きます。
  3. Javaコードは、ロードのためにAutonomous Databaseで実行されているOracle JVMに送信されます。

このプロセスは、SQLコードから動的なJavaストアド・プロシージャを作成するのと似ていますが、ファイル・アクセスは発生しませんが、コードが作成されます。

次に注意してください:

  • ロードするJavaコードは、オペレーティング・システムまたはネットワーク・コールを起動できません。

  • プロシージャdbms_java.loadjavaへのコールであるサーバー側のloadjavaの使用はサポートされていません。プロシージャdbms_java.loadjavaは、Oracle JVMが実行されているデータベース・サーバーのファイル・システムにアクセスします。これはAutonomous Databaseでは許可されず、Javaアプリケーション内からのプロシージャdbms_java.loadjavaのコールはサポートされていません。

Autonomous DatabaseでのOracle Javaに関するノート

Autonomous DatabaseでOracle Javaを使用するためのノートを提供します。

  • Oracle JavaをAutonomous Databaseインスタンスで有効にした後は、無効にできません。

  • Autonomous Databaseは、通常のAutonomous Databaseメンテナンス・ウィンドウ中に、必要に応じてOracle Javaのパッチ適用を実行します。

    Oracle Javaのパッチ適用中は、Javaを使用できず、次のようなエラーが発生しました:

    ERROR at line 1:
    ORA-29548: Java system class reported: release of Java system classes in the
    database (19.0.0.0.220118 1.8) does not match that of the oracle executable
    (19.0.0.0.220419 1.8).

    メンテナンス・ウィンドウでは、Javaのパッチ適用フェーズがアクティブなときにJavaセッション・コールに対するレスポンスがなくなるか、ORA-29548エラーが表示されます。メンテナンス期間の完了後、Javaの使用がリストアされます。

    イベントNewMaintenanceScheduleおよびScheduledMaintenanceWarningを使用して、Oracle Javaパッチ適用を通知できます。詳細は、Autonomous Databaseの情報イベントを参照してください。

    詳細は、スケジュールされたメンテナンスおよびパッチ適用についてを参照してください。