PowerCLI: One-Liner to get VMs, Clusters, ESX Hosts and Datastores并导入数据库中
需求:定期自动获取Vm在VCenter中对应的cluster、ESX、Datastore信息,同时将变化或者新增的数据上传到数据库中
解决思路分析:
1 首先使用VMware的powerCLI工具通过任务计划程序,定期抓取上述所需信息
2 然后通过文件比较差异,将新增或者修改了的数据提取出来
3 将差异结果放到指定位置,或者数据库中
详细解决步骤:
下面详细说一下我的解决步骤
1 通过PowerCLI抓取所需信息,并上传
1.1首先安装PowerCLI工具(在win7或者windows2008上安装,参考附录)
1.2然后编写自动获取数据的脚本,脚本VMInfo.ps1示例如下,对应这个脚本的解释 ,请参考附录
#这个脚本获取VMname,vmid,ESXname,ESXID,Cluster,Datastore
Connect-VIServer -server ip -user 用户名l -password 密码
Get-VM | Select Name,id,@{N="ESXIP";E={(Get-VMHost -VM $_).name}}, `
@{N="ESXID";E={(Get-VMHost -VM $_).id}}, `
@{N="Cluster";E={Get-Cluster -VM $_}}, `
@{N="Datastore";E={Get-Datastore -VM $_}},`
Time | Export-Csv -NoTypeInformation c:\VMInfo\"Export67VMinfo$(Get-Date -Format 'yyyyMMdd').csv"
Disconnect-VIServer -server * -force -Confirm:$false
获取得到的数据格式如下:

我通过任务计划程序自动运行该脚本并将其上传至FTP服务器
1.3创建任务计划程序脚本CreateTask.bat
schtasks /create /ru system /tn :
1.4任务计划程序引用的脚本VMInfoBat.bat,这个脚本会调用PowershellCLI脚本,并输出日志
set datevar=%,%%,%%,% echo -------------%datevar%-log------------- >> c:\VMInfo\Running.log if exist c:\VMInfo\Export* del /q c:\VMInfo\Export*.csv C:\Windows\System32\WindowsPowerShell\v1.\powershell.exe -psconsolefile >& c:\VMInfo\runftp.bat >> c:\VMInfo\Running.log >&
1.5使用FTP上传
::UploadFtp.bat,上传文件至FTP open 10.200.169.2 用户名 密码
binary cd VMdata put C:\VMInfo\Export*.csv bye ::runftp.bat通过命令执行上面的ftp脚本 ftp -s:c:\VMInfo\UploadFtp.bat
2 提前在数据库上创建好对应的表,注意一般都需要有主键列和时间列,免得后面再添加更改
--建表,表中uuid是主键,会顺序加1,IMTIME是每次插入的时间 CREATE TABLE ARADMIN.VM_INFO_Dayly (UUID int primary key, VMNAME ), VMID ), ESXIP ), ESXID ) , CLUSTERNAME ), DATASTORE ), IMTIME date default sysdate not null,STATUS varchar2(128)) --建立序列 START ;--或者如下建立序列
/* create sequence VM_ID_SEQ minvalue 1 maxvalue 9999999999999999999999999999 start with 1 increment by 1 nocache; */
--建立一个触发器: CREATE OR REPLACE TRIGGER TRG_VM BEFORE INSERT ON VM_INFO_Dayly FOR EACH ROW BEGIN SELECT VM_ID_SEQ.NEXTVAL INTO :NEW.UUID FROM DUAL; END TR_VM;
3 比对今天和昨天的文件,并将差异结果写入数据库
这个过程是在linux机器上完成的,毕竟linux命令毕竟熟悉一些
比较用到的命令是 :
grep -vxFf file1 file2 >a.txt #比较存在于file2中而不在file1中的行
grep -xFf file1 file2 >b.txt #比较file1 和file2 的交集,具体参考附录
数据上传使用的是sqlload
运行下面命令提前看一下数据库的字符集,并修改下面文件中的字符集,以便不出现乱码
select userenv('language') from dual;
1 脚本sqlload.sh
好了下面把我的脚本sqlload.sh放上来,这个脚本实现今日和昨日数据比较,并把差异放入数据库
#!/bin/bash
# Description:
# Program download the VMinfo csv data
# And then compair with yesterday's data
# At the End sqlload the diff to Oracle
#-- lizhaoxian
PATH=/bin:/sbin:/usr/bin:/usr/sbin:/usr/local/bin:/usr/local/sbin:~/bin
ORACLE_HOME=/oracle/app/oracle/product/11.2.0.3/db_1
export ORACLE_HOME
export PATH=$PATH:$ORACLE_HOME/bin
ddate=`date +%Y%m%d`
ydate=`date --date='1 days ago' +%Y%m%d`
yydate=`date --date='2 days ago' +%Y%m%d`
# Log File
LOGFILE=/Vminfo/Vminfo.log
cat /dev/null > ${LOGFILE}
# DownLoad From FTP
echo ${ddate} >> ${LOGFILE}
FileName=`echo "Export67VMinfo${ddate}.csv"`
>&
user administrator abcde@
cd VMdata
lcd /Vminfo
binary
mget ${FileName}
bye
!
# 文件格式转换
dos2unix /Vminfo/Export* >> ${LOGFILE} >&
# 文件处理和比较
sed -i 's/硬盘\ /Disk/g;s/\ Disk/;Disk/g' /Vminfo/Export67VMinfo${ddate}.csv
#里面可以提前把ipv6的地址都过滤掉awk 'NF>2{gsub(/fe80::[a-zA-Z0-9:]+/, " ", $0);gsub(/ +/, " ", $0); print $0;}' test.log
grep -vxFf /Vminfo/Export67VMinfo${ydate}.csv /Vminfo/Export67VMinfo${ddate}.csv |sed 's/^\"/,/g' | sed 's/\"//g' > /Vminfo/Vmdata${ddate}.txt
# sqlload导入数据库
export ORACLE_SID=ARDB
export NLS_LANG=american_america.AL32UTF8
#数据库结构控制文件
CTL_FILE=/Vminfo/Vmdata.ctl
#sqlload输出日志文件
LOG_FILE=/Vminfo/sqlload.log
#数据文件
DATA_FILE=/Vminfo/Vmdata${ddate}.txt
sqlldr ARADMIN/clmAdm1n@10.200.243.85/ARDB control=${CTL_FILE} data=${DATA_FILE} log=${LOG_FILE}
# Clean log files
# clear yesterday's data
rm -f /Vminfo/Vmdata${yydate}.txt /Vminfo/Vmdata${ydate}.bad /Vminfo/Export67VMinfo${yydate}.csv
3 都写好了,那就添加到crontab中,让系统自动运行吧
#备份系统crontab crontab -u root -l > crontab.bak #修改系统定时任务 crontab -e #添加一行到文件末,每天八点,定时跑 * * * /Vminfo/sqlload.sh
大功告成,查看下数据库有没有数据就行了
参考附录:
PowerCLI: One-Liner to get VMs, Clusters, ESX Hosts and Datastores
powercli script to get cluster name, datastore name, total size & free space on DS for a VM
PowerCLI: One-Liner to get VMs, Clusters, ESX Hosts and Datastores并导入数据库中的更多相关文章
- ESX/ESXi 主机上的每个插槽中安装了多少内存
要确定在 ESX/ESXi 主机上的每个插槽中安装了多少内存,请执行以下操作: 1. 启动ssh服务 2. 登陆esxi主机查看 使用 SSH 客户端登录主机,以 root 用户身份运行以下命令之一: ...
- VMware PowerCLi 使用示例
这几天研究PowerCLI,积累了几个例子,记下来,以便以后或者大家使用.部分例子来着网络,具体出处参考附录 1 获取vm 磁盘 和磁盘对应的datastore的信息 这个例子可以针对一台虚机有多个磁 ...
- 【exp/imp】将US7ASCII字符集的dmp文件导入到ZHS16GBK字符集的数据库中
[exp/imp]将US7ASCII字符集的dmp文件导入到ZHS16GBK字符集的数据库中 1.1 BLOG文档结构图 1.2 前言部分 1.2.1 导读和注意事项 各位技术爱好者,看完本文后 ...
- 转-【exp/imp】将US7ASCII字符集的dmp文件导入到ZHS16GBK字符集的数据库中
原帖地址:http://blog.csdn.net/lihuarongaini/article/details/71512116 1.2 前言部分 1.2.1 导读和注意事项 各位技术爱好者,看完 ...
- Python实现电子词典(图形界面)
Python实现电子词典(图形界面) 终端电子词典:https://www.cnblogs.com/noonjuan/p/11341375.html 文件一览: .├── client.py├── d ...
- Vmware esx/esxi Vlan三种配置模式(VST、EST和VGT)
在Vmware esx/esxi中使用虚拟Lan(Vlan)时,一般是指Vlan Trunk的使用,使用的Vlan配置还有其它三种类型: Virtual Switch Tagging(虚拟交换机标记, ...
- Oracle Real Application Clusters (RAC)
Oracle Real Application Clusters — 概述 包含 Oracle Real Application Clusters (RAC) 选件的 Oracle 数据库允许依托一组 ...
- 基于PowerCli自动部署和配置vmvare虚拟机
1 文档说明 2 Vsphere PowerCli安装和配置 3 PowerCli常用命令 4 创建自定义规范 5 虚拟机克隆与配置脚本 6 技术资料 1 文档说明 使用Vsphere管理虚拟机,在进 ...
- VCAP5-DCA – What’s new?
see also: 韩国人的教材:http://ddii.pe.kr/ Section 1.1 – Implement and Manage complex storage Determine use ...
随机推荐
- 关于t00ls的挂机脚本
0x00 前言 今天早上发现t00ls上有人发了个挂机脚本,二十四小时刷时间以及刷Tubi. 轻轻松松升级,坐收Tubi成富翁. 代码很简单,就是带上cookie每隔一段时间(比如60秒)去请求一下某 ...
- duilib基本框架
最近我一个同学在项目中使用到了duilib框架,但是之前并没有接触过,他与我讨论这方面的内容,看着官方给出的精美的例子,我对这个库有了很大的兴趣,我自己也是初学这个东东,我在网上花了不少时间来找相关的 ...
- Ubuntu设置程序开机自启或者开机禁止加载
先说说ubuntu,它有运行级别这个概念 0:停机 1:单用户形式,只root进行维护 2:多用户,不能使用net file system 3:完全多用户 5:图形化 6:重启 例子:按指定顺序.在指 ...
- Mycat 配置
前言 Mycat 是一个数据库分库分表中间件 MyCAT 是作为通用代理设计的,后端是以 Mysql协议 和 JDBC 的方式连接数据库,可以支持 Oracle.DB2.SQL Server . mo ...
- CSS 设置table下tbody滚动条
table tbody { display:block; height:195px; overflow-y:scroll; } table thead, tbody tr { display:tabl ...
- \(?0\d{2}[) -]?\d{8}正则表达式的解释
正则表达式30分钟出现了这样一个正则表达式:(?0\d{2}[) -]?\d{8} "("和")"也是元字符,所以需要转义. ?匹配零或一次 (? 表示 出现( ...
- 【转】如何将qlv格式的腾讯视频转换为mp4格式
一般来说,每个视频网站都会有自己的视频播放格式,如优酷的KUX.爱奇艺的QSV和腾讯的QLV等.但是大家知道,优酷是有转码功能的,而就目前来说腾讯视频还没有转码功能,这就给大家造成了一定的困扰.这里呢 ...
- Echarts---柱状图实现
做Echarts很简单,可以参看官网 http://echarts.baidu.com/index.html 作为程序员我们只需要把静态数据替换成我们自己需要的! 下面看一个自己做的例子: 还是先看看 ...
- hihocoder-1079题解(线段树+离散化)
一.题目链接 http://hihocoder.com/problemset/problem/1079 二.题意 给定一个长度为L的区间,给你n个子区间,没一个区间涂成一种颜色,问最后这个区间内有几种 ...
- python端口扫描器
吃了个火鸡面后感觉到了怀疑人生!!!!!!!!!妈耶,在也不吃了.思路都给辣没了!!! python端口扫描器代码如下: #-*-coding:utf-8 from socket import * i ...