Oracle DB 集成会收集 Oracle DB 指标和日志。这些指标通过查询相关的监控视图来收集。此集成会写入结构化跟踪日志。
如需详细了解 Oracle DB,请参阅 Oracle 数据库文档。
前提条件
如需收集 Oracle DB 遥测数据,您必须安装 Ops Agent 2.22.0 或更高版本。
此集成支持 Oracle DB 12.2 版、18c 版、19c 版和 21c 版。
配置 Oracle DB 实例
为了收集指标,监控用户需要对相关视图的 SELECT
访问权限。以下 SQL 脚本如果由具有足够权限(作为 SYSDBA 或 SYSOPER 连接到 Oracle DB 实例)的用户执行,则应创建一个监控用户并授予其相应权限。
-- Create the monitoring user "otel" CREATE USER otel IDENTIFIED BY; -- Grant the "otel" user the required permissions GRANT CONNECT TO otel; GRANT SELECT ON SYS.GV_$DATABASE to otel; GRANT SELECT ON SYS.GV_$INSTANCE to otel; GRANT SELECT ON SYS.GV_$PROCESS to otel; GRANT SELECT ON SYS.GV_$RESOURCE_LIMIT to otel; GRANT SELECT ON SYS.GV_$SYSMETRIC to otel; GRANT SELECT ON SYS.GV_$SYSSTAT to otel; GRANT SELECT ON SYS.GV_$SYSTEM_EVENT to otel; GRANT SELECT ON SYS.V_$RMAN_BACKUP_JOB_DETAILS to otel; GRANT SELECT ON SYS.V_$SORT_SEGMENT to otel; GRANT SELECT ON SYS.V_$TABLESPACE to otel; GRANT SELECT ON SYS.V_$TEMPFILE to otel; GRANT SELECT ON SYS.DBA_DATA_FILES to otel; GRANT SELECT ON SYS.DBA_FREE_SPACE to otel; GRANT SELECT ON SYS.DBA_TABLESPACE_USAGE_METRICS to otel; GRANT SELECT ON SYS.DBA_TABLESPACES to otel; GRANT SELECT ON SYS.GLOBAL_NAME to otel;
为 Oracle DB 配置 Ops Agent
按照配置 Ops Agent 指南,添加从 Oracle DB 实例收集遥测数据所需的元素并重启代理。
配置示例
以下命令会创建相关配置来收集和注入 Oracle DB 的遥测数据,并重启 Ops Agent。
配置日志收集
要从 Oracle DB 注入日志,您必须为 Oracle DB 生成的日志创建接收器,然后为新接收器创建流水线。
如需为 oracledb_audit
日志配置接收器,请指定以下字段:
字段 | 默认 | 说明 |
---|---|---|
exclude_paths |
[] |
要从 include_paths 匹配的集合中排除的文件系统路径模式列表。 |
include_paths |
要通过跟踪每个文件读取的文件系统路径列表。路径中可以使用通配符 (* )。 不能使用 oracle_home 字段提供。 |
|
oracle_home |
环境的 ORACLE_HOME 位置;如果提供,则会将 include_paths 设置为 $ORACLE_HOME/admin/*/adump/*.aud 。不能使用 include_paths 字段提供。 |
|
record_log_file_path |
false |
如果设置为 true ,则从中获取日志记录的特定文件的路径将作为 agent.googleapis.com/log_file_path 标签的值显示在输出日志条目中。使用通配符时,系统只会记录从中获取记录的文件的路径。 |
type |
该值必须为 oracledb_audit 。 |
|
wildcard_refresh_interval |
60s |
include_paths 中通配符文件路径的刷新间隔。指定为 time.ParseDuration 可解析的时长,例如 30s 或 2m 。该属性在高日志记录吞吐量下可能很有用,因为日志文件的轮替速度快于默认时间间隔。 |
如需为 oracledb_alert
日志配置接收器,请指定以下字段:
字段 | 默认 | 说明 |
---|---|---|
exclude_paths |
[] |
要从 include_paths 匹配的集合中排除的文件系统路径模式列表。 |
include_paths |
要通过跟踪每个文件读取的文件系统路径列表。路径中可以使用通配符 (* )。 不能使用 oracle_home 字段提供。 |
|
oracle_home |
环境的 ORACLE_HOME 位置,如果提供,则会将 include_paths 设置为 $ORACLE_HOME/diag/rdbms/*/*/trace/alert_*.log 。不能使用 include_paths 字段提供。 |
|
record_log_file_path |
false |
如果设置为 true ,则从中获取日志记录的特定文件的路径将作为 agent.googleapis.com/log_file_path 标签的值显示在输出日志条目中。使用通配符时,系统只会记录从中获取记录的文件的路径。 |
type |
该值必须为 oracledb_alert 。 |
|
wildcard_refresh_interval |
60s |
include_paths 中通配符文件路径的刷新间隔。指定为 time.ParseDuration 可解析的时长,例如 30s 或 2m 。该属性在高日志记录吞吐量下可能很有用,因为日志文件的轮替速度快于默认时间间隔。 |
记录的内容
logName
派生自配置中指定的接收器 ID。LogEntry
中的详细字段如下所示。
oracledb_alert
日志包含 LogEntry
中的以下字段:
字段 | 类型 | 说明 |
---|---|---|
jsonPayload.message |
字符串 | 日志消息 |
severity |
字符串 (LogSeverity ) |
日志条目级别(已转换) |
oracledb_audit
日志包含 LogEntry
中的以下字段:
字段 | 类型 | 说明 |
---|---|---|
jsonPayload.action |
字符串 | 审核日志中所记录的操作 |
jsonPayload.action_number |
数字 | 用于标识所记录操作类型的数字 |
jsonPayload.client_terminal |
字符串 | 发起操作的客户端终端的标识符 |
jsonPayload.client_user |
字符串 | 所审核操作的客户端用户 |
jsonPayload.database_user |
字符串 | 所审核操作的数据库用户 |
jsonPayload.dbid |
数字 | 数据库标识符 |
jsonPayload.length |
数字 | 表示所记录操作的字符串的长度 |
jsonPayload.privilege |
字符串 | 据以执行操作的数据库特权 |
jsonPayload.sessionid |
数字 | 会话标识符 |
jsonPayload.status |
字符串 | 操作的状态 |
jsonPayload.user_host |
字符串 | 发起审核操作的主机 |
severity |
字符串 (LogSeverity ) |
日志条目级别(已转换) |
配置指标收集
如需从 Oracle DB 注入指标,您必须为 Oracle DB 生成的指标创建接收器,然后为新的接收器创建流水线。
此接收器不支持在配置中使用多个实例,例如,监控多个端点。所有这些实例都会写入相同的时序,并且 Cloud Monitoring 无法区分它们。
如需为 oracledb
指标配置接收器,请指定以下字段:
字段 | 默认 | 说明 |
---|---|---|
collection_interval |
60s |
时长值,例如 30s 或 5m 。 |
endpoint |
localhost:1521 |
用于连接到 Oracle DB 实例的端点。此字段支持 host:port 或 unix 套接字路径。 |
insecure |
true |
设置是否使用安全 TLS 连接。如果设置为 false ,则启用 TLS。 |
insecure_skip_verify |
false |
设置是否跳过证书验证。如果 insecure 设置为 true ,则不使用 insecure_skip_verify 值。 |
password |
用于连接到实例的密码。 | |
service_name |
要监控的 Oracle 数据库服务名称。根据需要使用此字段或 sid 字段。 |
|
sid |
要监控的 Oracle 数据库的 SID。根据需要使用此字段或 service_name 字段。 |
|
type |
该值必须为 oracledb 。 |
|
username |
用于连接到实例的用户名。 | |
wallet |
包含 Oracle 钱包的目录路径,可选择用于身份验证和保护连接。 |
监控的内容
下表提供了 Ops Agent 从 Oracle DB 实例收集的指标列表。
指标类型 | |
---|---|
种类、类型 受监控的资源 |
标签 |
workload.googleapis.com/oracle.backup.latest
|
|
CUMULATIVE 、INT64 gce_instance |
database_id
db_system
global_name
|
workload.googleapis.com/oracle.buffer.cache.ratio
|
|
GAUGE 、DOUBLE gce_instance |
database_id
db_system
global_name
instance_id
|
workload.googleapis.com/oracle.cursor.count
|
|
CUMULATIVE 、INT64 gce_instance |
database_id
db_system
global_name
instance_id
|
workload.googleapis.com/oracle.cursor.current
|
|
GAUGE 、INT64 gce_instance |
database_id
db_system
global_name
instance_id
|
workload.googleapis.com/oracle.disk.operation.count
|
|
CUMULATIVE 、INT64 gce_instance |
database_id
db_system
direction
global_name
instance_id
|
workload.googleapis.com/oracle.disk.operation.size
|
|
CUMULATIVE 、INT64 gce_instance |
database_id
db_system
direction
global_name
instance_id
|
workload.googleapis.com/oracle.logon.count
|
|
CUMULATIVE 、INT64 gce_instance |
database_id
db_system
global_name
instance_id
|
workload.googleapis.com/oracle.logon.current
|
|
GAUGE 、INT64 gce_instance |
database_id
db_system
global_name
instance_id
|
workload.googleapis.com/oracle.network.data
|
|
CUMULATIVE 、INT64 gce_instance |
database_id
db_system
direction
global_name
instance_id
target
|
workload.googleapis.com/oracle.process.count
|
|
GAUGE 、INT64 gce_instance |
database_id
db_system
global_name
instance_id
|
workload.googleapis.com/oracle.process.limit
|
|
GAUGE 、INT64 gce_instance |
database_id
db_system
global_name
instance_id
|
workload.googleapis.com/oracle.process.pga_memory.size
|
|
GAUGE 、INT64 gce_instance |
database_id
db_system
global_name
instance_id
program
state
|
workload.googleapis.com/oracle.row.cache.ratio
|
|
GAUGE 、DOUBLE gce_instance |
database_id
db_system
global_name
instance_id
|
workload.googleapis.com/oracle.service.response_time
|
|
GAUGE 、DOUBLE gce_instance |
database_id
db_system
global_name
instance_id
|
workload.googleapis.com/oracle.session.count
|
|
GAUGE 、INT64 gce_instance |
database_id
db_system
global_name
instance_id
|
workload.googleapis.com/oracle.session.limit
|
|
GAUGE 、INT64 gce_instance |
database_id
db_system
global_name
instance_id
|
workload.googleapis.com/oracle.sort.count
|
|
CUMULATIVE 、INT64 gce_instance |
database_id
db_system
global_name
instance_id
type
|
workload.googleapis.com/oracle.sort.row.count
|
|
CUMULATIVE 、INT64 gce_instance |
database_id
db_system
global_name
instance_id
|
workload.googleapis.com/oracle.tablespace.count
|
|
GAUGE 、INT64 gce_instance |
contents
database_id
db_system
global_name
status
|
workload.googleapis.com/oracle.tablespace.size
|
|
GAUGE 、INT64 gce_instance |
contents
database_id
db_system
global_name
state
tablespace_name
|
workload.googleapis.com/oracle.user.calls
|
|
CUMULATIVE 、INT64 gce_instance |
database_id
db_system
global_name
instance_id
|
workload.googleapis.com/oracle.user.commits
|
|
CUMULATIVE 、INT64 gce_instance |
database_id
db_system
global_name
instance_id
|
workload.googleapis.com/oracle.user.rollbacks
|
|
CUMULATIVE 、INT64 gce_instance |
database_id
db_system
global_name
instance_id
|
workload.googleapis.com/oracle.wait.count
|
|
CUMULATIVE 、INT64 gce_instance |
database_id
db_system
global_name
instance_id
type
wait_class
|
workload.googleapis.com/oracle.wait.time
|
|
CUMULATIVE 、INT64 gce_instance |
database_id
db_system
global_name
instance_id
type
wait_class
|
workload.googleapis.com/oracle.wait.timeouts
|
|
CUMULATIVE 、INT64 gce_instance |
database_id
db_system
global_name
instance_id
type
wait_class
|
验证配置
本部分介绍如何验证您是否正确配置了 Oracle DB 接收器。Ops Agent 可能需要一两分钟才会开始收集遥测数据。
如需验证 Oracle DB 日志是否已发送到 Cloud Logging,请执行以下操作:
-
在 Google Cloud 控制台中,转到 Logs Explorer 页面。
如果您使用搜索栏查找此页面,请选择子标题为 Logging 的结果。
- 在编辑器中输入以下查询,然后点击运行查询:
resource.type="gce_instance" (log_id("oracledb_alert") OR log_id("oracledb_audit"))
如需验证 Oracle DB 指标是否已发送到 Cloud Monitoring,请执行以下操作:
-
在 Google Cloud 控制台中,转到 leaderboard Metrics Explorer 页面:
如果您使用搜索栏查找此页面,请选择子标题为监控的结果。
- 在查询构建器窗格的工具栏中,选择名为 code MQL 或 code MQL 的按钮。
- 验证已在MQL切换开关中选择 MQL。语言切换开关位于同一工具栏中,用于设置查询的格式。
- 在编辑器中输入以下查询,然后点击运行查询:
fetch gce_instance | metric 'workload.googleapis.com/oracle.logon.count' | every 1m
查看信息中心
如需查看 Oracle DB 指标,您必须配置一个图表或信息中心。 Oracle DB 集成服务可为您提供一个或多个信息中心。在您配置集成并且 Ops Agent 开始收集指标数据后,所有信息中心都会自动安装。
您还可以在不安装集成的情况下查看信息中心的静态预览。
如需查看已安装的信息中心,请执行以下操作:
-
在 Google Cloud 控制台中,转到 信息中心页面:
如果您使用搜索栏查找此页面,请选择子标题为监控的结果。
- 选择信息中心列表标签页,然后选择集成类别。
- 点击您要查看的信息中心的名称。
如果您已配置集成,但尚未安装信息中心,请检查 Ops Agent 是否正在运行。如果信息中心内没有图表的指标数据,则信息中心的安装将失败。Ops Agent 开始收集指标后,系统会为您安装信息中心。
如需查看信息中心的静态预览,请执行以下操作:
-
在 Google Cloud 控制台中,转到 集成页面:
如果您使用搜索栏查找此页面,请选择子标题为监控的结果。
- 点击 Compute Engine 部署平台过滤条件。
- 找到 Oracle DB 条目,然后点击查看详细信息。
- 选择信息中心标签页以查看静态预览。如果信息中心已安装,您可以通过点击查看信息中心来转到信息中心。
如需详细了解 Cloud Monitoring 中的信息中心,请参阅信息中心和图表。
如需详细了解如何使用集成页面,请参阅管理集成。
安装提醒政策
提醒政策会指示 Cloud Monitoring 在满足指定条件时通知您。 Oracle DB 集成包含一项或多项提醒政策供您使用。您可以从 Monitoring 中的集成页面查看和安装这些提醒政策。
如需查看可用提醒政策的说明并安装它们,请执行以下操作:
-
在 Google Cloud 控制台中,转到 集成页面:
如果您使用搜索栏查找此页面,请选择子标题为监控的结果。
- 找到 Oracle DB 条目,然后点击查看详细信息。
- 选择提醒标签页。此标签页提供可用提醒政策的说明,并提供一个安装政策的界面。
- 安装提醒政策。提醒政策需要知道将提醒触发的通知发送到何处,因此它们需要您提供信息才能进行安装。如需安装提醒政策,请执行以下操作:
- 从可用提醒政策列表中,选择您要安装的提醒政策。
在配置通知部分中,选择一个或多个通知渠道。您可以选择禁止使用通知渠道,但如果您这样做,则您的提醒政策将以静默方式触发。您可以在 Monitoring 中查看其状态,但不会收到通知。
如需详细了解通知渠道,请参阅管理通知渠道。
- 点击创建政策。
如需详细了解 Cloud Monitoring 中的提醒政策,请参阅提醒简介。
如需详细了解如何使用集成页面,请参阅管理集成。
后续步骤
如需查看如何使用 Ansible 安装 Ops Agent、配置第三方应用和安装示例信息中心的演示,请参阅安装 Ops Agent 以排查第三方应用的问题视频。