Files
ubicloud/model/vm_pool.rb
Burak Velioglu ee586fc6cb Lock only the selected row instead of whole pool
While allocating a vm from a pool, whole vms of the
related pool were locked. This was causing unnecessary
lock and increasing the run time of the query. So, locking
the selected row instead to allow concurrent requests to
continue with the next unlocked tuple.
2024-12-20 11:18:51 +03:00

41 lines
1.1 KiB
Ruby

# frozen_string_literal: true
require_relative "../model"
class VmPool < Sequel::Model
one_to_one :strand, key: :id
one_to_many :vms, key: :pool_id
include ResourceMethods
include SemaphoreMethods
semaphore :destroy
def pick_vm
# Find an available VM in the "running" state and not associated with a GitHub runner,
# and lock it with FOR UPDATE SKIP LOCKED.
vms_dataset
.where(Sequel[:vm][:display_state] => "running")
.exclude(id: DB[:github_runner].exclude(vm_id: nil).select(:vm_id))
.for_update
.skip_locked
.first
end
end
# Table: vm_pool
# Columns:
# id | uuid | PRIMARY KEY
# size | integer | NOT NULL
# vm_size | text | NOT NULL
# boot_image | text | NOT NULL
# location | text | NOT NULL
# storage_size_gib | bigint | NOT NULL
# arch | arch | NOT NULL DEFAULT 'x64'::arch
# storage_encrypted | boolean | NOT NULL DEFAULT true
# storage_skip_sync | boolean | NOT NULL DEFAULT false
# Indexes:
# vm_pool_pkey | PRIMARY KEY btree (id)
# Referenced By:
# vm | vm_pool_id_fkey | (pool_id) REFERENCES vm_pool(id)