前三篇,我已經說了,咱們能夠使用grains來定義一些網絡和磁盤屬性,今天我使用pillar來定義這些屬性,並作些修改來,來快速啓動虛擬機.python
pillarweb
/srv/pillar/top.sls
base:
'kvm.tc.com':
- vm.profile網絡
/srv/pillar/vm/profile.sls
virt: {'nic': {'nics': [{'eth0': {'bridge': 'br0'}}]}, 'disk': {'system': [{'system': {'pool': '/var/lib/libvirt/im
ages', 'format': 'raw'}}, {'data': {'pool': '/var/lib/libvirt/images', 'format': 'raw'}}]}} ide
virt.py模塊作些稍微的修改:函數
添加一個修改虛擬機函數:spa
def _edit_vm(nics,img_dest,name): vm_name=name+".tc.com" nic_content={} for nic in nics: name=nic['name'] vm_mac=nic['mac'] vm_ip=nic['ip'] nic_content[name]={} nic_content[name]['ip']=vm_ip nic_content[name]['mac']=vm_mac g = guestfs.GuestFS(python_return_dict=True) g.add_drive_opts(img_dest) g.launch() #partions_root=g.inspect_os() 不能使用此功能,不然我後面寫的客戶端無提示. g.mount('/dev/sda3','/') #這一塊是針對我虛擬機鏡像文件格式,若是你的不同,能夠作修改 #g.mount(partions_root[0],'/') #edit vm hostname hostname_fn='hostname.jinja' try: template_hostname = JINJA.get_template(hostname_fn) except jinja2.exceptions.TemplateNotFound: return False hostname_context={'hostname':vm_name} hostname_content=template_hostname.render(**hostname_context) g.write('/etc/sysconfig/network',hostname_content) #edit vm mac mac_fn='mac.jinja' try: template_mac = JINJA.get_template(mac_fn) except jinja2.exceptions.TemplateNotFound: return False mac_context={'mac':vm_mac} mac_content=template_mac.render(**mac_context) g.write('/etc/udev/rules.d/70-persistent-net.rules',mac_content) #edit vm ip net_fn='net.jinja' try: template_net = JINJA.get_template(net_fn) except jinja2.exceptions.TemplateNotFound: return False net_context={'mac':vm_mac,'ip':vm_ip} net_content=template_net.render(**net_context) g.write('/etc/sysconfig/network-scripts/ifcfg-eth0',net_content) g.close() return True
修改init函數orm
for disk in diskp:
for disk_name, args in disk.items():
if disk_name=='system':
fn_ = '{0}.{1}'.format(disk_name, args['format'])
img_dest = os.path.join(
args['pool'],
name,
fn_
) #獲取系統鏡像文件
ip
if not _edit_vm(nicp,img_dest,name):
return False開發
修改_nic_profile函數:get
添加一段獲取ip的
vm_ip=kwargs.get('ip','192.168.x.41') #這樣,即可以在客戶端處獲取ip地址信息了.
再在生成mac下,添加:
attributes['ip'] = vm_ip
客戶端
#!/usr/bin/env python import salt.client local=salt.client.LocalClient() result=local.cmd('kvm.tc.com','virt.init',['web20','4','512','nic=nics','disk=system','ip=192.168.x.31']) print result
執行後,便會主動生成一個web20的虛擬機.
後期,經過Django開發一個web界面,即可以提交建立虛擬機嘍。
若是想了解更多,請關注咱們的公衆號
公衆號ID:opdevos
掃碼關注