X-Git-Url: https://git.arvados.org/arvados.git/blobdiff_plain/469521bb7ea65a68f04a7595d3b6b10264026db6..745a7e253326a2b8e292dbd928c76320ce320216:/services/api/app/models/container.rb diff --git a/services/api/app/models/container.rb b/services/api/app/models/container.rb index 08f87bbdb1..21e8fcf508 100644 --- a/services/api/app/models/container.rb +++ b/services/api/app/models/container.rb @@ -83,6 +83,8 @@ class Container < ArvadosModel t.add :interactive_session_started t.add :output_storage_classes t.add :output_properties + t.add :cost + t.add :subrequests_cost end # Supported states for a container @@ -225,6 +227,12 @@ class Container < ArvadosModel if rc['keep_cache_ram'] == 0 rc['keep_cache_ram'] = Rails.configuration.Containers.DefaultKeepCacheRAM end + if rc['keep_cache_disk'] == 0 and rc['keep_cache_ram'] == 0 + # If neither ram nor disk cache was specified and + # DefaultKeepCacheRAM==0, default to disk cache with size equal + # to RAM constraint (but at least 2 GiB and at most 32 GiB). + rc['keep_cache_disk'] = [[rc['ram'] || 0, 2 << 30].max, 32 << 30].min + end rc end @@ -304,6 +312,15 @@ class Container < ArvadosModel # records that don't have a 'cuda' section in runtime_constraints resolved_runtime_constraints << resolved_runtime_constraints[0].except('cuda') end + if resolved_runtime_constraints[0]['keep_cache_disk'] == 0 + # If no disk cache requested, extend search to include older container + # records that don't have a 'keep_cache_disk' field in runtime_constraints + if resolved_runtime_constraints.length == 2 + # exclude the one that also excludes CUDA + resolved_runtime_constraints << resolved_runtime_constraints[1].except('keep_cache_disk') + end + resolved_runtime_constraints << resolved_runtime_constraints[0].except('keep_cache_disk') + end candidates = candidates.where_serialized(:runtime_constraints, resolved_runtime_constraints, md5: true, multivalue: true) log_reuse_info(candidates) { "after filtering on runtime_constraints #{attrs[:runtime_constraints].inspect}" } @@ -478,8 +495,9 @@ class Container < ArvadosModel def validate_change permitted = [:state] - progress_attrs = [:progress, :runtime_status, :log, :output, :output_properties, :exit_code] final_attrs = [:finished_at] + progress_attrs = [:progress, :runtime_status, :subrequests_cost, :cost, + :log, :output, :output_properties, :exit_code] if self.new_record? permitted.push(:owner_uuid, :command, :container_image, :cwd, @@ -498,9 +516,9 @@ class Container < ArvadosModel permitted.push :priority when Running - permitted.push :priority, :output_properties, *progress_attrs + permitted.push :priority, :output_properties, :gateway_address, *progress_attrs if self.state_changed? - permitted.push :started_at, :gateway_address + permitted.push :started_at end if !self.interactive_session_started_was permitted.push :interactive_session_started @@ -516,7 +534,7 @@ class Container < ArvadosModel when Running permitted.push :finished_at, *progress_attrs when Queued, Locked - permitted.push :finished_at, :log, :runtime_status + permitted.push :finished_at, :log, :runtime_status, :cost end else @@ -719,6 +737,7 @@ class Container < ArvadosModel cr.with_lock do leave_modified_by_user_alone do # Use row locking because this increments container_count + cr.cumulative_cost += self.cost + self.subrequests_cost cr.container_uuid = c.uuid cr.save! end