我们的zabbix 监控使用 oracle 作为存储, 因此,需要创建基于 基于时间戳的分区表,在此将操作过程记录如下

1. 创建,四个zabbix 最大的表的分区表

create table history_part
(
    "ITEMID" NUMBER(20,0) NOT NULL ENABLE,
    "CLOCK" NUMBER(10,0) DEFAULT '0' NOT NULL ENABLE,
    "VALUE" NUMBER(20,4) DEFAULT '0.0000' NOT NULL ENABLE,
    "NS" NUMBER(10,0) DEFAULT '0' NOT NULL ENABLE
)
PARTITION BY RANGE (CLOCK) INTERVAL (2592000)
(partition part_t01 values less than(1573401600));

CREATE TABLE "ZABBIX_SERVER"."HISTORY_UINT_PART"
   (    "ITEMID" NUMBER(20,0) NOT NULL ENABLE,
    "CLOCK" NUMBER(10,0) DEFAULT '0' NOT NULL ENABLE,
    "VALUE" NUMBER(20,0) DEFAULT '0' NOT NULL ENABLE,
    "NS" NUMBER(10,0) DEFAULT '0' NOT NULL ENABLE
   )
   PARTITION BY RANGE (CLOCK) INTERVAL (2592000)
(partition part_t01 values less than(1573401600));

CREATE TABLE "ZABBIX_SERVER"."TRENDS_PART"
   (    "ITEMID" NUMBER(20,0) NOT NULL ENABLE,
    "CLOCK" NUMBER(10,0) DEFAULT '0' NOT NULL ENABLE,
    "NUM" NUMBER(10,0) DEFAULT '0' NOT NULL ENABLE,
    "VALUE_MIN" NUMBER(20,4) DEFAULT '0.0000' NOT NULL ENABLE,
    "VALUE_AVG" NUMBER(20,4) DEFAULT '0.0000' NOT NULL ENABLE,
    "VALUE_MAX" NUMBER(20,4) DEFAULT '0.0000' NOT NULL ENABLE,
     PRIMARY KEY ("ITEMID", "CLOCK"))
     PARTITION BY RANGE (CLOCK) INTERVAL (2592000)
(partition part_t01 values less than(1573401600));

CREATE TABLE "ZABBIX_SERVER"."TRENDS_UINT_PART"
   (    "ITEMID" NUMBER(20,0) NOT NULL ENABLE,
    "CLOCK" NUMBER(10,0) DEFAULT '0' NOT NULL ENABLE,
    "NUM" NUMBER(10,0) DEFAULT '0' NOT NULL ENABLE,
    "VALUE_MIN" NUMBER(20,0) DEFAULT '0' NOT NULL ENABLE,
    "VALUE_AVG" NUMBER(20,0) DEFAULT '0' NOT NULL ENABLE,
    "VALUE_MAX" NUMBER(20,0) DEFAULT '0' NOT NULL ENABLE,
     PRIMARY KEY ("ITEMID", "CLOCK"))
      PARTITION BY RANGE (CLOCK) INTERVAL (2592000)
(partition part_t01 values less than(1573401600));

第二步 迁移历史数据

本地不迁移了, 如果自己迁移,注意数据不能用

insert into select 方式,这样的数据量非常大,造成回滚段被占满

第三部 分区表和原始表 采用重命名方式对调

alter table trends rename to trends_nopart;
alter table trends_uint  rename to trends_uint_nopart

alter table history rename to history_nopart;
alter table history_uint rename to history_uint_nopart

alter table trends_part rename to trends;
alter table trends_uint_part rename to trends_uint;
alter table history_part rename to history;
alter table history_uint_part rename to history_uint

第五  实际操作后,发现 还要建立history和history_uint的本地索引,删除历史数据

上面建表语句中发现,history 和history_uint 没有索引, 全表扫描,会造成 CPU 一直使用 100%, 以至于数据无法写入

创建2个表的索引:

CREATE INDEX idx_history_uint_part ON ZABBIX_SERVER.HISTORY_UINT(ITEMID, CLOCK) local;
 
  CREATE INDEX idx_history_part ON ZABBIX_SERVER.HISTORY(ITEMID, CLOCK) local;

清空历史数据
  truncate table history_nopart;
  truncate table history_uint_nopart;   
  truncate table trends_nopart;
  truncate table trends_uint_nopart;

oracle 基于时间错的 分区表的更多相关文章

  1. ORACLE调度之基于时间的调度(一)【weber出品】

    一.调度的概述 这里我看到一篇对调度的概述觉得描述的比我好,但仅限于概述部分,其他部分我觉得我讲的比他好,于是发生以下事情: ************************华丽的转载******** ...

  2. Oracle之表空间基于时间点的恢复

    记一次优化过程中:一次误操作,在不影响其他表空间的情况下:采用表空间基于时间点的恢复(TSPITR)方法恢复数据的过程. 1.TSPITR恢复原理    TSPITR目前最方便的方法是使用RMAN进行 ...

  3. 2019-9-9:渗透测试,基础学习,phpmyadmin getshell方法,基于时间的盲注,基于报错的注入,笔记

    phpmyadmin getshell方法1,查看是否有导入导出设置 show global variables like '%secure-file-priv%';2,如果secure-file-p ...

  4. 【Oracle】rman基于时间点恢复

    rman基于时间点恢复 场景: 由于某研究的误操作,导致财务模块的数据丢失,如何使用rman基于时间点恢复数据. 思路 1.克隆数据库的虚拟机,直接对数据库的数据进行恢复 RMAN> shutd ...

  5. 基于时间的 SQL注入研究

    SQL注入攻击是业界一种非常流行的攻击方式,是由rfp在1998年<Phrack>杂志第54期上的“NT Web Technology Vulnerabilities”文章中首次提出的.时 ...

  6. Oracle 基于用户管理恢复的处理

    ================================ -- Oracle 基于用户管理恢复的处理 --================================ Oracle支持多种 ...

  7. Oracle大表改为分区表及表空间切换方案

    Oracle大表改为分区表及表空间切换方案 一.            背景 由于之前数据库表和索引放在一个表空间导致表空间数据文件增长太快,文件数量即将达到Oracle表空间的限制,需要对表(没有分 ...

  8. 【RMAN】TSPITR--RMAN表空间基于时间点的自动恢复

    [RMAN]TSPITR--RMAN表空间基于时间点的自动恢复 一.1  BLOG文档结构图 一.2  前言部分 一.2.1  导读 各位技术爱好者,看完本文后,你可以掌握如下的技能,也可以学到一些其 ...

  9. mysql基于“时间”的盲注

    无需页面报错,根据页面响应时间做判断! mysql基于时间的盲注 =================================================================== ...

随机推荐

  1. Python(一):一行解法参考

    #一行快速排序quick_sort = lambda array: array if len(array) <= 1 else quick_sort([item for item in arra ...

  2. SpringMVC的三种处理器适配器

    SpringMVC具有三种处理器适配器,他们分别是BeanNameUrlHandlerMapping.SimpleControllerHandlerAdapter.ControllerClassNam ...

  3. 基于XML装配bean的解析-Bean的作用域

    一.Bean的种类1.普通bean:<bean  id=""  class="A"> ,spring直接创建A实例,并返回. 2.FactoryBe ...

  4. 【音乐欣赏】《99》 - MOB CHOIR

    曲名:99 作者:MOB CHOIR [00:00.000] 作曲 : 佐々木淳一 [00:00.150] 作词 : 佐々木淳一 [00:00.450] [00:02.370]If everyone ...

  5. 浅谈分治 —— 洛谷P1228 地毯填补问题 题解

    如果想看原题网址的话请点击这里:地毯填补问题 原题: 题目描述 相传在一个古老的阿拉伯国家里,有一座宫殿.宫殿里有个四四方方的格子迷宫,国王选择驸马的方法非常特殊,也非常简单:公主就站在其中一个方格子 ...

  6. Postman 设置token为全局变量

    在做接口测试的时候,经常会用到不同用户登陆的token,来测试API,通过设置全局的token,这样更便捷: 注意设置的名称必须与你登陆后返回的名称一致,我这里是 AccessToken 1.配置环境 ...

  7. java多线程信息共享

    上篇文章知识介绍了多线程的创建和启动问题,各个子线程和子线程或者说子线程和main线程没有信息的交流,这篇文章主要探讨线程之间信息共享以及交换问题.这篇文章主要以一个卖票例子来展开. 继承Thread ...

  8. 微信小程序获取unionid

    链接:https://blog.csdn.net/a493001894/article/details/80323403

  9. [C/C++] _tprintf() 输出不了汉字

    在前面加一个 setlocale(LC_ALL, ""); //必须得有这行 否则不能输出中文 注意得加locale头文件 #include<stdio.h> #inc ...

  10. 关于iOS appIcon launchImage 尺寸

    https://developer.apple.com/library/ios/documentation/UserExperience/Conceptual/MobileHIG/IconMatrix ...