需求:

第三方云平台管理的虚拟机会进行关机、资源扩展等操作,因此开关机状态、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 PL/SQL比较两个字段是否一样

ORACLE通过JOB定时执行存储过程

oracle 两表数据对比---minus

Oracle job procedure 存储过程定时任务

Oracle通过JOB定时执行存储过程实现两表数据比对的更多相关文章

  1. 创建JOB定时执行存储过程

    创建JOB定时执行存储过程有两种方式 方式1:通过plsql手动配置job,如下图: 方式2:通过sql语句,如下sql declare job_OpAutoDta pls_integer;--声明一 ...

  2. Oracle定时执行存储过程(转)

    定时执行存储过程在平时开发中经常会用到,年前的时候自己也做了一个,由于时间关系一直没能记录,现记录下来.       首先用一个完整的例子来实现定时执行存储过程. 任务目标:每小时向test表中插入一 ...

  3. oracle job 定时执行 存储过程

    oracle job 定时执行 存储过程   一:简单测试job的创建过程案例: 1,先创建一张JOB_TEST表,字段为a 日期格式 SQL> create table JOB_TEST(a ...

  4. [转]oracle job有定时执行的功能,可以在指定的时间点或每天的某个时间点自行执行任务。

    oracle job有定时执行的功能,可以在指定的时间点或每天的某个时间点自行执行任务. 一.查询系统中的job,可以查询视图 --相关视图 select * from dba_jobs; selec ...

  5. oracle job有定时执行功能

    oracle job有定时执行的功能,可以在指定的时间点或每天的某个时间点自行执行任务.   oracle job有定时执行的功能,可以在指定的时间点或每天的某个时间点自行执行任务. 一.查询系统中的 ...

  6. 0327定时执行--存储过程--dbms_job--dbms_scheduler.create_job

    --oracle job 定时执行 存储过程 --建一张测试表 create table Person( name ), sex ) ); / --创建测试的存储过程 create or replac ...

  7. ORACLE 定时执行存储过程

    推荐用dbms_scheduler方式更好 (2012-11-19注) /* 查询: select job,broken,what,interval,t.* from user_jobs t; job ...

  8. oracle job有定时执行的功能,可以在指定的时间点或每天的某个时间点自行执行任务。

    来源于:http://www.cnblogs.com/wangfg/p/5110831.html 一.查询系统中的job,可以查询视图 --相关视图 select * from dba_jobs; s ...

  9. Oracle定时执行存储过程

    首先查看 SQL> show parameter job NAME                                 TYPE        VALUE-------------- ...

随机推荐

  1. NOIP2017游记

    日常大考之前感冒(这次感冒了3周..) Day -4~Day 0 停课一周,不写作业不上课是很爽,然而想到NOIP结束第二天就要期中考.. 在学校刷刷题,跟着一大堆大佬的步伐,做着一大堆大佬的题目(其 ...

  2. 2017"百度之星"程序设计大赛 - 复赛1005&&HDU 6148 Valley Numer【数位dp】

    Valley Numer Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others)Tota ...

  3. [51nod1357]密码锁

    有一个密码锁,其有N位,每一位可以是一个0~9的数字,开启密码锁需要将锁上每一位数字转到解锁密码一致.这个类似你旅行用的行李箱上的密码锁,密码锁的每一位其实是一个圆形转盘,上面依次标了0,1,...9 ...

  4. Spring学习日志之Spring MVC启动配置

    对DispatcherServlet进行配置 Spring MVC的配置实际上就是对DispatcherServlet的配置 public class DispatcherServletConfig ...

  5. ionic2 安装与cordova打包

    1.安装: cnpm install -g cordova ionic ionic start name cd name cnpm install   2.环境配置: http://www.cnblo ...

  6. GDI绘制时钟效果,与系统时间保持同步,基于Winform

    2018年工作之余,想起来捡起GDI方面的技术,特意在RichCodeBox项目中做了两个示例程序,其中一个就是时钟效果,纯C#开发.这个CSharpQuartz是今天上午抽出一些时间,编写的,算是偷 ...

  7. ASP.NET没有魔法——ASP.NET MVC & 分层 代码篇

    上一篇文章对如何规范使用ASP.NET进行了介绍,本章内容将根据上一篇得出的结论来修改博客应用的代码. 代码分层 综合考虑将博客应用代码分为以下几个层次: ○ 模型:代表应用程序中的数据模型,与数据库 ...

  8. .23-浅析webpack源码之事件流compilation(1)

    正式开始跑编译,依次解析,首先是: compiler.apply( new JsonpTemplatePlugin(options.output), // start new FunctionModu ...

  9. 记node前后端代码共用的一次坑

    项目背景 nodejs项目,webpack打包,用axios请求,Promise封装,nunjucks模板引擎: 之前已将nunjucks模板通过webpack打包策略,做成前后端共用: 目前需要将网 ...

  10. O2O网站

    编辑 020是新型的网络营销模式,O2O即Online To Offline,线下销售与服务通过线上推广来揽客,消费者可以通过线上来筛选需求,在线预订.结算,甚至可以灵活地进行线上预订,线下交易.消费 ...