【OceanBase 诊断调优】—— OceanBase 数据库统计信息被禁用,状态为 broken 的原因和解决方法

问题现象

因为人为因素导致部分统计信息函数未安装,自动统计信息触发执行长期失败。重新安装统计信息相关函数后,发现仍然无法正常自动统计信息收集,统计信息状态为 broken。

问题原因

统计信息 JOB 收集失败次数达到 16 次会直接禁用 JOB 任务的使用。

适用版本

OceanBase 数据库 V4.2.4(oceanbase-4.2.4.0-100000252024070621)之前 V4.x 版本。

解决方法

  • 解决方法一:该禁用限制在 OceanBase 数据库 V4.2.4 版本已经取消,升级到 V4.2.4 版本。

    升级至问题已修复版本。目前已修复的版本为 V4.2.4(oceanbase-4.2.4.0-100000252024070621)版本。

  • 解决方法二:不升级的情况下,手动解除限制需要修改系统表。

    1. 登录 sys 租户切换到业务租户。

      复制代码
      alter system change TENANT xxx;
    2. 更新内部表 __all_tenant_scheduler_job

      复制代码
      -- 注意字段类型对应的值 failures,flag 是 int 类型。
      update __all_tenant_scheduler_job set failures=0,state='SCHEDULED',flag=0;
      警告

      更新内部表 __all_tenant_scheduler_job 存在风险,请勿自行操作。如果需要修改,请咨询 OceanBase 技术支持。

    3. 手动调用统计信息收集测试。

      复制代码
      -- 示例。
      call dbms_scheduler.set_attribute('MONDAY_WINDOW', 'NEXT_DATE', '2024-07-22 11:17:00');
    4. 在 sys 租户下查看统计信息收集的结果。

      复制代码
      select * from oceanbase.DBA_SCHEDULER_JOBS where job_name='MONDAY_WINDOW'\G;
相关推荐
不羁。。5 小时前
【撸靶笔记】第八关:GET - Blind - Boolian Based - Single Quotes
数据库·sql·mybatis
AwhiteV5 小时前
利用图数据库高效解决 Text2sql 任务中表结构复杂时占用过多大模型上下文的问题
数据库·人工智能·自然语言处理·oracle·大模型·text2sql
m0_595199856 小时前
Redis(以Django为例,含具体操作步骤)
数据库·redis·缓存
爱尚你19936 小时前
MySQL 三大日志:redo log、undo log、binlog 详解
数据库·mysql
小猿姐7 小时前
KubeBlocks AI:AI时代的云原生数据库运维探索
数据库·人工智能·云原生·kubeblocks
NocoBase9 小时前
10 个开源工具,快速构建数据应用
数据库·低代码·开源
麻辣清汤9 小时前
结合BI多维度异常分析(日期-> 商家/渠道->日期(商家/渠道))
数据库·python·sql·finebi
Kan先生11 小时前
对象存储解决方案:MinIO 的架构与代码实战
数据库·python
超级迅猛龙11 小时前
保姆级Debezium抽取SQL Server同步kafka
数据库·hadoop·mysql·sqlserver·kafka·linq·cdc
杨过过儿11 小时前
【Task02】:四步构建简单rag(第一章3节)
android·java·数据库