Vmware 控制脚本
#_*_ 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 控制脚本的更多相关文章
- SHELL编写NGINX服务控制脚本
使用源码包安装的Nginx没办法使用"service nginx start"或"/etc/init.d/nginx start"进行操作和控制,所以写了以下的 ...
- Unity 3D 一个简单的角色控制脚本
之所以写这个脚本,是因为我想起了我还是新手的时候,那时为了一个角色控制脚本百度了半天还是一无所获,因为看不懂啊,都写的太高级了 希望这个脚本能够帮助那些 像曾经的我一样迷失于代码中的新手们能够清晰的理 ...
- Unity3D第三人称摄像机控制脚本
好久没有敲Blog该.感谢您的留言.注意.私人信件和其他支持,但我似乎没有办法继续自己曾经写了一篇博客系列,因为我在网上找到有关unity3D太少的内容,U3D相关的文章!.. 第三人称视角 第三人称 ...
- 《Linux命令行与shell脚本编程大全》第十六章 控制脚本
一些控制脚本的方式:向脚本发送信号.修改脚本优先级,在脚本运行时切换到运行模式 16.1 处理信号 linux利用信号与运行在系统中的进程进行通信. 也可以通过对脚本进行编程,使其在收到特定信号时执行 ...
- Hadoop中的控制脚本
1.提出问题 在上篇博文中,提到了为什么要配置ssh免密码登录,说是Hadoop控制脚本依赖SSH来执行针对整个集群的操作,那么Hadoop中控制脚本都是什么东西呢?具体是如何通过SSH来针对整个集群 ...
- Shell编程—控制脚本
1处理信号 1.1信号表 编号 信号名称 缺省操作 解释 1 SIGHUP Terminate 挂起控制终端或进程 2 SIGINT Terminate 来自键盘的中断 3 SIGQUIT Dump ...
- Unity3D Player角色移动控制脚本
1. 简介 在Unity3D中,有多种方式可以改变物体的坐标,实现移动的目的,其本质是每帧修改物体的position.之前写过类似的文章,这次增加了平时常用API的脚本,每个脚本均手打测试可用. 2. ...
- Linux&shell之如何控制脚本
写在前面:案例.常用.归类.解释说明.(By Jim) Ctrl+C组合键可以生产SIGINT信号Ctrl+Z组合键生产SIGTSTP信号,停止进程后程序仍然留在内存中,能够从停止的地方继续运行. 捕 ...
- Linux控制脚本:信号捕捉,作业控制,调整谦让度,以及计划任务
1.关于信号以及信号捕捉 (1) $ ps -au可以用来查看所有作业,包括暂停的和停止的,当然还有正在运行的. 在STAT这一列表示各个作业的状态,S表示Stop,R表示Run,T表示被追踪的或停 ...
随机推荐
- 反射那点基础-Method
目录 1 获取 Method 1.1 方法 1.2 实例 2 Method 的方法 2.1 Java 方法基础知识 2.2 修饰符相关方法 2.2.1 获取修饰符 2.2.2 判断是否为 defaul ...
- H5 audio标签
37-audio标签 注意点: audio标签的使用和video标签的使用基本一样, video中能够使用的属性在audio标签中大部分都能够使用, 并且功能都一样 只不过有3个属性不能用, heig ...
- c++入门之命名空间存在的意义
看过鸡啄米的C++编程入门系列教程的朋友,应该能注意到,在其中的很多实例中,都有这么一条语句:using namespace std;,即使用命名空间std,其作用就是规定该文件中使用的标准库函数都是 ...
- Continued Fractions CodeForces - 305B (java+高精 / 数学)
A continued fraction of height n is a fraction of form . You are given two rational numbers, one is ...
- Windows之PowerShell使用命令
Windows之PowerShell使用命令 切换 命令格式: cd [option] 切换到上一级目录 cd ../ 或者 cd .. 不同磁盘之间切换 盘符: 清屏 清空当前窗口的内容 cls 查 ...
- EntityFrameworkCore中的实体状态
Entry表示一个追踪,里面有state属性,是EntityState的枚举类型. 每一个实体都有一个相对应的Entry: var entry = dbContext.ChangeTracker.En ...
- [转帖]Docker的数据管理(volume/bind mount/tmpfs)
Docker(十五)-Docker的数据管理(volume/bind mount/tmpfs) https://www.cnblogs.com/zhuochong/p/10069719.html do ...
- Vagrant系列(二)----Vagrant的配置文件Vagrantfile详解
一.简介 在我们的工作目录下有一个Vagrantfile文件,里面包含有大量的配置信息,通过它可以定义虚拟机的各种配置,如网络.内存.主机名等,主要包括三个方面的配置,虚拟机的配置.SSH配置.Vag ...
- vue.js实战——vue 实时时间
created:实例创建完成后调用,此阶段完成了数据的观测等,但尚未挂载,$el还不可用,需要初始化处理一些数据时会比较有用. mounted:el挂载到实例上后调用,一般我们的第一个业务逻辑会在这里 ...
- python爬虫之Anaconda安装
Anaconda概述 Anaconda是一个用于科学计算的Python发行版,支持 Linux, Mac, Windows系统,提供了包管理与环境管理的功能,可以很方便地解决多版本python并存.切 ...