# frozen_string_literal: true # Copyright 2022 Google LLC # # 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 # # https://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. # Auto-generated by gapic-generator-ruby. DO NOT EDIT! module Google module Cloud module Batch module V1 # The Cloud Batch Job description. # @!attribute [r] name # @return [::String] # Output only. Job name. # For example: "projects/123456/locations/us-central1/jobs/job01". # @!attribute [r] uid # @return [::String] # Output only. A system generated unique ID (in UUID4 format) for the Job. # @!attribute [rw] priority # @return [::Integer] # Priority of the Job. # The valid value range is [0, 100). Default value is 0. # Higher value indicates higher priority. # A job with higher priority value is more likely to run earlier if all other # requirements are satisfied. # @!attribute [rw] task_groups # @return [::Array<::Google::Cloud::Batch::V1::TaskGroup>] # Required. TaskGroups in the Job. Only one TaskGroup is supported now. # @!attribute [rw] allocation_policy # @return [::Google::Cloud::Batch::V1::AllocationPolicy] # Compute resource allocation for all TaskGroups in the Job. # @!attribute [rw] labels # @return [::Google::Protobuf::Map{::String => ::String}] # Labels for the Job. Labels could be user provided or system generated. # For example, # "labels": { # "department": "finance", # "environment": "test" # } # You can assign up to 64 labels. [Google Compute Engine label # restrictions](https://cloud.google.com/compute/docs/labeling-resources#restrictions) # apply. # Label names that start with "goog-" or "google-" are reserved. # @!attribute [r] status # @return [::Google::Cloud::Batch::V1::JobStatus] # Output only. Job status. It is read only for users. # @!attribute [r] create_time # @return [::Google::Protobuf::Timestamp] # Output only. When the Job was created. # @!attribute [r] update_time # @return [::Google::Protobuf::Timestamp] # Output only. The last time the Job was updated. # @!attribute [rw] logs_policy # @return [::Google::Cloud::Batch::V1::LogsPolicy] # Log preservation policy for the Job. # @!attribute [rw] notifications # @return [::Array<::Google::Cloud::Batch::V1::JobNotification>] # Notification configurations. class Job include ::Google::Protobuf::MessageExts extend ::Google::Protobuf::MessageExts::ClassMethods # @!attribute [rw] key # @return [::String] # @!attribute [rw] value # @return [::String] class LabelsEntry include ::Google::Protobuf::MessageExts extend ::Google::Protobuf::MessageExts::ClassMethods end end # LogsPolicy describes how outputs from a Job's Tasks (stdout/stderr) will be # preserved. # @!attribute [rw] destination # @return [::Google::Cloud::Batch::V1::LogsPolicy::Destination] # Where logs should be saved. # @!attribute [rw] logs_path # @return [::String] # The path to which logs are saved when the destination = PATH. This can be a # local file path on the VM, or under the mount point of a Persistent Disk or # Filestore, or a Cloud Storage path. class LogsPolicy include ::Google::Protobuf::MessageExts extend ::Google::Protobuf::MessageExts::ClassMethods # The destination (if any) for logs. module Destination # Logs are not preserved. DESTINATION_UNSPECIFIED = 0 # Logs are streamed to Cloud Logging. CLOUD_LOGGING = 1 # Logs are saved to a file path. PATH = 2 end end # Job status. # @!attribute [rw] state # @return [::Google::Cloud::Batch::V1::JobStatus::State] # Job state # @!attribute [rw] status_events # @return [::Array<::Google::Cloud::Batch::V1::StatusEvent>] # Job status events # @!attribute [rw] task_groups # @return [::Google::Protobuf::Map{::String => ::Google::Cloud::Batch::V1::JobStatus::TaskGroupStatus}] # Aggregated task status for each TaskGroup in the Job. # The map key is TaskGroup ID. # @!attribute [rw] run_duration # @return [::Google::Protobuf::Duration] # The duration of time that the Job spent in status RUNNING. class JobStatus include ::Google::Protobuf::MessageExts extend ::Google::Protobuf::MessageExts::ClassMethods # VM instance status. # @!attribute [rw] machine_type # @return [::String] # The Compute Engine machine type. # @!attribute [rw] provisioning_model # @return [::Google::Cloud::Batch::V1::AllocationPolicy::ProvisioningModel] # The VM instance provisioning model. # @!attribute [rw] task_pack # @return [::Integer] # The max number of tasks can be assigned to this instance type. # @!attribute [rw] boot_disk # @return [::Google::Cloud::Batch::V1::AllocationPolicy::Disk] # The VM boot disk. class InstanceStatus include ::Google::Protobuf::MessageExts extend ::Google::Protobuf::MessageExts::ClassMethods end # Aggregated task status for a TaskGroup. # @!attribute [rw] counts # @return [::Google::Protobuf::Map{::String => ::Integer}] # Count of task in each state in the TaskGroup. # The map key is task state name. # @!attribute [rw] instances # @return [::Array<::Google::Cloud::Batch::V1::JobStatus::InstanceStatus>] # Status of instances allocated for the TaskGroup. class TaskGroupStatus include ::Google::Protobuf::MessageExts extend ::Google::Protobuf::MessageExts::ClassMethods # @!attribute [rw] key # @return [::String] # @!attribute [rw] value # @return [::Integer] class CountsEntry include ::Google::Protobuf::MessageExts extend ::Google::Protobuf::MessageExts::ClassMethods end end # @!attribute [rw] key # @return [::String] # @!attribute [rw] value # @return [::Google::Cloud::Batch::V1::JobStatus::TaskGroupStatus] class TaskGroupsEntry include ::Google::Protobuf::MessageExts extend ::Google::Protobuf::MessageExts::ClassMethods end # Valid Job states. module State # Job state unspecified. STATE_UNSPECIFIED = 0 # Job is admitted (validated and persisted) and waiting for resources. QUEUED = 1 # Job is scheduled to run as soon as resource allocation is ready. # The resource allocation may happen at a later time but with a high # chance to succeed. SCHEDULED = 2 # Resource allocation has been successful. At least one Task in the Job is # RUNNING. RUNNING = 3 # All Tasks in the Job have finished successfully. SUCCEEDED = 4 # At least one Task in the Job has failed. FAILED = 5 # The Job will be deleted, but has not been deleted yet. Typically this is # because resources used by the Job are still being cleaned up. DELETION_IN_PROGRESS = 6 end end # Notification configurations. # @!attribute [rw] pubsub_topic # @return [::String] # The Pub/Sub topic where notifications like the job state changes # will be published. The topic must exist in the same project as # the job and billings will be charged to this project. # If not specified, no Pub/Sub messages will be sent. # Topic format: `projects/{project}/topics/{topic}`. # @!attribute [rw] message # @return [::Google::Cloud::Batch::V1::JobNotification::Message] # The attribute requirements of messages to be sent to this Pub/Sub topic. # Without this field, no message will be sent. class JobNotification include ::Google::Protobuf::MessageExts extend ::Google::Protobuf::MessageExts::ClassMethods # Message details. # Describe the conditions under which messages will be sent. # If no attribute is defined, no message will be sent by default. # One message should specify either the job or the task level attributes, # but not both. For example, # job level: JOB_STATE_CHANGED and/or a specified new_job_state; # task level: TASK_STATE_CHANGED and/or a specified new_task_state. # @!attribute [rw] type # @return [::Google::Cloud::Batch::V1::JobNotification::Type] # The message type. # @!attribute [rw] new_job_state # @return [::Google::Cloud::Batch::V1::JobStatus::State] # The new job state. # @!attribute [rw] new_task_state # @return [::Google::Cloud::Batch::V1::TaskStatus::State] # The new task state. class Message include ::Google::Protobuf::MessageExts extend ::Google::Protobuf::MessageExts::ClassMethods end # The message type. module Type # Unspecified. TYPE_UNSPECIFIED = 0 # Notify users that the job state has changed. JOB_STATE_CHANGED = 1 # Notify users that the task state has changed. TASK_STATE_CHANGED = 2 end end # A Job's resource allocation policy describes when, where, and how compute # resources should be allocated for the Job. # @!attribute [rw] location # @return [::Google::Cloud::Batch::V1::AllocationPolicy::LocationPolicy] # Location where compute resources should be allocated for the Job. # @!attribute [rw] instances # @return [::Array<::Google::Cloud::Batch::V1::AllocationPolicy::InstancePolicyOrTemplate>] # Describe instances that can be created by this AllocationPolicy. # Only instances[0] is supported now. # @!attribute [rw] service_account # @return [::Google::Cloud::Batch::V1::ServiceAccount] # Service account that VMs will run as. # @!attribute [rw] labels # @return [::Google::Protobuf::Map{::String => ::String}] # Labels applied to all VM instances and other resources # created by AllocationPolicy. # Labels could be user provided or system generated. # You can assign up to 64 labels. [Google Compute Engine label # restrictions](https://cloud.google.com/compute/docs/labeling-resources#restrictions) # apply. # Label names that start with "goog-" or "google-" are reserved. # @!attribute [rw] network # @return [::Google::Cloud::Batch::V1::AllocationPolicy::NetworkPolicy] # The network policy. # @!attribute [rw] placement # @return [::Google::Cloud::Batch::V1::AllocationPolicy::PlacementPolicy] # The placement policy. class AllocationPolicy include ::Google::Protobuf::MessageExts extend ::Google::Protobuf::MessageExts::ClassMethods # @!attribute [rw] allowed_locations # @return [::Array<::String>] # A list of allowed location names represented by internal URLs. # # Each location can be a region or a zone. # Only one region or multiple zones in one region is supported now. # For example, # ["regions/us-central1"] allow VMs in any zones in region us-central1. # ["zones/us-central1-a", "zones/us-central1-c"] only allow VMs # in zones us-central1-a and us-central1-c. # # All locations end up in different regions would cause errors. # For example, # ["regions/us-central1", "zones/us-central1-a", "zones/us-central1-b", # "zones/us-west1-a"] contains 2 regions "us-central1" and # "us-west1". An error is expected in this case. class LocationPolicy include ::Google::Protobuf::MessageExts extend ::Google::Protobuf::MessageExts::ClassMethods end # A new persistent disk or a local ssd. # A VM can only have one local SSD setting but multiple local SSD partitions. # See https://cloud.google.com/compute/docs/disks#pdspecs and # https://cloud.google.com/compute/docs/disks#localssds. # @!attribute [rw] image # @return [::String] # URL for a VM image to use as the data source for this disk. # For example, the following are all valid URLs: # # * Specify the image by its family name: # projects/\\{project}/global/images/family/\\{image_family} # * Specify the image version: # projects/\\{project}/global/images/\\{image_version} # # You can also use Batch customized image in short names. # The following image values are supported for a boot disk: # # * `batch-debian`: use Batch Debian images. # * `batch-centos`: use Batch CentOS images. # * `batch-cos`: use Batch Container-Optimized images. # * `batch-hpc-centos`: use Batch HPC CentOS images. # * `batch-hpc-rocky`: use Batch HPC Rocky Linux images. # @!attribute [rw] snapshot # @return [::String] # Name of a snapshot used as the data source. # Snapshot is not supported as boot disk now. # @!attribute [rw] type # @return [::String] # Disk type as shown in `gcloud compute disk-types list`. # For example, local SSD uses type "local-ssd". # Persistent disks and boot disks use "pd-balanced", "pd-extreme", "pd-ssd" # or "pd-standard". # @!attribute [rw] size_gb # @return [::Integer] # Disk size in GB. # # **Non-Boot Disk**: # If the `type` specifies a persistent disk, this field # is ignored if `data_source` is set as `image` or `snapshot`. # If the `type` specifies a local SSD, this field should be a multiple of # 375 GB, otherwise, the final size will be the next greater multiple of # 375 GB. # # **Boot Disk**: # Batch will calculate the boot disk size based on source # image and task requirements if you do not speicify the size. # If both this field and the `boot_disk_mib` field in task spec's # `compute_resource` are defined, Batch will only honor this field. # Also, this field should be no smaller than the source disk's # size when the `data_source` is set as `snapshot` or `image`. # For example, if you set an image as the `data_source` field and the # image's default disk size 30 GB, you can only use this field to make the # disk larger or equal to 30 GB. # @!attribute [rw] disk_interface # @return [::String] # Local SSDs are available through both "SCSI" and "NVMe" interfaces. # If not indicated, "NVMe" will be the default one for local ssds. # This field is ignored for persistent disks as the interface is chosen # automatically. See # https://cloud.google.com/compute/docs/disks/persistent-disks#choose_an_interface. class Disk include ::Google::Protobuf::MessageExts extend ::Google::Protobuf::MessageExts::ClassMethods end # A new or an existing persistent disk (PD) or a local ssd attached to a VM # instance. # @!attribute [rw] new_disk # @return [::Google::Cloud::Batch::V1::AllocationPolicy::Disk] # @!attribute [rw] existing_disk # @return [::String] # Name of an existing PD. # @!attribute [rw] device_name # @return [::String] # Device name that the guest operating system will see. # It is used by Runnable.volumes field to mount disks. So please specify # the device_name if you want Batch to help mount the disk, and it should # match the device_name field in volumes. class AttachedDisk include ::Google::Protobuf::MessageExts extend ::Google::Protobuf::MessageExts::ClassMethods end # Accelerator describes Compute Engine accelerators to be attached to the VM. # @!attribute [rw] type # @return [::String] # The accelerator type. For example, "nvidia-tesla-t4". # See `gcloud compute accelerator-types list`. # @!attribute [rw] count # @return [::Integer] # The number of accelerators of this type. # @!attribute [rw] install_gpu_drivers # @return [::Boolean] # Deprecated: please use instances[0].install_gpu_drivers instead. # @!attribute [rw] driver_version # @return [::String] # Optional. The NVIDIA GPU driver version that should be installed for this # type. # # You can define the specific driver version such as "470.103.01", # following the driver version requirements in # https://cloud.google.com/compute/docs/gpus/install-drivers-gpu#minimum-driver. # Batch will install the specific accelerator driver if qualified. class Accelerator include ::Google::Protobuf::MessageExts extend ::Google::Protobuf::MessageExts::ClassMethods end # InstancePolicy describes an instance type and resources attached to each VM # created by this InstancePolicy. # @!attribute [rw] machine_type # @return [::String] # The Compute Engine machine type. # @!attribute [rw] min_cpu_platform # @return [::String] # The minimum CPU platform. # See # https://cloud.google.com/compute/docs/instances/specify-min-cpu-platform. # @!attribute [rw] provisioning_model # @return [::Google::Cloud::Batch::V1::AllocationPolicy::ProvisioningModel] # The provisioning model. # @!attribute [rw] accelerators # @return [::Array<::Google::Cloud::Batch::V1::AllocationPolicy::Accelerator>] # The accelerators attached to each VM instance. # @!attribute [rw] boot_disk # @return [::Google::Cloud::Batch::V1::AllocationPolicy::Disk] # Boot disk to be created and attached to each VM by this InstancePolicy. # Boot disk will be deleted when the VM is deleted. # Batch API now only supports booting from image. # @!attribute [rw] disks # @return [::Array<::Google::Cloud::Batch::V1::AllocationPolicy::AttachedDisk>] # Non-boot disks to be attached for each VM created by this InstancePolicy. # New disks will be deleted when the VM is deleted. # A non-boot disk is a disk that can be of a device with a # file system or a raw storage drive that is not ready for data # storage and accessing. # @!attribute [rw] reservation # @return [::String] # Optional. If specified, VMs will consume only the specified reservation. # If not specified (default), VMs will consume any applicable reservation. class InstancePolicy include ::Google::Protobuf::MessageExts extend ::Google::Protobuf::MessageExts::ClassMethods end # InstancePolicyOrTemplate lets you define the type of resources to use for # this job either with an InstancePolicy or an instance template. # If undefined, Batch picks the type of VM to use and doesn't include # optional VM resources such as GPUs and extra disks. # @!attribute [rw] policy # @return [::Google::Cloud::Batch::V1::AllocationPolicy::InstancePolicy] # InstancePolicy. # @!attribute [rw] instance_template # @return [::String] # Name of an instance template used to create VMs. # Named the field as 'instance_template' instead of 'template' to avoid # c++ keyword conflict. # @!attribute [rw] install_gpu_drivers # @return [::Boolean] # Set this field true if users want Batch to help fetch drivers from a # third party location and install them for GPUs specified in # policy.accelerators or instance_template on their behalf. Default is # false. # # For Container-Optimized Image cases, Batch will install the # accelerator driver following milestones of # https://cloud.google.com/container-optimized-os/docs/release-notes. For # non Container-Optimized Image cases, following # https://github.com/GoogleCloudPlatform/compute-gpu-installation/blob/main/linux/install_gpu_driver.py. class InstancePolicyOrTemplate include ::Google::Protobuf::MessageExts extend ::Google::Protobuf::MessageExts::ClassMethods end # A network interface. # @!attribute [rw] network # @return [::String] # The URL of an existing network resource. # You can specify the network as a full or partial URL. # # For example, the following are all valid URLs: # # * https://www.googleapis.com/compute/v1/projects/\\{project}/global/networks/\\{network} # * projects/\\{project}/global/networks/\\{network} # * global/networks/\\{network} # @!attribute [rw] subnetwork # @return [::String] # The URL of an existing subnetwork resource in the network. # You can specify the subnetwork as a full or partial URL. # # For example, the following are all valid URLs: # # * https://www.googleapis.com/compute/v1/projects/\\{project}/regions/\\{region}/subnetworks/\\{subnetwork} # * projects/\\{project}/regions/\\{region}/subnetworks/\\{subnetwork} # * regions/\\{region}/subnetworks/\\{subnetwork} # @!attribute [rw] no_external_ip_address # @return [::Boolean] # Default is false (with an external IP address). Required if # no external public IP address is attached to the VM. If no external # public IP address, additional configuration is required to allow the VM # to access Google Services. See # https://cloud.google.com/vpc/docs/configure-private-google-access and # https://cloud.google.com/nat/docs/gce-example#create-nat for more # information. class NetworkInterface include ::Google::Protobuf::MessageExts extend ::Google::Protobuf::MessageExts::ClassMethods end # NetworkPolicy describes VM instance network configurations. # @!attribute [rw] network_interfaces # @return [::Array<::Google::Cloud::Batch::V1::AllocationPolicy::NetworkInterface>] # Network configurations. class NetworkPolicy include ::Google::Protobuf::MessageExts extend ::Google::Protobuf::MessageExts::ClassMethods end # PlacementPolicy describes a group placement policy for the VMs controlled # by this AllocationPolicy. # @!attribute [rw] collocation # @return [::String] # UNSPECIFIED vs. COLLOCATED (default UNSPECIFIED). Use COLLOCATED when you # want VMs to be located close to each other for low network latency # between the VMs. No placement policy will be generated when collocation # is UNSPECIFIED. # @!attribute [rw] max_distance # @return [::Integer] # When specified, causes the job to fail if more than max_distance logical # switches are required between VMs. Batch uses the most compact possible # placement of VMs even when max_distance is not specified. An explicit # max_distance makes that level of compactness a strict requirement. # Not yet implemented class PlacementPolicy include ::Google::Protobuf::MessageExts extend ::Google::Protobuf::MessageExts::ClassMethods end # @!attribute [rw] key # @return [::String] # @!attribute [rw] value # @return [::String] class LabelsEntry include ::Google::Protobuf::MessageExts extend ::Google::Protobuf::MessageExts::ClassMethods end # Compute Engine VM instance provisioning model. module ProvisioningModel # Unspecified. PROVISIONING_MODEL_UNSPECIFIED = 0 # Standard VM. STANDARD = 1 # SPOT VM. SPOT = 2 # Preemptible VM (PVM). # # Above SPOT VM is the preferable model for preemptible VM instances: the # old preemptible VM model (indicated by this field) is the older model, # and has been migrated to use the SPOT model as the underlying technology. # This old model will still be supported. PREEMPTIBLE = 3 end end # A TaskGroup defines one or more Tasks that all share the same TaskSpec. # @!attribute [r] name # @return [::String] # Output only. TaskGroup name. # The system generates this field based on parent Job name. # For example: # "projects/123456/locations/us-west1/jobs/job01/taskGroups/group01". # @!attribute [rw] task_spec # @return [::Google::Cloud::Batch::V1::TaskSpec] # Required. Tasks in the group share the same task spec. # @!attribute [rw] task_count # @return [::Integer] # Number of Tasks in the TaskGroup. # Default is 1. # @!attribute [rw] parallelism # @return [::Integer] # Max number of tasks that can run in parallel. # Default to min(task_count, parallel tasks per job limit). # See: [Job Limits](https://cloud.google.com/batch/quotas#job_limits). # Field parallelism must be 1 if the scheduling_policy is IN_ORDER. # @!attribute [rw] scheduling_policy # @return [::Google::Cloud::Batch::V1::TaskGroup::SchedulingPolicy] # Scheduling policy for Tasks in the TaskGroup. # The default value is AS_SOON_AS_POSSIBLE. # @!attribute [rw] task_environments # @return [::Array<::Google::Cloud::Batch::V1::Environment>] # An array of environment variable mappings, which are passed to Tasks with # matching indices. If task_environments is used then task_count should # not be specified in the request (and will be ignored). Task count will be # the length of task_environments. # # Tasks get a BATCH_TASK_INDEX and BATCH_TASK_COUNT environment variable, in # addition to any environment variables set in task_environments, specifying # the number of Tasks in the Task's parent TaskGroup, and the specific Task's # index in the TaskGroup (0 through BATCH_TASK_COUNT - 1). # @!attribute [rw] task_count_per_node # @return [::Integer] # Max number of tasks that can be run on a VM at the same time. # If not specified, the system will decide a value based on available # compute resources on a VM and task requirements. # @!attribute [rw] require_hosts_file # @return [::Boolean] # When true, Batch will populate a file with a list of all VMs assigned to # the TaskGroup and set the BATCH_HOSTS_FILE environment variable to the path # of that file. Defaults to false. # @!attribute [rw] permissive_ssh # @return [::Boolean] # When true, Batch will configure SSH to allow passwordless login between # VMs running the Batch tasks in the same TaskGroup. class TaskGroup include ::Google::Protobuf::MessageExts extend ::Google::Protobuf::MessageExts::ClassMethods # How Tasks in the TaskGroup should be scheduled relative to each other. module SchedulingPolicy # Unspecified. SCHEDULING_POLICY_UNSPECIFIED = 0 # Run Tasks as soon as resources are available. # # Tasks might be executed in parallel depending on parallelism and # task_count values. AS_SOON_AS_POSSIBLE = 1 # Run Tasks sequentially with increased task index. IN_ORDER = 2 end end # Carries information about a Google Cloud service account. # @!attribute [rw] email # @return [::String] # Email address of the service account. If not specified, the default # Compute Engine service account for the project will be used. If instance # template is being used, the service account has to be specified in the # instance template and it has to match the email field here. # @!attribute [rw] scopes # @return [::Array<::String>] # List of scopes to be enabled for this service account on the VM, in # addition to the cloud-platform API scope that will be added by default. class ServiceAccount include ::Google::Protobuf::MessageExts extend ::Google::Protobuf::MessageExts::ClassMethods end end end end end