首頁 > 軟體

pyvmomi 實現VMware自動化

2020-06-16 17:45:42

運維離不開自動化,python的發展更是給自動化注入了一劑興奮劑;還記得當時公司年會,大家都在嗨皮,苦逼的運維攻城獅還在賣力的給一個大客戶手動開通500台雲主機的情形,現在想想好傻O(∩_∩)O哈哈~。如果早點接觸pyVmomi,就不至於這麼苦逼了。

pyVmomi is the Python SDK for the VMware vSphere API that allows you to manage ESX, ESXi, and vCenter.官方如是說。自己這裡寫篇部落格整理一下,也希望對還停留在手工時代的同學有所幫助。

壞境設定:
1、網路環境:
    安裝pyvmomi的server和VMware vCenter 網路打通;
2、系統環境:
    pyvmomi用pip安裝,所以需要有python和pip;pyvmomi 6.0.0需要的python版本支援為2.7, 3.3 和 3.4, 支援的vSphere 版本為:6.0, 5.5, 5.1 和 5.0。
安裝如下:
$sudo apt-get install python-pip
$sudo pip install pyvmomi
$sudo pip freeze | grep pyvmomi    #檢視安裝的pyvmomi版本,現在是6.0版本
pyvmomi==6.0.0        #如果已經安裝過,升級用pip install --upgrade pyvmomi

或者也可以下載原始碼包安裝,https://github.com/vmware/pyvmomi.git:
$sudo python setup.py install

3、pyvmomi提供了一些社群樣本專案,可以參考編寫自己的程式碼:
git clone https://github.com/vmware/pyvmomi-community-samples.git

4、下面是 pyvmomi給出的獲取所有vm的指令碼:
#!/usr/bin/env python
# VMware vSphere Python SDK
# Copyright (c) 2008-2015 VMware, Inc. All Rights Reserved.
#
# Licensed under the Apache License, Version 2.0 (the "License");
# you may not use this file except in compliance with the License.
# You may obtain a copy of the License at
#
#    http://www.apache.org/licenses/LICENSE-2.0
#
# Unless required by applicable law or agreed to in writing, software
# distributed under the License is distributed on an "AS IS" BASIS,
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
# See the License for the specific language governing permissions and
# limitations under the License.
 
"""
Python program for listing the vms on an ESX / vCenter host
"""
 
from __future__ import print_function
 
from pyVim.connect import SmartConnect, Disconnect
 
import argparse
import atexit
import getpass
import ssl
 
def GetArgs():
  """
  Supports the command-line arguments listed below.
  """
  parser = argparse.ArgumentParser(
      description='Process args for retrieving all the Virtual Machines')
  parser.add_argument('-s', '--host', required=True, action='store',
                      help='Remote host to connect to')
  parser.add_argument('-o', '--port', type=int, default=443, action='store',
                      help='Port to connect on')
  parser.add_argument('-u', '--user', required=True, action='store',
                      help='User name to use when connecting to host')
  parser.add_argument('-p', '--password', required=False, action='store',
                      help='Password to use when connecting to host')
  args = parser.parse_args()
  return args
 
 
def PrintVmInfo(vm, depth=1):
  """
  Print information for a particular virtual machine or recurse into a folder
    with depth protection
  """
  maxdepth = 10
 
  # if this is a group it will have children. if it does, recurse into them
  # and then return
  if hasattr(vm, 'childEntity'):
      if depth > maxdepth:
        return
      vmList = vm.childEntity
      for c in vmList:
        PrintVmInfo(c, depth+1)
      return
 
  summary = vm.summary
  print("Name      : ", summary.config.name)
  print("Path      : ", summary.config.vmPathName)
  print("Guest      : ", summary.config.guestFullName)
  annotation = summary.config.annotation
  if annotation != None and annotation != "":
      print("Annotation : ", annotation)
  print("State      : ", summary.runtime.powerState)
  if summary.guest != None:
      ip = summary.guest.ipAddress
      if ip != None and ip != "":
        print("IP        : ", ip)
  if summary.runtime.question != None:
      print("Question  : ", summary.runtime.question.text)
  print("")
 
def main():
  """
  Simple command-line program for listing the virtual machines on a system.
  """
  args = GetArgs()
  if args.password:
      password = args.password
  else:
      password = getpass.getpass(prompt='Enter password for host %s and '
                                        'user %s: ' % (args.host,args.user))
 
 
  context = ssl.SSLContext(ssl.PROTOCOL_TLSv1)
  context.verify_mode = ssl.CERT_NONE
  si = SmartConnect(host=args.host,
                    user=args.user,
                    pwd=password,
                    port=int(args.port),
                    sslContext=context)
  if not si:
      print("Could not connect to the specified host using specified "
            "username and password")
      return -1
 
  atexit.register(Disconnect, si)
 
  content = si.RetrieveContent()
  for child in content.rootFolder.childEntity:
      if hasattr(child, 'vmFolder'):
        datacenter = child
        vmFolder = datacenter.vmFolder
        vmList = vmFolder.childEntity
        for vm in vmList:
            PrintVmInfo(vm)
  return 0
 
# Start program
if __name__ == "__main__":
  main()

5、執行之後輸出格式如下:

本文永久更新連結地址http://www.linuxidc.com/Linux/2016-03/128967.htm


IT145.com E-mail:sddin#qq.com