Oracle Java 虚拟机 - Amazon Relational Database Service
Amazon Web Services 文档中描述的 Amazon Web Services 服务或功能可能因区域而异。要查看适用于中国区域的差异,请参阅中国的 Amazon Web Services 服务入门

Oracle Java 虚拟机

Amazon RDS 通过使用 JVM 选项来支持 Oracle Java 虚拟机 (JVM)。Oracle Java 提供了 SQL 架构和函数以在 Oracle 数据库中利用 Oracle Java 功能。有关更多信息,请参阅 Oracle 文档中的 Oracle Database 中的 Java 简介

您可以将 Oracle JVM 与以下 Oracle Database 版本一起使用:

  • Oracle Database 19c (19.0.0.0),所有版本

  • Oracle Database 18c (18.0.0.0),所有版本

  • Oracle Database 12c 第 2 版 (12.2),所有版本

  • Oracle Database 12c 第 1 版 (12.1),版本 12.1.0.2.v13 或更高版本

Amazon RDS 中的 Java 实施拥有一组有限的权限。主用户被授予 RDS_JAVA_ADMIN 角色,进而授予 JAVA_ADMIN 角色所获权限的一个子集。若要列出授予 RDS_JAVA_ADMIN 角色的权限,请在您的数据库实例上运行以下查询:

SELECT * FROM dba_java_policy WHERE grantee IN ('RDS_JAVA_ADMIN', 'PUBLIC') AND enabled = 'ENABLED' ORDER BY type_name, name, grantee;

Oracle JVM 的先决条件

以下是使用 Oracle Java 的先决条件:

  • 数据库实例必须在 Virtual Private Cloud (VPC) 内。有关更多信息,请参阅 确定您使用的是 EC2-VPC 还是 EC2-Classic 平台

  • 您的数据库实例必须属于足够大的类。db.t3.micro 或 db.t3.small 数据库实例类别不支持 Oracle Java。有关更多信息,请参阅 数据库实例类

  • 数据库实例必须已启用自动次要版本升级。该选项允许数据库实例在次要数据库引擎版本升级可用时自动接收这些升级。Amazon RDS 使用该选项将数据库实例更新为最新的 Oracle 补丁集更新 (PSU) 或版本更新 (RU)。有关更多信息,请参阅 修改 Amazon RDS 数据库实例

Oracle JVM 的最佳实践

以下是使用 Oracle Java 的最佳实践:

  • 为了实现最高安全性,可将 JVM 选项与安全套接字层 (SSL) 结合使用。有关更多信息,请参阅Oracle 安全套接字层

  • 配置您的数据库实例以限制网络访问。有关更多信息,请参阅在 VPC 中访问数据库实例的方案在 VPC 中使用数据库实例

  • 如果您满足以下条件,请更新 HTTPS 端点的配置以支持 TLSv1.2:

    • 您可以使用 Oracle Java 虚拟机 (JVM) 通过 TLSv1 或 TLSv1.1 协议连接 HTTPS 端点。

    • 您的端点不支持 TLSv1.2 协议。

    • 您尚未将 2021 年 4 月版本更新应用于 Oracle 数据库。

    通过更新端点配置,您可以确保 JVM 与 HTTPS 端点的连接将继续有效。有关 Oracle JRE 和 JDK 中 TLS 更改的更多信息,请参阅 Oracle JRE 和 JDK 加密路线图

添加 Oracle JVM 选项

下面是将 JVM 选项添加到数据库实例的一般过程:

  1. 创建新的选项组,或者复制或修改现有选项组。

  2. 向选项组添加选项。

  3. 将选项组与数据库实例相关联。

添加 JVM 选项后,将出现短暂中断。在添加 选项后,您无需重新启动数据库实例。在选项组处于活动状态后,Oracle Java 将立即可用。

注意

在该中断期间,将短暂禁用密码验证功能。您还可能会在中断期间看到与密码验证功能相关的事件。在 Oracle 数据库实例变得可用之前,将再次启用密码验证功能。

将 JVM 选项添加到数据库实例

  1. 确定您要使用的选项组。您可以创建新的选项组,或使用现有选项组。如果您想使用现有选项组,请跳到下一步。或者,通过以下设置创建自定义数据库选项组:

    • 对于引擎,选择数据库实例使用的数据库引擎(oracle-eeoracle-seoracle-se1oracle-se2)。

    • 对于主引擎版本,选择数据库实例的版本。

    有关更多信息,请参阅 创建选项组

  2. JVM 选项添加到该选项组。有关添加选项的更多信息,请参阅 将选项添加到选项组

  3. 将选项组应用到新的或现有的数据库实例:

  4. 为用户授予所需的权限。

    默认情况下,Amazon RDS 主用户具有使用 JVM 选项的权限。如果其他用户需要具有这些权限,请在 SQL 客户端中以主用户身份连接到数据库实例,并为用户授予这些权限。

    以下示例为 test_proc 用户授予使用 JVM 选项的权限。

    create user test_proc identified by password; CALL dbms_java.grant_permission('TEST_PROC', 'oracle.aurora.security.JServerPermission', 'LoadClassInPackage.*', '');

    在为用户授予这些权限后,以下查询将返回输出。

    select * from dba_java_policy where grantee='TEST_PROC';
    注意

    Oracle 用户名区分大小写,通常全部为大写字符。

删除 Oracle JVM 选项

您可以从数据库实例中删除 JVM 选项。删除该选项后,将出现短暂中断。删除 JVM 选项后,您无需重新启动数据库实例。

警告

如果数据库实例使用的是在选项中启用的数据类型,则删除 JVM 选项会导致数据丢失。请先备份数据,然后再继续。有关更多信息,请参阅备份和还原 Amazon RDS 数据库实例

要从数据库实例中删除 JVM 选项,请执行下列操作之一:

  • JVM 选项所属的选项组中删除该选项。此更改会影响使用该选项组的所有数据库实例。有关更多信息,请参阅 从选项组中删除选项

  • 修改数据库实例并指定不包含 JVM 选项的另一个选项组。此更改会影响单个数据库实例。您可以指定默认 (空) 选项组,或指定其他自定义选项组。有关更多信息,请参阅修改 Amazon RDS 数据库实例