Oracle通过JOB定时执行存储过程实现两表数据比对
需求:
第三方云平台管理的虚拟机会进行关机、资源扩展等操作,因此开关机状态、CPU、内存、磁盘大小等数据需要进行同步。这里第三方云平台是BMC CLM云平台,底层虚拟化平台是Vcenter。进行同步的内容包括:PowerState,MemoryMB,NumCPU,HDNAME,CapacityKB,唯一键是Cluster,VMName,HDNAME
解决思路:
1 首先通过VMware vSphere PowerCLI工具每天抓取这些需要同步的数据
2 通过sqlload将数据放入BMC Cloud Lifecycle Management平台的oracle数据库中
3 在oracle数据库中建立存储过程,通过minus函数比对插入数据和已有数据的差异,并将差异结果放入一个表中。创建一个Oracle JOB每天执行这个存储过程。
4 差异结果已经找出,调用BMC内部接口只同步这几台机器即可,大大减少了数据量和工作负载
具体实现:
1 VMware vSphere PowerCLI每天抓取虚拟机配置信息
#脚本和上篇文章类似 Get-VM | %{$_.HardDisks | Select @{N="Cluster";E={$_.Parent.VMHost.Parent}},@{N="VMName";E={$_.Parent.Name}},@{N="PowerState";E={$_.Parent.PowerState}},` @{N="MemoryMB";E={$_.Parent.MemoryMB}},@{N="NumCPU";E={$_.Parent.NumCPU}},@{N="HDNAME";E={$_.Name}},CapacityKB}` | Export-Csv -NoTypeInformation -encoding utf8 c:\VMInfo\"Export67VMConfig$(Get-Date -Format 'yyyyMMdd').csv"
2 通过sqlload将数据放入BMC Cloud Lifecycle Management平台的oracle数据库中
具体sqlload方法参看前面文章
3 Oracle定期比对
这里注意minus函数的使用,这个函数比对全部字段,任意一个字段不同,都会视为差异
说明:下面sql语句中 表VM_Config_Dayly是每天插入的全部数据的表,表VM_Config_Update_Dayly是差异数据存放的表
3.1 首先创建比对作业的存储过程
create or replace procedure sp_update_vmdata as BEGIN delete from VM_Config_Update_Dayly; --插入前清空历史数据 commit; insert into VM_Config_Update_Dayly --插入下面查询出的数据 (uuid, CLUSTER1, VMNAME, POWERSTATE, MEMORYMB, NUMCPU, HDNAME, CAPACITYKB) select con.uuid, --查询差异数据的准确值 con.CLUSTER1, con.VMNAME, con.POWERSTATE, con.MEMORYMB, con.NUMCPU, con.HDNAME, con.CAPACITYKB from VM_Config_Dayly con, (select cl.shortdescription CLUSTER1, --把差异数据取出来 co.name VMNAME, (case co.state when 'Running' then 'PoweredOn' else 'PoweredOff' end) as POWERSTATE, co.totalphysicalmemory MEMORYMB, co.cloudtotalcpu NUMCPU, lo.name HDNAME, lo.blocksize CapacitiyKB from BMC_CORE_BMC_COMPUTERSYSTEM co, BMC_CORE_BMC_DEPENDENCY de, BMC_CORE_BMC_CLUSTER cl, BMC_CORE_BMC_LOGICALDISK lo, BMC_CORE_BMC_COMPONENT cp where co.instanceid = de.destination_instanceid and de.source_instanceid = cl.instanceid and de.source_classid = 'BMC_CLUSTER' and co.instanceid = cp.source_instanceid and cp.destination_instanceid = lo.instanceid and cp.destination_classid = 'BMC_LOGICALDISK' and co.cloudclass = 'virtualguest' MINUS select CLUSTER1, VMNAME, POWERSTATE, MEMORYMB, NUMCPU, HDNAME, CAPACITYKB from VM_Config_Dayly t) diff where con.CLUSTER1 = diff.CLUSTER1 and con.vmname = diff.vmname and con.hdname = diff.hdname; commit; end sp_update_vmdata;
3.2 创建JOB定期执行存储上面的存储过程
declare job_update_vmdata number; begin 用户.dbms_job.submit(job_update_vmdata,),'trunc(sysdate+1)+9/24'); commit; end; --注意上面的用户默认是sys,但不写也可以,我老是报错就栽倒在这了
4 差异结果同步
目前BMC还不支持同步功能的自动调用,但可以手动触发同步功能,如下图点击
oracle 构造列和默认列值 可以如下
select sysdate,1 t from dual
select sysdate,'value' Header from dual
参考
Oracle通过JOB定时执行存储过程实现两表数据比对的更多相关文章
- 创建JOB定时执行存储过程
创建JOB定时执行存储过程有两种方式 方式1:通过plsql手动配置job,如下图: 方式2:通过sql语句,如下sql declare job_OpAutoDta pls_integer;--声明一 ...
- Oracle定时执行存储过程(转)
定时执行存储过程在平时开发中经常会用到,年前的时候自己也做了一个,由于时间关系一直没能记录,现记录下来. 首先用一个完整的例子来实现定时执行存储过程. 任务目标:每小时向test表中插入一 ...
- oracle job 定时执行 存储过程
oracle job 定时执行 存储过程 一:简单测试job的创建过程案例: 1,先创建一张JOB_TEST表,字段为a 日期格式 SQL> create table JOB_TEST(a ...
- [转]oracle job有定时执行的功能,可以在指定的时间点或每天的某个时间点自行执行任务。
oracle job有定时执行的功能,可以在指定的时间点或每天的某个时间点自行执行任务. 一.查询系统中的job,可以查询视图 --相关视图 select * from dba_jobs; selec ...
- oracle job有定时执行功能
oracle job有定时执行的功能,可以在指定的时间点或每天的某个时间点自行执行任务. oracle job有定时执行的功能,可以在指定的时间点或每天的某个时间点自行执行任务. 一.查询系统中的 ...
- 0327定时执行--存储过程--dbms_job--dbms_scheduler.create_job
--oracle job 定时执行 存储过程 --建一张测试表 create table Person( name ), sex ) ); / --创建测试的存储过程 create or replac ...
- ORACLE 定时执行存储过程
推荐用dbms_scheduler方式更好 (2012-11-19注) /* 查询: select job,broken,what,interval,t.* from user_jobs t; job ...
- oracle job有定时执行的功能,可以在指定的时间点或每天的某个时间点自行执行任务。
来源于:http://www.cnblogs.com/wangfg/p/5110831.html 一.查询系统中的job,可以查询视图 --相关视图 select * from dba_jobs; s ...
- Oracle定时执行存储过程
首先查看 SQL> show parameter job NAME TYPE VALUE-------------- ...
随机推荐
- 优雅的处理Redis访问超时
很长一段时间以来,一直在项目中使用Redis作为辅助存储,确切来说是利用Redis的内存存储,而不是将其作为缓存.比如常见的利用Set集合来判断某个数值是否存在,或者将来自不同请求的数据放在Redis ...
- 前端工程化webpack(一)
webpack 的基本用法 1.app.js 引入模块 import moduleLog from './module.js' //引入moduleLog从./module.js 2.module ...
- Django-环境搭建
django开发环境搭建 环境说明 python django mysql pymysql pycharm 安装过程 安装python3.6.3 64位下载地址: https://www.python ...
- 任务调度框架Quartz原理简介
[TOC] 第一章 Quartz 1.1 Quartz概念 Quartz是OpenSymphony开源组织的一个Java开源项目, 在2009被Terracotta收购.Quartz官网 1.2 Qu ...
- Java入门篇(一)——如何编写一个简单的Java程序
最近准备花费很长一段时间写一些关于Java的从入门到进阶再到项目开发的教程,希望对初学Java的朋友们有所帮助,更快的融入Java的学习之中. 主要内容包括JavaSE.JavaEE的基础知识以及如何 ...
- 微信小程序登陆授权
小程序前端代码 function WXlogin(){ wx.login({ success: function (code) { wx.getUserInfo({ success:function( ...
- 使用python写天气预告
先去YY天气注册一个账号,然后就能用API了 http://www.yytianqi.com/ # encoding=utf-8import urllib.requestimport jsonimpo ...
- bzoj:1299: [LLH邀请赛]巧克力棒
原题:http://www.lydsy.com/JudgeOnline/problem.php?id=1299 众多dalao的题解已经很详细了:http://blog.csdn.net/wzq_qw ...
- 【Java学习笔记之十一】Java中常用的8大排序算法详解总结
分类: 1)插入排序(直接插入排序.希尔排序) 2)交换排序(冒泡排序.快速排序) 3)选择排序(直接选择排序.堆排序) 4)归并排序 5)分配排序(基数排序) 所需辅助空间最多:归并排序 所需辅助空 ...
- HDU1754-I Hate It-线段树
I Hate It Time Limit: 9000/3000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others)Total S ...