主机设置
编辑主机设置
编辑某些驱动程序需要额外的配置才能工作。在此处查找这些驱动程序的说明。
Oracle 数据库连接先决条件
编辑要连接到 Oracle 数据库,应设置 ORACLE_SID
、ORACLE_BASE
和 ORACLE_HOME
环境变量。
例如:假设按照此链接手动使用 RPM 安装 Oracle Database 21c,则应按如下方式设置环境变量
export ORACLE_BASE=/opt/oracle/oradata export ORACLE_HOME=/opt/oracle/product/21c/dbhome_1
此外,将 ORACLE_HOME/bin
添加到 PATH
环境变量。
Oracle 即时客户端安装
编辑Oracle 即时客户端支持开发和部署连接到 Oracle 数据库的应用程序。即时客户端库提供必要的网络连接和高级数据功能,以充分利用 Oracle 数据库。如果您有一个带有预安装这些库的 OCI Oracle 服务器,则不需要单独的客户端安装。
OCI 库安装一些客户端共享库,这些库必须在安装 Metricbeat 的计算机上引用。请按照此链接进行 OCI 即时客户端设置。OCI 即时客户端可使用 Oracle Universal Installer、RPM 文件或 ZIP 文件获得。下载链接可以在此处找到。
启用 Oracle 监听器
编辑Oracle 监听器是在数据库主机上运行并接收来自 Oracle 客户端请求的服务。请确保监听器正在运行。要检查监听器是否正在运行,请运行
lsnrctl STATUS
如果监听器未运行,请使用该命令启动
lsnrctl START
然后,可以启动 Metricbeat。
Oracle 的主机配置
编辑支持以下类型的主机配置
-
旧式的 Oracle 连接字符串,用于向后兼容
-
hosts: ["user/[email protected]:1521/ORCLPDB1.localdomain"]
-
hosts: ["user/[email protected]:1521/ORCLPDB1.localdomain as sysdba"]
-
-
作为 URL 的 DSN 配置
-
hosts: ["oracle://user:[email protected]:1521/ORCLPDB1.localdomain?sysdba=1"]
-
-
作为 logfmt 编码参数列表的 DSN 配置
-
hosts: ['user="user" password="pass" connectString="0.0.0.0:1521/ORCLPDB1.localdomain"']
-
hosts: ['user="user" password="password" connectString="host:port/service_name" sysdba=true']
-
DSN 主机配置是推荐的配置类型,因为它支持在密码中使用特殊字符。
在 URL 中,任何特殊字符都应进行 URL 编码。
在 logfmt 编码的 DSN 格式中,如果密码包含反斜杠字符 (\
),则必须使用另一个反斜杠进行转义。例如,如果密码是 my\_password
,则必须写成 my\\_password
。
连接到数据库的用户名和密码可以作为 sql.yml
的 username
和 password
键的值提供。
- module: sql metricsets: - query period: 10s driver: "oracle" enabled: true hosts: ['user="" password="" connectString="0.0.0.0:1521/ORCLCDB.localdomain" sysdba=true'] username: sys password: password sql_queries: - query: SELECT METRIC_NAME, VALUE FROM V$SYSMETRIC WHERE GROUP_ID = 2 and METRIC_NAME LIKE '%' response_format: variables
SQL 模块支持 模块 中描述的标准配置选项。这是一个示例配置
metricbeat.modules: - module: sql metricsets: - query period: 10s hosts: ["user=myuser password=mypassword dbname=mydb sslmode=disable"] driver: "postgres" sql_query: "select now()" sql_response_format: table
以下指标集可用