All Downloads are FREE. Search and download functionalities are using the official Maven repository.

com.google.api.services.run.v1.model.Container Maven / Gradle / Ivy

There is a newer version: v2-rev20241213-2.0.0
Show newest version
/*
 * 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
 *
 * http://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.
 */
/*
 * This code was generated by https://github.com/googleapis/google-api-java-client-services/
 * Modify at your own risk.
 */

package com.google.api.services.run.v1.model;

/**
 * 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.
 *
 * 

This is the Java data model class that specifies how to parse/serialize into the JSON that is * transmitted over HTTP when working with the Cloud Run Admin API. For a detailed explanation see: * https://developers.google.com/api-client-library/java/google-http-java-client/json *

* * @author Google, Inc. */ @SuppressWarnings("javadoc") public final class Container extends com.google.api.client.json.GenericJson { /** * Arguments to the entrypoint. The docker image's CMD is used if this is not provided. Variable * references are not supported in Cloud Run. * The value may be {@code null}. */ @com.google.api.client.util.Key private java.util.List args; /** * Entrypoint array. Not executed within a shell. The docker image's ENTRYPOINT is used if this is * not provided. Variable references are not supported in Cloud Run. * The value may be {@code null}. */ @com.google.api.client.util.Key private java.util.List command; /** * List of environment variables to set in the container. * The value may be {@code null}. */ @com.google.api.client.util.Key private java.util.List env; /** * Not supported by Cloud Run. * The value may be {@code null}. */ @com.google.api.client.util.Key private java.util.List envFrom; /** * Required. URL of the Container image in Google Container Registry or Google Artifact Registry. * More info: https://kubernetes.io/docs/concepts/containers/images * The value may be {@code null}. */ @com.google.api.client.util.Key private java.lang.String image; /** * 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 * The value may be {@code null}. */ @com.google.api.client.util.Key private java.lang.String imagePullPolicy; /** * Periodic probe of container liveness. Container will be restarted if the probe fails. More * info: https://kubernetes.io/docs/concepts/workloads/pods/pod-lifecycle#container-probes * The value may be {@code null}. */ @com.google.api.client.util.Key private Probe livenessProbe; /** * 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 * The value may be {@code null}. */ @com.google.api.client.util.Key private java.lang.String name; /** * 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. * The value may be {@code null}. */ @com.google.api.client.util.Key private java.util.List ports; /** * Not supported by Cloud Run. * The value may be {@code null}. */ @com.google.api.client.util.Key private Probe readinessProbe; /** * Compute Resources required by this container. More info: * https://kubernetes.io/docs/concepts/storage/persistent-volumes#resources * The value may be {@code null}. */ @com.google.api.client.util.Key private ResourceRequirements resources; /** * Not supported by Cloud Run. * The value may be {@code null}. */ @com.google.api.client.util.Key private SecurityContext securityContext; /** * Startup probe of application within the container. All other probes are disabled if a startup * probe is provided, until it succeeds. Container will not receive traffic if the probe fails. If * not provided, a default startup probe with TCP socket action is used. More info: * https://kubernetes.io/docs/concepts/workloads/pods/pod-lifecycle#container-probes * The value may be {@code null}. */ @com.google.api.client.util.Key private Probe startupProbe; /** * 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. * The value may be {@code null}. */ @com.google.api.client.util.Key private java.lang.String terminationMessagePath; /** * 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. * The value may be {@code null}. */ @com.google.api.client.util.Key private java.lang.String terminationMessagePolicy; /** * Volume to mount into the container's filesystem. Only supports SecretVolumeSources. Pod volumes * to mount into the container's filesystem. * The value may be {@code null}. */ @com.google.api.client.util.Key private java.util.List volumeMounts; /** * Container's working directory. If not specified, the container runtime's default will be used, * which might be configured in the container image. * The value may be {@code null}. */ @com.google.api.client.util.Key private java.lang.String workingDir; /** * Arguments to the entrypoint. The docker image's CMD is used if this is not provided. Variable * references are not supported in Cloud Run. * @return value or {@code null} for none */ public java.util.List getArgs() { return args; } /** * Arguments to the entrypoint. The docker image's CMD is used if this is not provided. Variable * references are not supported in Cloud Run. * @param args args or {@code null} for none */ public Container setArgs(java.util.List args) { this.args = args; return this; } /** * Entrypoint array. Not executed within a shell. The docker image's ENTRYPOINT is used if this is * not provided. Variable references are not supported in Cloud Run. * @return value or {@code null} for none */ public java.util.List getCommand() { return command; } /** * Entrypoint array. Not executed within a shell. The docker image's ENTRYPOINT is used if this is * not provided. Variable references are not supported in Cloud Run. * @param command command or {@code null} for none */ public Container setCommand(java.util.List command) { this.command = command; return this; } /** * List of environment variables to set in the container. * @return value or {@code null} for none */ public java.util.List getEnv() { return env; } /** * List of environment variables to set in the container. * @param env env or {@code null} for none */ public Container setEnv(java.util.List env) { this.env = env; return this; } /** * Not supported by Cloud Run. * @return value or {@code null} for none */ public java.util.List getEnvFrom() { return envFrom; } /** * Not supported by Cloud Run. * @param envFrom envFrom or {@code null} for none */ public Container setEnvFrom(java.util.List envFrom) { this.envFrom = envFrom; return this; } /** * Required. URL of the Container image in Google Container Registry or Google Artifact Registry. * More info: https://kubernetes.io/docs/concepts/containers/images * @return value or {@code null} for none */ public java.lang.String getImage() { return image; } /** * Required. URL of the Container image in Google Container Registry or Google Artifact Registry. * More info: https://kubernetes.io/docs/concepts/containers/images * @param image image or {@code null} for none */ public Container setImage(java.lang.String image) { this.image = image; return this; } /** * 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 * @return value or {@code null} for none */ public java.lang.String getImagePullPolicy() { return imagePullPolicy; } /** * 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 * @param imagePullPolicy imagePullPolicy or {@code null} for none */ public Container setImagePullPolicy(java.lang.String imagePullPolicy) { this.imagePullPolicy = imagePullPolicy; return this; } /** * Periodic probe of container liveness. Container will be restarted if the probe fails. More * info: https://kubernetes.io/docs/concepts/workloads/pods/pod-lifecycle#container-probes * @return value or {@code null} for none */ public Probe getLivenessProbe() { return livenessProbe; } /** * Periodic probe of container liveness. Container will be restarted if the probe fails. More * info: https://kubernetes.io/docs/concepts/workloads/pods/pod-lifecycle#container-probes * @param livenessProbe livenessProbe or {@code null} for none */ public Container setLivenessProbe(Probe livenessProbe) { this.livenessProbe = livenessProbe; return this; } /** * 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 * @return value or {@code null} for none */ public java.lang.String getName() { return name; } /** * 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 * @param name name or {@code null} for none */ public Container setName(java.lang.String name) { this.name = name; return this; } /** * 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. * @return value or {@code null} for none */ public java.util.List getPorts() { return ports; } /** * 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. * @param ports ports or {@code null} for none */ public Container setPorts(java.util.List ports) { this.ports = ports; return this; } /** * Not supported by Cloud Run. * @return value or {@code null} for none */ public Probe getReadinessProbe() { return readinessProbe; } /** * Not supported by Cloud Run. * @param readinessProbe readinessProbe or {@code null} for none */ public Container setReadinessProbe(Probe readinessProbe) { this.readinessProbe = readinessProbe; return this; } /** * Compute Resources required by this container. More info: * https://kubernetes.io/docs/concepts/storage/persistent-volumes#resources * @return value or {@code null} for none */ public ResourceRequirements getResources() { return resources; } /** * Compute Resources required by this container. More info: * https://kubernetes.io/docs/concepts/storage/persistent-volumes#resources * @param resources resources or {@code null} for none */ public Container setResources(ResourceRequirements resources) { this.resources = resources; return this; } /** * Not supported by Cloud Run. * @return value or {@code null} for none */ public SecurityContext getSecurityContext() { return securityContext; } /** * Not supported by Cloud Run. * @param securityContext securityContext or {@code null} for none */ public Container setSecurityContext(SecurityContext securityContext) { this.securityContext = securityContext; return this; } /** * Startup probe of application within the container. All other probes are disabled if a startup * probe is provided, until it succeeds. Container will not receive traffic if the probe fails. If * not provided, a default startup probe with TCP socket action is used. More info: * https://kubernetes.io/docs/concepts/workloads/pods/pod-lifecycle#container-probes * @return value or {@code null} for none */ public Probe getStartupProbe() { return startupProbe; } /** * Startup probe of application within the container. All other probes are disabled if a startup * probe is provided, until it succeeds. Container will not receive traffic if the probe fails. If * not provided, a default startup probe with TCP socket action is used. More info: * https://kubernetes.io/docs/concepts/workloads/pods/pod-lifecycle#container-probes * @param startupProbe startupProbe or {@code null} for none */ public Container setStartupProbe(Probe startupProbe) { this.startupProbe = startupProbe; return this; } /** * 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. * @return value or {@code null} for none */ public java.lang.String getTerminationMessagePath() { return terminationMessagePath; } /** * 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. * @param terminationMessagePath terminationMessagePath or {@code null} for none */ public Container setTerminationMessagePath(java.lang.String terminationMessagePath) { this.terminationMessagePath = terminationMessagePath; return this; } /** * 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. * @return value or {@code null} for none */ public java.lang.String getTerminationMessagePolicy() { return terminationMessagePolicy; } /** * 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. * @param terminationMessagePolicy terminationMessagePolicy or {@code null} for none */ public Container setTerminationMessagePolicy(java.lang.String terminationMessagePolicy) { this.terminationMessagePolicy = terminationMessagePolicy; return this; } /** * Volume to mount into the container's filesystem. Only supports SecretVolumeSources. Pod volumes * to mount into the container's filesystem. * @return value or {@code null} for none */ public java.util.List getVolumeMounts() { return volumeMounts; } /** * Volume to mount into the container's filesystem. Only supports SecretVolumeSources. Pod volumes * to mount into the container's filesystem. * @param volumeMounts volumeMounts or {@code null} for none */ public Container setVolumeMounts(java.util.List volumeMounts) { this.volumeMounts = volumeMounts; return this; } /** * Container's working directory. If not specified, the container runtime's default will be used, * which might be configured in the container image. * @return value or {@code null} for none */ public java.lang.String getWorkingDir() { return workingDir; } /** * Container's working directory. If not specified, the container runtime's default will be used, * which might be configured in the container image. * @param workingDir workingDir or {@code null} for none */ public Container setWorkingDir(java.lang.String workingDir) { this.workingDir = workingDir; return this; } @Override public Container set(String fieldName, Object value) { return (Container) super.set(fieldName, value); } @Override public Container clone() { return (Container) super.clone(); } }




© 2015 - 2025 Weber Informatics LLC | Privacy Policy