Class: Google::Apis::RunV1alpha1::Container

Inherits:
Object
  • Object
show all
Includes:
Core::Hashable, Core::JsonObjectSupport
Defined in:
lib/google/apis/run_v1alpha1/classes.rb,
lib/google/apis/run_v1alpha1/representations.rb,
lib/google/apis/run_v1alpha1/representations.rb

Overview

A single application container. This specifies both the container to run, the command to run in the container and the arguments to supply to it. Note that additional arguments may be supplied by the system to the container at runtime.

Instance Attribute Summary collapse

Instance Method Summary collapse

Constructor Details

#initialize(**args) ⇒ Container

Returns a new instance of Container.



290
291
292
# File 'lib/google/apis/run_v1alpha1/classes.rb', line 290

def initialize(**args)
   update!(**args)
end

Instance Attribute Details

#argsArray<String>

(Optional) Arguments to the entrypoint. The docker image's CMD is used if this is not provided. Variable references $(VAR_NAME) are expanded using the container's environment. If a variable cannot be resolved, the reference in the input string will be unchanged. The $(VAR_NAME) syntax can be escaped with a double $$, ie: $$(VAR_NAME). Escaped references will never be expanded, regardless of whether the variable exists or not. More info: https:// kubernetes.io/docs/tasks/inject-data-application/define-command-argument- container/#running-a-command-in-a-shell Corresponds to the JSON property args

Returns:

  • (Array<String>)


171
172
173
# File 'lib/google/apis/run_v1alpha1/classes.rb', line 171

def args
  @args
end

#commandArray<String>

Corresponds to the JSON property command

Returns:

  • (Array<String>)


176
177
178
# File 'lib/google/apis/run_v1alpha1/classes.rb', line 176

def command
  @command
end

#envArray<Google::Apis::RunV1alpha1::EnvVar>

(Optional) List of environment variables to set in the container. Corresponds to the JSON property env



181
182
183
# File 'lib/google/apis/run_v1alpha1/classes.rb', line 181

def env
  @env
end

#env_fromArray<Google::Apis::RunV1alpha1::EnvFromSource>

(Optional) List of sources to populate environment variables in the container. The keys defined within a source must be a C_IDENTIFIER. All invalid keys will be reported as an event when the container is starting. When a key exists in multiple sources, the value associated with the last source will take precedence. Values defined by an Env with a duplicate key will take precedence. Cannot be updated. Corresponds to the JSON property envFrom



191
192
193
# File 'lib/google/apis/run_v1alpha1/classes.rb', line 191

def env_from
  @env_from
end

#imageString

Only supports containers from Google Container Registry or Artifact Registry URL of the Container image. More info: https://kubernetes.io/docs/concepts/ containers/images Corresponds to the JSON property image

Returns:

  • (String)


198
199
200
# File 'lib/google/apis/run_v1alpha1/classes.rb', line 198

def image
  @image
end

#image_pull_policyString

(Optional) Image pull policy. One of Always, Never, IfNotPresent. Defaults to Always if :latest tag is specified, or IfNotPresent otherwise. More info: https://kubernetes.io/docs/concepts/containers/images#updating-images Corresponds to the JSON property imagePullPolicy

Returns:

  • (String)


205
206
207
# File 'lib/google/apis/run_v1alpha1/classes.rb', line 205

def image_pull_policy
  @image_pull_policy
end

#liveness_probeGoogle::Apis::RunV1alpha1::Probe

Not supported by Cloud Run Probe describes a health check to be performed against a container to determine whether it is alive or ready to receive traffic. Corresponds to the JSON property livenessProbe



212
213
214
# File 'lib/google/apis/run_v1alpha1/classes.rb', line 212

def liveness_probe
  @liveness_probe
end

#nameString

(Optional) Name of the container specified as a DNS_LABEL. Currently unused in Cloud Run. More info: https://kubernetes.io/docs/concepts/overview/working- with-objects/names/#dns-label-names Corresponds to the JSON property name

Returns:

  • (String)


219
220
221
# File 'lib/google/apis/run_v1alpha1/classes.rb', line 219

def name
  @name
end

#portsArray<Google::Apis::RunV1alpha1::ContainerPort>

(Optional) List of ports to expose from the container. Only a single port can be specified. The specified ports must be listening on all interfaces (0.0.0.0) within the container to be accessible. If omitted, a port number will be chosen and passed to the container through the PORT environment variable for the container to listen on. Corresponds to the JSON property ports



228
229
230
# File 'lib/google/apis/run_v1alpha1/classes.rb', line 228

def ports
  @ports
end

#readiness_probeGoogle::Apis::RunV1alpha1::Probe

Not supported by Cloud Run Probe describes a health check to be performed against a container to determine whether it is alive or ready to receive traffic. Corresponds to the JSON property readinessProbe



235
236
237
# File 'lib/google/apis/run_v1alpha1/classes.rb', line 235

def readiness_probe
  @readiness_probe
end

#resourcesGoogle::Apis::RunV1alpha1::ResourceRequirements

ResourceRequirements describes the compute resource requirements. Corresponds to the JSON property resources



240
241
242
# File 'lib/google/apis/run_v1alpha1/classes.rb', line 240

def resources
  @resources
end

#security_contextGoogle::Apis::RunV1alpha1::SecurityContext

Not supported by Cloud Run SecurityContext holds security configuration that will be applied to a container. Some fields are present in both SecurityContext and PodSecurityContext. When both are set, the values in SecurityContext take precedence. Corresponds to the JSON property securityContext



248
249
250
# File 'lib/google/apis/run_v1alpha1/classes.rb', line 248

def security_context
  @security_context
end

#startup_probeGoogle::Apis::RunV1alpha1::Probe

Not supported by Cloud Run Probe describes a health check to be performed against a container to determine whether it is alive or ready to receive traffic. Corresponds to the JSON property startupProbe



255
256
257
# File 'lib/google/apis/run_v1alpha1/classes.rb', line 255

def startup_probe
  @startup_probe
end

#termination_message_pathString

(Optional) Path at which the file to which the container's termination message will be written is mounted into the container's filesystem. Message written is intended to be brief final status, such as an assertion failure message. Will be truncated by the node if greater than 4096 bytes. The total message length across all containers will be limited to 12kb. Defaults to /dev/termination- log. Corresponds to the JSON property terminationMessagePath

Returns:

  • (String)


265
266
267
# File 'lib/google/apis/run_v1alpha1/classes.rb', line 265

def termination_message_path
  @termination_message_path
end

#termination_message_policyString

(Optional) Indicate how the termination message should be populated. File will use the contents of terminationMessagePath to populate the container status message on both success and failure. FallbackToLogsOnError will use the last chunk of container log output if the termination message file is empty and the container exited with an error. The log output is limited to 2048 bytes or 80 lines, whichever is smaller. Defaults to File. Cannot be updated. Corresponds to the JSON property terminationMessagePolicy

Returns:

  • (String)


275
276
277
# File 'lib/google/apis/run_v1alpha1/classes.rb', line 275

def termination_message_policy
  @termination_message_policy
end

#volume_mountsArray<Google::Apis::RunV1alpha1::VolumeMount>

(Optional) Volume to mount into the container's filesystem. Only supports SecretVolumeSources. Pod volumes to mount into the container's filesystem. Corresponds to the JSON property volumeMounts



281
282
283
# File 'lib/google/apis/run_v1alpha1/classes.rb', line 281

def volume_mounts
  @volume_mounts
end

#working_dirString

(Optional) Container's working directory. If not specified, the container runtime's default will be used, which might be configured in the container image. Corresponds to the JSON property workingDir

Returns:

  • (String)


288
289
290
# File 'lib/google/apis/run_v1alpha1/classes.rb', line 288

def working_dir
  @working_dir
end

Instance Method Details

#update!(**args) ⇒ Object

Update properties of this object



295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
# File 'lib/google/apis/run_v1alpha1/classes.rb', line 295

def update!(**args)
  @args = args[:args] if args.key?(:args)
  @command = args[:command] if args.key?(:command)
  @env = args[:env] if args.key?(:env)
  @env_from = args[:env_from] if args.key?(:env_from)
  @image = args[:image] if args.key?(:image)
  @image_pull_policy = args[:image_pull_policy] if args.key?(:image_pull_policy)
  @liveness_probe = args[:liveness_probe] if args.key?(:liveness_probe)
  @name = args[:name] if args.key?(:name)
  @ports = args[:ports] if args.key?(:ports)
  @readiness_probe = args[:readiness_probe] if args.key?(:readiness_probe)
  @resources = args[:resources] if args.key?(:resources)
  @security_context = args[:security_context] if args.key?(:security_context)
  @startup_probe = args[:startup_probe] if args.key?(:startup_probe)
  @termination_message_path = args[:termination_message_path] if args.key?(:termination_message_path)
  @termination_message_policy = args[:termination_message_policy] if args.key?(:termination_message_policy)
  @volume_mounts = args[:volume_mounts] if args.key?(:volume_mounts)
  @working_dir = args[:working_dir] if args.key?(:working_dir)
end