#_*_ coding:utf8 _*_
import sys,time
import yaml
import re
import os
import ssl
import random
import ConfigParser
from unittest import TestCase from pysphere import VIServer, VIProperty, MORTypes, VIException, FaultTypes, \
VMPowerState, ToolsStatus class VmDP:
def __init__(self, host, user, password, **kwargs):
self.host = host
self.user = user
self.pwd = password self.server = VIServer()
self.server.connect(self.host, self.user, self.pwd)
self.kwargs = kwargs #虚拟机的资源信息显示
def vm_info(self):
all_hosts = self.server.get_hosts() # 查看物理机
datacenter = self.server.get_datacenters() # 查看数据中心
cluster = self.server.get_clusters() # 查看集群
store = self.server.get_datastores() # 查看存储
resource = self.server.get_resource_pools() # 资源池信息
vm_name = self.server.get_registered_vms() # 所有虚拟机
vm_power_on = self.server.get_registered_vms(status='poweredOn') # 所有已上电的虚拟机
vm_power_off = self.server.get_registered_vms(status='poweredOff') # 所有未上电的虚拟机 print("----物理主机信息----")
for k, v in all_hosts.items():
print("[主机名ID]:%s -- [IP地址]:%s" % (k, v)) print("----数据中心信息----")
for k, v in datacenter.items():
print("[数据中心ID]:%s -- [数据中心名字]:%s" % (k, v)) print("----存储信息----")
for k, v in store.items():
print("[存储ID]:%s -- [存储名字]:%s" %(k,v)) print("----集群信息----")
for k, v in cluster.items():
print("[集群ID]:%s -- [集群名字]:%s" %(k,v)) print("----资源池信息----(分组信息)")
for k, v in resource.items():
print("[资源池ID]:%s -- [资源路径]:%s" %(k,v)) def install_vm_info(self, vm_name):
if vm_name is None:
print("没有参数vm_name.请输入参数:install_vm_info(vm_name)")
exit(1)
tmp = filter(self.server, vm_name)
vm = self.server.get_vm_by_path(tmp)
os_info = vm.get_properties()['guest_full_name']
guest_id = vm.get_properties()['guest_id']
cpu_nu = vm.get_properties()['num_cpu']
disk_capacity = str(vm.get_properties()['disks'][0]['capacity'] / 1024 / 1024) + "g"
device_cd = vm.get_properties()['devices'][16000]["label"]
device_network = vm.get_properties()['devices'][4000]["label"]
mem_nu = str(vm.get_properties()['memory_mb'] / 1024) + "g"
vm_ip = vm.get_properties()['ip_address']
vm_mac = vm.get_properties()['net'][0]['mac_address']
vnc_network = vm.get_properties()['net'][0]['network']
print("""
\t\t==========================================================
\t\t虚拟机安装的系统信息 : %s
\t\t==========================================================""" % os_info) print("""
==============
虚拟机基础信息
==============
主机名: %s\t\t虚拟机名: %s\t\t虚拟机ID: %s
IP地址: %s\t\tMAC地址: %s\t\t虚拟网络: %s
==============
虚拟机硬件配置
==============
CPU数: %s\t内存: %s\t硬盘: %s\tCDROM: %s\t网卡: %s""" % (host_name, vm_in_name, guest_id, \
vm_ip, vm_mac, vnc_network, cpu_nu, mem_nu, disk_capacity, device_cd, device_network)) # 过滤出虚拟机的 存储和虚拟机名
def filter(obj, v):
hosts = obj.get_registered_vms()
if v is not None:
for host in hosts:
res = re.findall(r'\[\S*\] ' + v + '\/' + v + '\.vmx', host)
# res = re.findall(r''+'\[\w*\] '+ v + '\/\w*.vmx',host)
if res:
return res[0] def vm_dis(self):
if self.server.is_connected():
self.server.disconnect() def network_info(self):
return os.system("/usr/bin/ezmomi list --type Network") def vm_all_host(self):
return os.system("/usr/bin/ezmomi list --type VirtualMachine") def clone_template(self, kwargs):
k = kwargs
print k
os.system("ezmomi clone --template %s --hostname %s --cpus %s --mem %s --ips %s" \
% (k['template'], k['hostname'], k['cpu'] ,k['mem'], k['new_vm_ip']))
return True if __name__ == "__main__":
# 关闭ssl证书验证
ssl._create_default_https_context = ssl._create_unverified_context config_name = 'config.yaml'
config_file = os.path.join(os.path.dirname(os.path.abspath(__file__)), config_name)
config = yaml.load(file(config_file))
v = VmDP(config['vmware']['host'], config['vmware']['user'], config['vmware']['pwd'])
v.vm_info()
clone_conf = {'template': 'template-test',
'hostname': 'test_zhang',
'cpu': '4',
'mem': '4',
'new_vm_ip': '10.101.255.208'}
v.clone_template(clone_conf)

  

Vmware 控制脚本的更多相关文章

  1. SHELL编写NGINX服务控制脚本

    使用源码包安装的Nginx没办法使用"service nginx start"或"/etc/init.d/nginx start"进行操作和控制,所以写了以下的 ...

  2. Unity 3D 一个简单的角色控制脚本

    之所以写这个脚本,是因为我想起了我还是新手的时候,那时为了一个角色控制脚本百度了半天还是一无所获,因为看不懂啊,都写的太高级了 希望这个脚本能够帮助那些 像曾经的我一样迷失于代码中的新手们能够清晰的理 ...

  3. Unity3D第三人称摄像机控制脚本

    好久没有敲Blog该.感谢您的留言.注意.私人信件和其他支持,但我似乎没有办法继续自己曾经写了一篇博客系列,因为我在网上找到有关unity3D太少的内容,U3D相关的文章!.. 第三人称视角 第三人称 ...

  4. 《Linux命令行与shell脚本编程大全》第十六章 控制脚本

    一些控制脚本的方式:向脚本发送信号.修改脚本优先级,在脚本运行时切换到运行模式 16.1 处理信号 linux利用信号与运行在系统中的进程进行通信. 也可以通过对脚本进行编程,使其在收到特定信号时执行 ...

  5. Hadoop中的控制脚本

    1.提出问题 在上篇博文中,提到了为什么要配置ssh免密码登录,说是Hadoop控制脚本依赖SSH来执行针对整个集群的操作,那么Hadoop中控制脚本都是什么东西呢?具体是如何通过SSH来针对整个集群 ...

  6. Shell编程—控制脚本

    1处理信号 1.1信号表 编号 信号名称 缺省操作 解释 1 SIGHUP Terminate 挂起控制终端或进程 2 SIGINT Terminate 来自键盘的中断 3 SIGQUIT Dump ...

  7. Unity3D Player角色移动控制脚本

    1. 简介 在Unity3D中,有多种方式可以改变物体的坐标,实现移动的目的,其本质是每帧修改物体的position.之前写过类似的文章,这次增加了平时常用API的脚本,每个脚本均手打测试可用. 2. ...

  8. Linux&shell之如何控制脚本

    写在前面:案例.常用.归类.解释说明.(By Jim) Ctrl+C组合键可以生产SIGINT信号Ctrl+Z组合键生产SIGTSTP信号,停止进程后程序仍然留在内存中,能够从停止的地方继续运行. 捕 ...

  9. Linux控制脚本:信号捕捉,作业控制,调整谦让度,以及计划任务

    1.关于信号以及信号捕捉 (1) $ ps  -au可以用来查看所有作业,包括暂停的和停止的,当然还有正在运行的. 在STAT这一列表示各个作业的状态,S表示Stop,R表示Run,T表示被追踪的或停 ...

随机推荐

  1. FineUIMvc v4.0.0 发布了,MVC控件库基础版免费!

    FineUI(MVC版)v4.0.0 已经于 2017-10-24 发布! 这个版本将引入了激动人心的 CSS3 动画,只需要开启全局属性 EnableAnimation 即可,先睹为快: 1. 菜单 ...

  2. 单点登录SSO:图示和讲解

    目录 概述 示例运行效果动画 跨域Web SSO时序图 代码截图 几个基本概念 涉及的站点和页面 重点理解:单点登录的核心步骤 敢说最准确的单点登录图示,因为: 我严格对照所画时序图的每个步骤,开发了 ...

  3. 1、Django系列之web应用与http协议

    第1节:最简单的web应用程序 Web应用程序指供浏览器访问的程序,通常也简称为Web应用.应用程序有两种模式C/S.B/S.C/S是客户端/服务器端程序,也就是说这类程序一般独立运行.而B/S就是浏 ...

  4. vue报错信息

    1.Property or method "xxx" is not defined on the instance but referenced during render. 原因 ...

  5. Centos7 ssh配置RSA证书登录

    修改sshd配置文件 vim /etc/ssh/sshd_config #增加以下三项 RSAAuthentication yes PubkeyAuthentication yes Authorize ...

  6. Log4.Net 在Winform、MVC、ashx程序里的使用,ashx程序里使用异步

    最近做一个双11活动的,是一套相关的H5页面.本来以为难度不大,但是做下来几天还是遇到些问题.就总结一下吧,还是有收获的. 1.在H5页面中,有一个遮罩层,还是挺有意思的.直接用div+css控制遮罩 ...

  7. H5 36-背景定位属性

    <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8&quo ...

  8. l^oo不可分的两个注意点

    1  不理解等一个等式 , 2.不理解为什么,一个可分的集合里面有不可数的子集?谢谢 1是 2.是可分集合里面每个元素 做中心后的一个开覆盖 所有0 1序列是和所有二进制小数   可以一一对应   而 ...

  9. scrapy之持久化存储

    scrapy之持久化存储 scrapy持久化存储一般有三种,分别是基于终端指令保存到磁盘本地,存储到MySQL,以及存储到Redis. 基于终端指令的持久化存储 scrapy crawl xxoo - ...

  10. Python_阻塞IO、非阻塞IO、IO多路复用

    0.承上 进程: 计算机里最小的资源分配单位: 数据隔离, 利用多核,数据不安全. 线程: 计算机中最小的CPU调度单位: 数据共享,GIL锁,数据不安全. 协程: 线程的一部分,是有用户来调度的; ...