mirror of
https://github.com/puppetlabs/vmpooler.git
synced 2026-01-26 10:08:40 -05:00
Futzing with pooler queue logic
This commit is contained in:
parent
3ca6cdf418
commit
26aa06e6fa
1 changed files with 33 additions and 23 deletions
|
|
@ -50,7 +50,8 @@ loop do
|
||||||
(! $redis.sismember('vmware_host_pool__pending__'+pool['name'], vm['name'])) and
|
(! $redis.sismember('vmware_host_pool__pending__'+pool['name'], vm['name'])) and
|
||||||
(! $redis.sismember('vmware_host_pool__ready__'+pool['name'], vm['name'])) and
|
(! $redis.sismember('vmware_host_pool__ready__'+pool['name'], vm['name'])) and
|
||||||
(! $redis.sismember('vmware_host_pool__running__'+pool['name'], vm['name'])) and
|
(! $redis.sismember('vmware_host_pool__running__'+pool['name'], vm['name'])) and
|
||||||
(! $redis.sismember('vmware_host_pool__completed__'+pool['name'], vm['name']))
|
(! $redis.sismember('vmware_host_pool__completed__'+pool['name'], vm['name'])) and
|
||||||
|
(! $redis.sismember('vmware_host_pool__failed__'+pool['name'], vm['name']))
|
||||||
)
|
)
|
||||||
$redis.sadd('vmware_host_pool__pending__'+pool['name'], vm['name'])
|
$redis.sadd('vmware_host_pool__pending__'+pool['name'], vm['name'])
|
||||||
end
|
end
|
||||||
|
|
@ -70,6 +71,8 @@ loop do
|
||||||
(vsphere_helper.find_vms(vm)[vm].summary.guest.toolsRunningStatus == 'guestToolsRunning') and
|
(vsphere_helper.find_vms(vm)[vm].summary.guest.toolsRunningStatus == 'guestToolsRunning') and
|
||||||
(vsphere_helper.find_vms(vm)[vm].summary.guest.ipAddress != nil)
|
(vsphere_helper.find_vms(vm)[vm].summary.guest.ipAddress != nil)
|
||||||
)
|
)
|
||||||
|
if (vsphere_helper.find_vms(vm)[vm].summary.guest.hostName)
|
||||||
|
if (vsphere_helper.find_vms(vm)[vm].summary.guest.hostName == vm)
|
||||||
begin
|
begin
|
||||||
Socket.getaddrinfo(vm, nil)
|
Socket.getaddrinfo(vm, nil)
|
||||||
rescue
|
rescue
|
||||||
|
|
@ -80,6 +83,12 @@ loop do
|
||||||
$redis.srem('vmware_host_pool__pending__'+pool['name'], vm)
|
$redis.srem('vmware_host_pool__pending__'+pool['name'], vm)
|
||||||
|
|
||||||
logger.log('s', "[>] '#{vm}' moved to 'ready' queue")
|
logger.log('s', "[>] '#{vm}' moved to 'ready' queue")
|
||||||
|
else
|
||||||
|
$redis.srem('vmware_host_pool__pending__'+pool['name'], vm)
|
||||||
|
$redis.sadd('vmware_host_pool__failed__'+pool['name'], vm)
|
||||||
|
|
||||||
|
logger.log('s', "[<] '#{vm}' moved to 'failed' queue")
|
||||||
|
end
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
|
|
@ -148,6 +157,7 @@ loop do
|
||||||
if (
|
if (
|
||||||
(vsphere_helper.find_vms(vm)[vm]) and
|
(vsphere_helper.find_vms(vm)[vm]) and
|
||||||
(vsphere_helper.find_vms(vm)[vm].summary.guest.toolsRunningStatus == 'guestToolsRunning') and
|
(vsphere_helper.find_vms(vm)[vm].summary.guest.toolsRunningStatus == 'guestToolsRunning') and
|
||||||
|
(vsphere_helper.find_vms(vm)[vm].summary.guest.hostName == vm) and
|
||||||
(vsphere_helper.find_vms(vm)[vm].summary.guest.ipAddress != nil)
|
(vsphere_helper.find_vms(vm)[vm].summary.guest.ipAddress != nil)
|
||||||
)
|
)
|
||||||
begin
|
begin
|
||||||
|
|
@ -160,25 +170,25 @@ loop do
|
||||||
$redis.srem('vmware_host_pool__failed__'+pool['name'], vm)
|
$redis.srem('vmware_host_pool__failed__'+pool['name'], vm)
|
||||||
|
|
||||||
logger.log('s', "[>] '#{vm}' moved to 'ready' queue")
|
logger.log('s', "[>] '#{vm}' moved to 'ready' queue")
|
||||||
end
|
else
|
||||||
|
|
||||||
if (
|
if (
|
||||||
(vsphere_helper.find_vms(vm)[vm]) and
|
(vsphere_helper.find_vms(vm)[vm]) and
|
||||||
(vsphere_helper.find_vms(vm)[vm].runtime)
|
(vsphere_helper.find_vms(vm)[vm].runtime)
|
||||||
)
|
)
|
||||||
start = Time.now
|
start = Time.now
|
||||||
|
|
||||||
if host.runtime.powerState == 'poweredOn'
|
if vsphere_helper.find_vms(vm)[vm].runtime.powerState == 'poweredOn'
|
||||||
logger.log('d', "[ ] '#{vm}' is being shut down")
|
logger.log('d', "[ ] '#{vm}' is being shut down")
|
||||||
host.PowerOffVM_Task.wait_for_completion
|
vsphere_helper.find_vms(vm)[vm].PowerOffVM_Task.wait_for_completion
|
||||||
end
|
end
|
||||||
|
|
||||||
host.Destroy_Task.wait_for_completion
|
vsphere_helper.find_vms(vm)[vm].Destroy_Task.wait_for_completion
|
||||||
finish = '%.2f' % (Time.now-start)
|
finish = '%.2f' % (Time.now-start)
|
||||||
|
|
||||||
logger.log('s', "[-] '#{vm}' destroyed in #{finish} seconds")
|
logger.log('s', "[-] '#{vm}' destroyed in #{finish} seconds")
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
end
|
||||||
|
|
||||||
# Bring the pool up to the desired size
|
# Bring the pool up to the desired size
|
||||||
if total < pool['size']
|
if total < pool['size']
|
||||||
|
|
|
||||||
Loading…
Add table
Add a link
Reference in a new issue