百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 优雅编程 > 正文

Oracle数据库运维场景下,智能运维如何落地生根?

sinye56 2024-10-17 15:10 4 浏览 0 评论

从马车到汽车是为了提升运输效率,而随着时代的发展,如今我们又希望用自动驾驶把驾驶员从开车这项体力劳动中解放出来,增加运行效率,同时也可减少交通事故发生率,这也是企业对于智能运维的诉求。

从人工运维到自动化运维是为了减少人力成本,降低操作风险,提高运维效率,但自动化运维的本质依然是人与自动化工具相结合的运维模式,仍有局限性。为了持续地面向大规模、高复杂性的系统提供高质量的运维服务,智能运维(AIOps)应运而生。

本文,袋鼠云将跟大家分享智能运维大数据平台(一款开箱即用的运维监控平台)在Oracle数据库运维场景下的具体应用。

数据采集

使用平台第一步是数据接入。要做好Oracle的运维,需要哪些数据支撑?根据我们运维Oracle日常的经验总结,以下几类数据是特别重要的:

  • 实例和数据库基础信息
    包括实例的版本、Patch、启动时间、实例参数、主机基本配置信息。
  • 数据库健康检查
    检查数据库是否能正常连接,读写响应时间是否正常。
  • 实例基础性能数据
    包括业务的QPS、TPS,实例和主机的CPU使用率、内存使用率、连接数使用率,SQL解析情况,数据库的逻辑读、物理读,数据库锁等待状况,以及RAC集群间的通信状况。
  • Oracle等待事件
    采集Oracle内部等待事件的类型、等待次数和消耗时间。从等待事件可以判断实例运行的整体健康情况,定位实例瓶颈。
  • 数据库空间使用信息
    包括表空间文件占用空间、表空间使用空间、临时表空间使用情况、UNDO表空间使用情况。需要实时监控表空间使用情况,避免表空间占满引起故障。
  • 数据库Session信息
    Session信息记录了实例当前运行的SQL情况,记录了当前阻塞Session的具体信息,比较常见的如锁等待。通过Session信息,方便快速定位实例中的阻塞现象。
  • 数据库备份情况
    在数据库运维领域,备份重于泰山。每天都需要检查数据库的备份情况,包括备份是否成功,备份耗时,备份占用空间等。
  • DataGuard运行状况
    DataGuard是Oracle高可用最常用的方案之一。需要实时检测Oracle DataGuard的运行状况,包括日志传输是否正常,日志应用延迟。
  • 日志信息
    数据库的告警日志、TNS监听日志。从日志中可以发现数据库内部运行错误、异常的客户端连接信息等。

上述的数据采集,已经集成在产品中。用户只需要在数据库性能采集模块配置接入信息,就会自动采集这些数据。

数据接入之后,产品上会从几个方面来使用这些数据:

  • 仪表盘
    系统默认带了Oracle场景的通用仪表盘。用户也可以根据自己的使用习惯,通过SPL的方式配置自定义仪表盘。
  • 监控告警
    系统内置常见的监控告警。也可以通过SPL的方式配置自定义告警项。数据只要采集到了,就可以用于配置告警。
  • 智能巡检
    系统支持配置自定义巡检规则,按用户定义的时间间隔,定期进行数据库巡检。
  • 日志分析
    基于系统采集的Oracle告警日志、TNS监听日志,除了使用基本的日志搜索、监控告警,也可以配置一些日志分析的场景。

本文重点介绍仪表盘的使用。

Oracle仪表盘

仪表盘是数据可视化展现的基本形式,便于用户从直观上了解系统的整体运行状况。

3.1 Oracle实例总览

Oracle总览Dashboard主要包括这几个部分:
实例统计,包括实例总数,异常实例数,数据库数量,实例版本分布。通过这几个指标,能对接入系统中的实例有一个大体的了解。
TOP实例,包括繁忙率TOP实例,活跃会话数TOP实例。

通过这2个指标定位繁忙的实例。

  • 异常实例列表
    这个表格展示所有无法连接的实例,包括连接报错信息。
  • TOP性能趋势图
    选取数据库的核心指标,对整体实例的运行状况有一个整体的了解。选取的指标:DB Time使用率:体现实例整体繁忙程度DB CPU使用率:CPU资源的使用率。活动会话数:是否后SQL积压会话数使用率:Session资源使用率QPS/TPS:展现业务请求吞吐量

3.2 Oracle实例详情

该仪表盘用于展现单个实例的运行详细状况。仪表盘主要分如下几个部分。

  • 实例信息
    显示实例的基本信息,包括主机情况,实例运行状态,实例的版本,数据库的角色,读写模式等
  • 实例运行情况
    展现实例的核心运行指标。阻塞会话数/活跃会话数DB Time使用率实例当前会话数使用率CPU使用率趋势实例会话数趋势SQL执行量/SQL解析量实例逻辑读/物理读实例网络流量实例IO请求次数

3.3 Oracle实例空间总览

该仪表盘展现实例的空间使用情况。主要包括几个部分:

  • 实例总空间分布
    展现所有实例的空间分布情况。
  • 实例使用空间TOP
    展现空间使用率TOP实例的空间变化趋势。
  • 实例表空间相关信息
    展现所选实例的表空间数量、实例总空间以及空间同比和环比、UNDO空间和TEMP空间、闪回区空间使用情况。
  • 实例表空间使用率和占用空间排名。
  • 实例表空间使用率TOP趋势
  • 实例表空间列表
    展现实例所有表空间的空间使用情况。

3.4 Oracle阻塞会话

该仪表盘展现实例中阻塞会话的情况,仪表盘主要有几个部分组成。

  • TOP阻塞会话趋势图
    展现系统中所有实例的阻塞会话数变化趋势。如有阻塞会话,需要特别关注。
  • 实例等等事件分布图
    展现所选实例的阻塞会话的等待事件分布情况。
  • 阻塞源分析
    展现哪些Session引起了其它Session阻塞
  • 等待事件趋势
    实例等待事件趋势
  • 阻塞会话列表
    以表格的形式展现阻塞会话的详细信息,包括:Session ID会回登陆时机会回当前状态引起阻塞的会话ID阻塞对象ID等待事件等待时间登陆用户信息,包括用户名,登陆终端,应用程序名称。执行的SQL信息,包括SQL ID,SQL语句。

通过上面这些仪表盘,既能从总体上掌握所有实例的基本运行状况,也能在单个实例上进行深入的分析,细到具体执行的SQL。能从总体上把握所有数据库的空间使用趋势,也能看到单个表空间的数据使用情况。

总结

上面的案例,是智能运维大数据产品在Oracle数据库运维场景下的一个具体应用。
其实整个产品,完全不局限于数据库运维这个场景。

产品在数据采集和数据应用上,具有强大的扩展能力。

  • 自动巡检
    所有的指标,都可以配置成巡检项,系统支持自定义调度周期(小时粒度),定期巡检系统的运行状况,以钉钉消息或邮件的方式发送出来。
  • 全链路的监控
    上面只介绍了数据库的场景,其实系统支持整个链路上的数据采集、分析。目前系统支持的采集包括:物理设备信息采集(物理机CPU风扇、磁盘、温度、电源状态)网络设备(交换机、防火墙、无线AP)阿里云云产品数据采集,支持几十种云产品的数据集成。通用软件(Docker,Tomcat,消息中间件)WEB访问日志、防火墙日志、主机日志应用日志数据APM应用调用联路数据采集
  • 智能算法
    自动基线学习,无需配置告警,就能自动监测系统运行异常状况。

「智能运维大数据平台」

「智能运维大数据平台」是一款开箱即用的运维监控平台,通过特有的平台功能可以将企业的基础架构、应用程序、日志管理结合在一起,提供统一采集、统一存储、关联分析、统一监控企业业务保障能力,保障企业业务稳定高效运行,同时利用离线计算、实时计算、机器学习等技术,实现运维数据共享、数据开发和加工能力,让开发人员、运营团队和业务团队协同工作,构建和改进软件应用程序,并帮助企业了解业务和用户使用情况。被各大企业用于实现数字转型和云迁移,推动开发,运营和业务团队之间的协作,加快应用程序的上线时间,缩短解决问题的时间,了解用户行为和跟踪关键业务指标。

相关推荐

程序员:JDK的安装与配置(完整版)_jdk的安装方法

对于Java程序员来说,jdk是必不陌生的一个词。但怎么安装配置jdk,对新手来说确实头疼的一件事情。我这里以jdk10为例,详细的说明讲解了jdk的安装和配置,如果有不明白的小伙伴可以评论区留言哦下...

Linux中安装jdk并配置环境变量_linux jdk安装教程及环境变量配置

一、通过连接工具登录到Linux(我这里使用的Centos7.6版本)服务器连接工具有很多我就不一一介绍了今天使用比较常用的XShell工具登录成功如下:二、上传jdk安装包到Linux服务器jdk...

麒麟系统安装JAVA JDK教程_麒麟系统配置jdk

检查检查系统是否自带java在麒麟系统桌面空白处,右键“在终端打开”,打开shell对话框输入:java–version查看是否自带java及版本如图所示,系统自带OpenJDK,要先卸载自带JDK...

学习笔记-Linux JDK - 安装&配置

前提条件#检查是否存在JDKrpm-qa|grepjava#删除现存JDKyum-yremovejava*安装OracleJDK不分系统#进入安装文件目...

Linux新手入门系列:Linux下jdk安装配置

本系列文章是把作者刚接触和学习Linux时候的实操记录分享出来,内容主要包括Linux入门的一些理论概念知识、Web程序、mysql数据库的简单安装部署,希望能够帮到一些初学者,少走一些弯路。注意:L...

测试员必备:Linux下安装JDK 1.8你必须知道的那些事

1.简介在Oracle收购Sun后,Java的一系列产品就被整合到Oracle官网中,打开官网乍眼一看也不知道去哪里下载,还得一个一个的摸索尝试,而且网上大多数都是一些Oracle收购Sun前,或者就...

Linux 下安装JDK17_linux 安装jdk1.8 yum

一、安装环境操作系统:JDK版本:17二、安装步骤第一步:下载安装包下载Linux环境下的jdk1.8,请去官网(https://www.oracle.com/java/technologies/do...

在Ubuntu系统中安装JDK 17并配置环境变量教程

在Ubuntu系统上安装JDK17并配置环境变量是Java开发环境搭建的重要步骤。JDK17是Oracle提供的长期支持版本,广泛用于开发Java应用程序。以下是详细的步骤,帮助你在Ubuntu系...

如何在 Linux 上安装 Java_linux安装java的步骤

在桌面上拥抱Java应用程序,然后在所有桌面上运行它们。--SethKenlon(作者)无论你运行的是哪种操作系统,通常都有几种安装应用程序的方法。有时你可能会在应用程序商店中找到一个应用程序...

Windows和Linux环境下的JDK安装教程

JavaDevelopmentKit(简称JDK),是Java开发的核心工具包,提供了Java应用程序的编译、运行和开发所需的各类工具和类库。它包括了JRE(JavaRuntimeEnviro...

linux安装jdk_linux安装jdk软连接

JDK是啥就不用多介绍了哈,外行的人也不会进来看我的博文。依然记得读大学那会,第一次实验课就是在机房安装jdk,编写HelloWorld程序。时光飞逝啊,一下过了十多年了,挣了不少钱,买了跑车,娶了富...

linux安装jdk,全局配置,不同用户不同jdk

jdk1.8安装包链接:https://pan.baidu.com/s/14qBrh6ZpLK04QS8ogCepwg提取码:09zs上传文件解压tar-zxvfjdk-8u152-linux-...

运维大神教你在linux下安装jdk8_linux安装jdk1.7

1.到官网下载适合自己机器的版本。楼主下载的是jdk-8u66-linux-i586.tar.gzhttp://www.oracle.com/technetwork/java/javase/downl...

window和linux安装JDK1.8_linux 安装jdk1.8.tar

Windows安装JDK1.8的步骤:步骤1:下载JDK打开浏览器,找到JDK下载页面https://d.injdk.cn/download/oraclejdk/8在页面中找到并点击“下载...

最全的linux下安装JavaJDK的教程(图文详解)不会安装你来打我?

默认已经有了linux服务器,且有root账号首先检查一下是否已经安装过java的jdk任意位置输入命令:whichjava像我这个已经安装过了,就会提示在哪个位置,你的肯定是找不到。一般我们在...

取消回复欢迎 发表评论: