We use analytics and cookies to understand site traffic. Information about your use of our site is shared with Google for that purpose. Learn more.
Knative Serving Component
Packages:
- serving.knative.dev/v1alpha1
- serving.knative.dev/v1beta1
- autoscaling.internal.knative.dev/v1alpha1
- networking.internal.knative.dev/v1alpha1
- serving.knative.dev/v1
serving.knative.dev/v1alpha1
Resource Types:
Configuration
Configuration represents the “floating HEAD” of a linear history of Revisions, and optionally how the containers those revisions reference are built. Users create new Revisions by updating the Configuration’s spec. The “latest created” revision’s name is available under status, as is the “latest ready” revision’s name. See also: https://github.com/knative/serving/blob/master/docs/spec/overview.md#configuration
Field | Description | ||||||||
---|---|---|---|---|---|---|---|---|---|
apiVersion
string |
serving.knative.dev/v1alpha1
|
||||||||
kind
string
|
Configuration |
||||||||
metadata
Kubernetes meta/v1.ObjectMeta
|
(Optional)
Refer to the Kubernetes API documentation for the fields of the
metadata field.
|
||||||||
spec
ConfigurationSpec
|
(Optional)
Spec holds the desired state of the Configuration (from the client).
|
||||||||
status
ConfigurationStatus
|
(Optional)
Status communicates the observed state of the Configuration (from the controller). |
Revision
Revision is an immutable snapshot of code and configuration. A revision references a container image, and optionally a build that is responsible for materializing that container image from source. Revisions are created by updates to a Configuration.
See also: https://github.com/knative/serving/blob/master/docs/spec/overview.md#revision
Field | Description | ||||||||||||||
---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|
apiVersion
string |
serving.knative.dev/v1alpha1
|
||||||||||||||
kind
string
|
Revision |
||||||||||||||
metadata
Kubernetes meta/v1.ObjectMeta
|
(Optional)
Refer to the Kubernetes API documentation for the fields of the
metadata field.
|
||||||||||||||
spec
RevisionSpec
|
(Optional)
Spec holds the desired state of the Revision (from the client).
|
||||||||||||||
status
RevisionStatus
|
(Optional)
Status communicates the observed state of the Revision (from the controller). |
Route
Route is responsible for configuring ingress over a collection of Revisions. Some of the Revisions a Route distributes traffic over may be specified by referencing the Configuration responsible for creating them; in these cases the Route is additionally responsible for monitoring the Configuration for “latest ready” revision changes, and smoothly rolling out latest revisions. See also: https://github.com/knative/serving/blob/master/docs/spec/overview.md#route
Field | Description | ||||
---|---|---|---|---|---|
apiVersion
string |
serving.knative.dev/v1alpha1
|
||||
kind
string
|
Route |
||||
metadata
Kubernetes meta/v1.ObjectMeta
|
(Optional)
Refer to the Kubernetes API documentation for the fields of the
metadata field.
|
||||
spec
RouteSpec
|
(Optional)
Spec holds the desired state of the Route (from the client).
|
||||
status
RouteStatus
|
(Optional)
Status communicates the observed state of the Route (from the controller). |
Service
Service acts as a top-level container that manages a set of Routes and Configurations which implement a network service. Service exists to provide a singular abstraction which can be access controlled, reasoned about, and which encapsulates software lifecycle decisions such as rollout policy and team resource ownership. Service acts only as an orchestrator of the underlying Routes and Configurations (much as a kubernetes Deployment orchestrates ReplicaSets), and its usage is optional but recommended.
The Service’s controller will track the statuses of its owned Configuration and Route, reflecting their statuses and conditions as its own.
See also: https://github.com/knative/serving/blob/master/docs/spec/overview.md#service
Field | Description | ||||||||||||||
---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|
apiVersion
string |
serving.knative.dev/v1alpha1
|
||||||||||||||
kind
string
|
Service |
||||||||||||||
metadata
Kubernetes meta/v1.ObjectMeta
|
(Optional)
Refer to the Kubernetes API documentation for the fields of the
metadata field.
|
||||||||||||||
spec
ServiceSpec
|
(Optional)
|
||||||||||||||
status
ServiceStatus
|
(Optional) |
CannotConvertError
CannotConvertError is returned when a field cannot be converted.
Field | Description |
---|---|
Message
string
|
|
Field
string
|
ConfigurationSpec
(Appears on: Configuration, PinnedType, ReleaseType, RunLatestType, ServiceSpec)
ConfigurationSpec holds the desired state of the Configuration (from the client).
Field | Description |
---|---|
generation
int64
|
(Optional)
DeprecatedGeneration was used prior in Kubernetes versions <1.11 when metadata.generation was not being incremented by the api server This property will be dropped in future Knative releases and should not be used - use metadata.generation Tracking issue: https://github.com/knative/serving/issues/643 |
build
k8s.io/apimachinery/pkg/runtime.RawExtension
|
(Optional)
Build optionally holds the specification for the build to perform to produce the Revision’s container image. |
revisionTemplate
RevisionTemplateSpec
|
(Optional)
DeprecatedRevisionTemplate holds the latest specification for the Revision to be stamped out. If a Build specification is provided, then the DeprecatedRevisionTemplate’s BuildName field will be populated with the name of the Build object created to produce the container for the Revision. DEPRECATED Use Template instead. |
template
RevisionTemplateSpec
|
(Optional)
Template holds the latest specification for the Revision to be stamped out. |
ConfigurationStatus
(Appears on: Configuration)
ConfigurationStatus communicates the observed state of the Configuration (from the controller).
Field | Description |
---|---|
Status
knative.dev/pkg/apis/duck/v1.Status
|
(Members of |
ConfigurationStatusFields
ConfigurationStatusFields
|
(Members of |
ConfigurationStatusFields
(Appears on: ConfigurationStatus, ServiceStatus)
ConfigurationStatusFields holds all of the non-duckv1.Status status fields of a Route. These are defined outline so that we can also inline them into Service, and more easily copy them.
Field | Description |
---|---|
latestReadyRevisionName
string
|
(Optional)
LatestReadyRevisionName holds the name of the latest Revision stamped out from this Configuration that has had its “Ready” condition become “True”. |
latestCreatedRevisionName
string
|
(Optional)
LatestCreatedRevisionName is the last revision that was created from this Configuration. It might not be ready yet, for that use LatestReadyRevisionName. |
DeprecatedRevisionRequestConcurrencyModelType
(string
alias)
(Appears on: RevisionSpec)
DeprecatedRevisionRequestConcurrencyModelType is an enumeration of the concurrency models supported by a Revision. DEPRECATED in favor of an integer based ContainerConcurrency setting. TODO(vagababov): retire completely in 0.9.
DeprecatedRevisionServingStateType
(string
alias)
(Appears on: RevisionSpec)
DeprecatedRevisionServingStateType is an enumeration of the levels of serving readiness of the Revision. See also: https://github.com/knative/serving/blob/master/docs/spec/errors.md#error-conditions-and-reporting
ManualType
(Appears on: ServiceSpec)
ManualType contains the options for configuring a manual service. See ServiceSpec for more details.
PinnedType
(Appears on: ServiceSpec)
PinnedType is DEPRECATED. ReleaseType should be used instead. To get the behavior of PinnedType set ReleaseType.Revisions to []string{PinnedType.RevisionName} and ReleaseType.RolloutPercent to 0.
Field | Description |
---|---|
revisionName
string
|
(Optional)
The revision name to pin this service to until changed to a different service type. |
configuration
ConfigurationSpec
|
(Optional)
The configuration for this service. |
ReleaseType
(Appears on: ServiceSpec)
ReleaseType contains the options for slowly releasing revisions. See ServiceSpec for more details.
Field | Description |
---|---|
revisions
[]string
|
(Optional)
Revisions is an ordered list of 1 or 2 revisions. The first will have a TrafficTarget with a name of “current” and the second will have a name of “candidate”. |
rolloutPercent
int
|
(Optional)
RolloutPercent is the percent of traffic that should be sent to the “candidate” revision. Valid values are between 0 and 99 inclusive. |
configuration
ConfigurationSpec
|
(Optional)
The configuration for this service. All revisions from this service must come from a single configuration. |
RevisionSpec
(Appears on: Revision, RevisionTemplateSpec)
RevisionSpec holds the desired state of the Revision (from the client).
Field | Description |
---|---|
RevisionSpec
RevisionSpec
|
(Members of |
generation
int64
|
(Optional)
DeprecatedGeneration was used prior in Kubernetes versions <1.11 when metadata.generation was not being incremented by the api server This property will be dropped in future Knative releases and should not be used - use metadata.generation Tracking issue: https://github.com/knative/serving/issues/643 |
servingState
DeprecatedRevisionServingStateType
|
(Optional)
DeprecatedServingState holds a value describing the desired state the Kubernetes resources should be in for this Revision. Users must not specify this when creating a revision. These values are no longer updated by the system. |
concurrencyModel
DeprecatedRevisionRequestConcurrencyModelType
|
(Optional)
DeprecatedConcurrencyModel specifies the desired concurrency model (Single or Multi) for the Revision. Defaults to Multi. Deprecated in favor of ContainerConcurrency. |
buildName
string
|
(Optional)
DeprecatedBuildName optionally holds the name of the Build responsible for producing the container image for its Revision. DEPRECATED: Use DeprecatedBuildRef instead. |
buildRef
Kubernetes core/v1.ObjectReference
|
(Optional)
DeprecatedBuildRef holds the reference to the build (if there is one) responsible for producing the container image for this Revision. Otherwise, nil |
container
Kubernetes core/v1.Container
|
(Optional)
Container defines the unit of execution for this Revision. In the context of a Revision, we disallow a number of the fields of this Container, including: name and lifecycle. See also the runtime contract for more information about the execution environment: https://github.com/knative/serving/blob/master/docs/runtime-contract.md |
RevisionStatus
(Appears on: Revision)
RevisionStatus communicates the observed state of the Revision (from the controller).
Field | Description |
---|---|
Status
knative.dev/pkg/apis/duck/v1.Status
|
(Members of |
serviceName
string
|
(Optional)
ServiceName holds the name of a core Kubernetes Service resource that load balances over the pods backing this Revision. |
logUrl
string
|
(Optional)
LogURL specifies the generated logging url for this particular revision based on the revision url template specified in the controller’s config. |
imageDigest
string
|
(Optional)
ImageDigest holds the resolved digest for the image specified within .Spec.Container.Image. The digest is resolved during the creation of Revision. This field holds the digest value regardless of whether a tag or digest was originally specified in the Container object. It may be empty if the image comes from a registry listed to skip resolution. |
RevisionTemplateSpec
(Appears on: ConfigurationSpec)
RevisionTemplateSpec describes the data a revision should have when created from a template. Based on: https://github.com/kubernetes/api/blob/e771f807/core/v1/types.go#L3179-L3190
Field | Description | ||||||||||||||
---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|
metadata
Kubernetes meta/v1.ObjectMeta
|
(Optional)
Refer to the Kubernetes API documentation for the fields of the
metadata field.
|
||||||||||||||
spec
RevisionSpec
|
(Optional)
|
RouteSpec
(Appears on: Route, ServiceSpec)
RouteSpec holds the desired state of the Route (from the client).
Field | Description |
---|---|
generation
int64
|
(Optional)
DeprecatedGeneration was used prior in Kubernetes versions <1.11 when metadata.generation was not being incremented by the api server This property will be dropped in future Knative releases and should not be used - use metadata.generation Tracking issue: https://github.com/knative/serving/issues/643 |
traffic
[]TrafficTarget
|
(Optional)
Traffic specifies how to distribute traffic over a collection of Knative Serving Revisions and Configurations. |
RouteStatus
(Appears on: Route)
RouteStatus communicates the observed state of the Route (from the controller).
Field | Description |
---|---|
Status
knative.dev/pkg/apis/duck/v1.Status
|
(Members of |
RouteStatusFields
RouteStatusFields
|
(Members of |
RouteStatusFields
(Appears on: RouteStatus, ServiceStatus)
RouteStatusFields holds all of the non-duckv1.Status status fields of a Route. These are defined outline so that we can also inline them into Service, and more easily copy them.
Field | Description |
---|---|
url
knative.dev/pkg/apis.URL
|
(Optional)
URL holds the url that will distribute traffic over the provided traffic targets. It generally has the form http[s]://{route-name}.{route-namespace}.{cluster-level-suffix} |
domain
string
|
(Optional)
DeprecatedDomain holds the top-level domain that will distribute traffic over the provided targets. It generally has the form {route-name}.{route-namespace}.{cluster-level-suffix} |
domainInternal
string
|
(Optional)
DeprecatedDomainInternal holds the top-level domain that will distribute traffic over the provided targets from inside the cluster. It generally has the form {route-name}.{route-namespace}.svc.{cluster-domain-name} DEPRECATED: Use Address instead. |
address
knative.dev/pkg/apis/duck/v1alpha1.Addressable
|
(Optional)
Address holds the information needed for a Route to be the target of an event. |
traffic
[]TrafficTarget
|
(Optional)
Traffic holds the configured traffic distribution. These entries will always contain RevisionName references. When ConfigurationName appears in the spec, this will hold the LatestReadyRevisionName that we last observed. |
RunLatestType
(Appears on: ServiceSpec)
RunLatestType contains the options for always having a route to the latest configuration. See ServiceSpec for more details.
Field | Description |
---|---|
configuration
ConfigurationSpec
|
(Optional)
The configuration for this service. |
ServiceSpec
(Appears on: Service)
ServiceSpec represents the configuration for the Service object. Exactly one of its members (other than Generation) must be specified. Services can either track the latest ready revision of a configuration or be pinned to a specific revision.
Field | Description |
---|---|
generation
int64
|
(Optional)
DeprecatedGeneration was used prior in Kubernetes versions <1.11 when metadata.generation was not being incremented by the api server This property will be dropped in future Knative releases and should not be used - use metadata.generation Tracking issue: https://github.com/knative/serving/issues/643 |
runLatest
RunLatestType
|
(Optional)
DeprecatedRunLatest defines a simple Service. It will automatically configure a route that keeps the latest ready revision from the supplied configuration running. |
pinned
PinnedType
|
(Optional)
DeprecatedPinned is DEPRECATED in favor of ReleaseType |
manual
ManualType
|
(Optional)
DeprecatedManual mode enables users to start managing the underlying Route and Configuration resources directly. This advanced usage is intended as a path for users to graduate from the limited capabilities of Service to the full power of Route. |
release
ReleaseType
|
(Optional)
Release enables gradual promotion of new revisions by allowing traffic to be split between two revisions. This type replaces the deprecated Pinned type. |
ConfigurationSpec
ConfigurationSpec
|
(Members of We are moving to a shape where the Configuration and Route specifications are inlined into the Service, which gives them compatible shapes. We are staging this change here as a path to this in v1beta1, which drops the “mode” based specifications above. Ultimately all non-v1beta1 fields will be deprecated, and then dropped in v1beta1. |
RouteSpec
RouteSpec
|
(Members of |
ServiceStatus
(Appears on: Service)
ServiceStatus represents the Status stanza of the Service resource.
Field | Description |
---|---|
Status
knative.dev/pkg/apis/duck/v1.Status
|
(Members of |
RouteStatusFields
RouteStatusFields
|
(Members of |
ConfigurationStatusFields
ConfigurationStatusFields
|
(Members of |
TrafficTarget
(Appears on: RouteSpec, RouteStatusFields)
TrafficTarget holds a single entry of the routing table for a Route.
Field | Description |
---|---|
name
string
|
(Optional)
Name is optionally used to expose a dedicated hostname for referencing this target exclusively. It has the form: {name}.${route.status.domain} |
TrafficTarget
TrafficTarget
|
(Members of We inherit most of our fields by inlining the v1 type. Ultimately all non-v1 fields will be deprecated. |
serving.knative.dev/v1beta1
Resource Types:
Configuration
Configuration represents the “floating HEAD” of a linear history of Revisions. Users create new Revisions by updating the Configuration’s spec. The “latest created” revision’s name is available under status, as is the “latest ready” revision’s name. See also: https://github.com/knative/serving/blob/master/docs/spec/overview.md#configuration
Field | Description | ||
---|---|---|---|
apiVersion
string |
serving.knative.dev/v1beta1
|
||
kind
string
|
Configuration |
||
metadata
Kubernetes meta/v1.ObjectMeta
|
(Optional)
Refer to the Kubernetes API documentation for the fields of the
metadata field.
|
||
spec
ConfigurationSpec
|
(Optional)
|
||
status
ConfigurationStatus
|
(Optional) |
Revision
Revision is an immutable snapshot of code and configuration. A revision references a container image. Revisions are created by updates to a Configuration.
See also: https://github.com/knative/serving/blob/master/docs/spec/overview.md#revision
Field | Description | ||||||
---|---|---|---|---|---|---|---|
apiVersion
string |
serving.knative.dev/v1beta1
|
||||||
kind
string
|
Revision |
||||||
metadata
Kubernetes meta/v1.ObjectMeta
|
(Optional)
Refer to the Kubernetes API documentation for the fields of the
metadata field.
|
||||||
spec
RevisionSpec
|
(Optional)
|
||||||
status
RevisionStatus
|
(Optional) |
Route
Route is responsible for configuring ingress over a collection of Revisions. Some of the Revisions a Route distributes traffic over may be specified by referencing the Configuration responsible for creating them; in these cases the Route is additionally responsible for monitoring the Configuration for “latest ready revision” changes, and smoothly rolling out latest revisions. See also: https://github.com/knative/serving/blob/master/docs/spec/overview.md#route
Field | Description | ||
---|---|---|---|
apiVersion
string |
serving.knative.dev/v1beta1
|
||
kind
string
|
Route |
||
metadata
Kubernetes meta/v1.ObjectMeta
|
(Optional)
Refer to the Kubernetes API documentation for the fields of the
metadata field.
|
||
spec
RouteSpec
|
(Optional)
Spec holds the desired state of the Route (from the client).
|
||
status
RouteStatus
|
(Optional)
Status communicates the observed state of the Route (from the controller). |
Service
Service acts as a top-level container that manages a Route and Configuration which implement a network service. Service exists to provide a singular abstraction which can be access controlled, reasoned about, and which encapsulates software lifecycle decisions such as rollout policy and team resource ownership. Service acts only as an orchestrator of the underlying Routes and Configurations (much as a kubernetes Deployment orchestrates ReplicaSets), and its usage is optional but recommended.
The Service’s controller will track the statuses of its owned Configuration and Route, reflecting their statuses and conditions as its own.
See also: https://github.com/knative/serving/blob/master/docs/spec/overview.md#service
Field | Description | ||||
---|---|---|---|---|---|
apiVersion
string |
serving.knative.dev/v1beta1
|
||||
kind
string
|
Service |
||||
metadata
Kubernetes meta/v1.ObjectMeta
|
(Optional)
Refer to the Kubernetes API documentation for the fields of the
metadata field.
|
||||
spec
ServiceSpec
|
(Optional)
|
||||
status
ServiceStatus
|
(Optional) |
autoscaling.internal.knative.dev/v1alpha1
Resource Types:
PodAutoscaler
PodAutoscaler is a Knative abstraction that encapsulates the interface by which Knative components instantiate autoscalers. This definition is an abstraction that may be backed by multiple definitions. For more information, see the Knative Pluggability presentation: https://docs.google.com/presentation/d/10KWynvAJYuOEWy69VBa6bHJVCqIsz1TNdEKosNvcpPY/edit
Field | Description | ||||||||||
---|---|---|---|---|---|---|---|---|---|---|---|
apiVersion
string |
autoscaling.internal.knative.dev/v1alpha1
|
||||||||||
kind
string
|
PodAutoscaler |
||||||||||
metadata
Kubernetes meta/v1.ObjectMeta
|
(Optional)
Refer to the Kubernetes API documentation for the fields of the
metadata field.
|
||||||||||
spec
PodAutoscalerSpec
|
(Optional)
Spec holds the desired state of the PodAutoscaler (from the client).
|
||||||||||
status
PodAutoscalerStatus
|
(Optional)
Status communicates the observed state of the PodAutoscaler (from the controller). |
Metric
Metric represents a resource to configure the metric collector with.
Field | Description | ||||||
---|---|---|---|---|---|---|---|
metadata
Kubernetes meta/v1.ObjectMeta
|
(Optional)
Refer to the Kubernetes API documentation for the fields of the
metadata field.
|
||||||
spec
MetricSpec
|
(Optional)
Spec holds the desired state of the Metric (from the client).
|
||||||
status
MetricStatus
|
(Optional)
Status communicates the observed state of the Metric (from the controller). |
MetricSpec
(Appears on: Metric)
MetricSpec contains all values a metric collector needs to operate.
Field | Description |
---|---|
stableWindow
time.Duration
|
StableWindow is the aggregation window for metrics in a stable state. |
panicWindow
time.Duration
|
PanicWindow is the aggregation window for metrics where quick reactions are needed. |
scrapeTarget
string
|
ScrapeTarget is the K8s service that publishes the metric endpoint. |
MetricStatus
(Appears on: Metric)
MetricStatus reflects the status of metric collection for this specific entity.
Field | Description |
---|---|
Status
knative.dev/pkg/apis/duck/v1.Status
|
(Members of |
PodAutoscalerSpec
(Appears on: PodAutoscaler)
PodAutoscalerSpec holds the desired state of the PodAutoscaler (from the client).
Field | Description |
---|---|
generation
int64
|
(Optional)
DeprecatedGeneration was used prior in Kubernetes versions <1.11 when metadata.generation was not being incremented by the api server This property will be dropped in future Knative releases and should not be used - use metadata.generation Tracking issue: https://github.com/knative/serving/issues/643 |
containerConcurrency
int64
|
(Optional)
ContainerConcurrency specifies the maximum allowed
in-flight (concurrent) requests per container of the Revision.
Defaults to |
scaleTargetRef
Kubernetes core/v1.ObjectReference
|
ScaleTargetRef defines the /scale-able resource that this PodAutoscaler is responsible for quickly right-sizing. |
reachability
ReachabilityType
|
(Optional)
Reachable specifies whether or not the |
protocolType
knative.dev/serving/pkg/apis/networking.ProtocolType
|
The application-layer protocol. Matches |
PodAutoscalerStatus
(Appears on: PodAutoscaler)
PodAutoscalerStatus communicates the observed state of the PodAutoscaler (from the controller).
Field | Description |
---|---|
Status
knative.dev/pkg/apis/duck/v1.Status
|
(Members of |
serviceName
string
|
ServiceName is the K8s Service name that serves the revision, scaled by this PA. The service is created and owned by the ServerlessService object owned by this PA. |
metricsServiceName
string
|
MetricsServiceName is the K8s Service name that provides revision metrics. The service is managed by the PA object. |
desiredScale
int32
|
DesiredScale shows the current desired number of replicas for the revision. |
actualScale
int32
|
ActualScale shows the actual number of replicas for the revision. |
PodScalable
PodScalable is a duck type that the resources referenced by the
PodAutoscaler’s ScaleTargetRef must implement. They must also
implement the /scale
sub-resource for use with /scale
based
implementations (e.g. HPA), but this further constrains the shape
the referenced resources may take.
Field | Description | ||||||
---|---|---|---|---|---|---|---|
metadata
Kubernetes meta/v1.ObjectMeta
|
Refer to the Kubernetes API documentation for the fields of the
metadata field.
|
||||||
spec
PodScalableSpec
|
|
||||||
status
PodScalableStatus
|
PodScalableSpec
(Appears on: PodScalable)
PodScalableSpec is the specification for the desired state of a PodScalable (or at least our shared portion).
Field | Description |
---|---|
replicas
int32
|
|
selector
Kubernetes meta/v1.LabelSelector
|
|
template
Kubernetes core/v1.PodTemplateSpec
|
PodScalableStatus
(Appears on: PodScalable)
PodScalableStatus is the observed state of a PodScalable (or at least our shared portion).
Field | Description |
---|---|
replicas
int32
|
ReachabilityType
(string
alias)
(Appears on: PodAutoscalerSpec)
ReachabilityType is the enumeration type for the different states of reachability
to the ScaleTarget
of a PodAutoscaler
networking.internal.knative.dev/v1alpha1
Resource Types:
Certificate
Certificate is responsible for provisioning a SSL certificate for the given hosts. It is a Knative abstraction for various SSL certificate provisioning solutions (such as cert-manager or self-signed SSL certificate).
Field | Description | ||||
---|---|---|---|---|---|
apiVersion
string |
networking.internal.knative.dev/v1alpha1
|
||||
kind
string
|
Certificate |
||||
metadata
Kubernetes meta/v1.ObjectMeta
|
(Optional)
Standard object’s metadata. More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#metadata Refer to the Kubernetes API documentation for the fields of themetadata field.
|
||||
spec
CertificateSpec
|
(Optional)
Spec is the desired state of the Certificate. More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#spec-and-status
|
||||
status
CertificateStatus
|
(Optional)
Status is the current state of the Certificate. More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#spec-and-status |
Ingress
Ingress is a collection of rules that allow inbound connections to reach the endpoints defined by a backend. An Ingress can be configured to give services externally-reachable URLs, load balance traffic, offer name based virtual hosting, etc.
This is heavily based on K8s Ingress https://godoc.org/k8s.io/api/networking/v1beta1#Ingress which some highlighted modifications.
Field | Description | ||||||||
---|---|---|---|---|---|---|---|---|---|
apiVersion
string |
networking.internal.knative.dev/v1alpha1
|
||||||||
kind
string
|
Ingress |
||||||||
metadata
Kubernetes meta/v1.ObjectMeta
|
(Optional)
Standard object’s metadata. More info: https://git.k8s.io/community/contributors/devel/api-conventions.md#metadata Refer to the Kubernetes API documentation for the fields of themetadata field.
|
||||||||
spec
IngressSpec
|
(Optional)
Spec is the desired state of the Ingress. More info: https://git.k8s.io/community/contributors/devel/api-conventions.md#spec-and-status
|
||||||||
status
IngressStatus
|
(Optional)
Status is the current state of the Ingress. More info: https://git.k8s.io/community/contributors/devel/api-conventions.md#spec-and-status |
ServerlessService
ServerlessService is a proxy for the K8s service objects containing the endpoints for the revision, whether those are endpoints of the activator or revision pods. See: https://knative.page.link/naxz for details.
Field | Description | ||||||
---|---|---|---|---|---|---|---|
apiVersion
string |
networking.internal.knative.dev/v1alpha1
|
||||||
kind
string
|
ServerlessService |
||||||
metadata
Kubernetes meta/v1.ObjectMeta
|
(Optional)
Standard object’s metadata. More info: https://git.k8s.io/community/contributors/devel/api-conventions.md#metadata Refer to the Kubernetes API documentation for the fields of themetadata field.
|
||||||
spec
ServerlessServiceSpec
|
(Optional)
Spec is the desired state of the ServerlessService. More info: https://git.k8s.io/community/contributors/devel/api-conventions.md#spec-and-status
|
||||||
status
ServerlessServiceStatus
|
(Optional)
Status is the current state of the ServerlessService. More info: https://git.k8s.io/community/contributors/devel/api-conventions.md#spec-and-status |
CertificateSpec
(Appears on: Certificate)
CertificateSpec defines the desired state of a Certificate
.
Field | Description |
---|---|
dnsNames
[]string
|
DNSNames is a list of DNS names the Certificate could support. The wildcard format of DNSNames (e.g. *.default.example.com) is supported. |
secretName
string
|
SecretName is the name of the secret resource to store the SSL certificate in. |
CertificateStatus
(Appears on: Certificate)
CertificateStatus defines the observed state of a Certificate
.
Field | Description |
---|---|
Status
knative.dev/pkg/apis/duck/v1.Status
|
(Members of When Certificate status is ready, it means: - The target secret exists - The target secret contains a certificate that has not expired - The target secret contains a private key valid for the certificate |
notAfter
Kubernetes meta/v1.Time
|
(Optional)
The expiration time of the TLS certificate stored in the secret named by this resource in spec.secretName. |
http01Challenges
[]HTTP01Challenge
|
HTTP01Challenges is a list of HTTP01 challenges that need to be fulfilled in order to get the TLS certificate.. |
HTTP01Challenge
(Appears on: CertificateStatus)
HTTP01Challenge defines the status of a HTTP01 challenge that a certificate needs to fulfill.
Field | Description |
---|---|
url
knative.dev/pkg/apis.URL
|
URL is the URL that the HTTP01 challenge is expected to serve on. |
serviceName
string
|
ServiceName is the name of the service to serve HTTP01 challenge requests. |
serviceNamespace
string
|
ServiceNamespace is the namespace of the service to serve HTTP01 challenge requests. |
servicePort
k8s.io/apimachinery/pkg/util/intstr.IntOrString
|
ServicePort is the port of the service to serve HTTP01 challenge requests. |
HTTPIngressPath
(Appears on: HTTPIngressRuleValue)
HTTPIngressPath associates a path regex with a backend. Incoming URLs matching the path are forwarded to the backend.
Field | Description |
---|---|
path
string
|
(Optional)
Path is an extended POSIX regex as defined by IEEE Std 1003.1, (i.e this follows the egrep/unix syntax, not the perl syntax) matched against the path of an incoming request. Currently it can contain characters disallowed from the conventional “path” part of a URL as defined by RFC 3986. Paths must begin with a ‘/’. If unspecified, the path defaults to a catch all sending traffic to the backend. |
splits
[]IngressBackendSplit
|
Splits defines the referenced service endpoints to which the traffic will be forwarded to. |
appendHeaders
map[string]string
|
(Optional)
AppendHeaders allow specifying additional HTTP headers to add before forwarding a request to the destination service. NOTE: This differs from K8s Ingress which doesn’t allow header appending. |
timeout
Kubernetes meta/v1.Duration
|
(Optional)
Timeout for HTTP requests. NOTE: This differs from K8s Ingress which doesn’t allow setting timeouts. |
retries
HTTPRetry
|
(Optional)
Retry policy for HTTP requests. NOTE: This differs from K8s Ingress which doesn’t allow retry settings. |
HTTPIngressRuleValue
(Appears on: IngressRule)
HTTPIngressRuleValue is a list of http selectors pointing to backends.
In the example: http://
Field | Description |
---|---|
paths
[]HTTPIngressPath
|
A collection of paths that map requests to backends. If they are multiple matching paths, the first match takes precendent. |
HTTPRetry
(Appears on: HTTPIngressPath)
HTTPRetry describes the retry policy to use when a HTTP request fails.
Field | Description |
---|---|
attempts
int
|
Number of retries for a given request. |
perTryTimeout
Kubernetes meta/v1.Duration
|
Timeout per retry attempt for a given request. format: 1h/1m/1s/1ms. MUST BE >=1ms. |
IngressBackend
(Appears on: IngressBackendSplit)
IngressBackend describes all endpoints for a given service and port.
Field | Description |
---|---|
serviceNamespace
string
|
Specifies the namespace of the referenced service. NOTE: This differs from K8s Ingress to allow routing to different namespaces. |
serviceName
string
|
Specifies the name of the referenced service. |
servicePort
k8s.io/apimachinery/pkg/util/intstr.IntOrString
|
Specifies the port of the referenced service. |
IngressBackendSplit
(Appears on: HTTPIngressPath)
IngressBackendSplit describes all endpoints for a given service and port.
Field | Description |
---|---|
IngressBackend
IngressBackend
|
(Members of Specifies the backend receiving the traffic split. |
percent
int
|
Specifies the split percentage, a number between 0 and 100. If only one split is specified, we default to 100. NOTE: This differs from K8s Ingress to allow percentage split. |
appendHeaders
map[string]string
|
(Optional)
AppendHeaders allow specifying additional HTTP headers to add before forwarding a request to the destination service. NOTE: This differs from K8s Ingress which doesn’t allow header appending. |
IngressRule
(Appears on: IngressSpec)
IngressRule represents the rules mapping the paths under a specified host to the related backend services. Incoming requests are first evaluated for a host match, then routed to the backend associated with the matching IngressRuleValue.
Field | Description |
---|---|
hosts
[]string
|
(Optional)
Host is the fully qualified domain name of a network host, as defined
by RFC 3986. Note the following deviations from the “host” part of the
URI as defined in the RFC:
1. IPs are not allowed. Currently a rule value can only apply to the
IP in the Spec of the parent .
2. The |
visibility
IngressVisibility
|
(Optional)
Visibility signifies whether this rule should |
http
HTTPIngressRuleValue
|
HTTP represents a rule to apply against incoming requests. If the rule is satisfied, the request is routed to the specified backend. |
IngressSpec
(Appears on: Ingress)
IngressSpec describes the Ingress the user wishes to exist.
In general this follows the same shape as K8s Ingress. Some notable differences: - Backends now can have namespace: - Traffic can be split across multiple backends. - Timeout & Retry can be configured. - Headers can be appended.
Field | Description |
---|---|
generation
int64
|
(Optional)
DeprecatedGeneration was used prior in Kubernetes versions <1.11 when metadata.generation was not being incremented by the api server This property will be dropped in future Knative releases and should not be used - use metadata.generation Tracking issue: https://github.com/knative/serving/issues/643 |
tls
[]IngressTLS
|
(Optional)
TLS configuration. Currently Ingress only supports a single TLS port: 443. If multiple members of this list specify different hosts, they will be multiplexed on the same port according to the hostname specified through the SNI TLS extension, if the ingress controller fulfilling the ingress supports SNI. |
rules
[]IngressRule
|
(Optional)
A list of host rules used to configure the Ingress. |
visibility
IngressVisibility
|
Visibility setting. |
IngressStatus
(Appears on: Ingress)
IngressStatus describe the current state of the Ingress.
Field | Description |
---|---|
Status
knative.dev/pkg/apis/duck/v1.Status
|
(Members of |
loadBalancer
LoadBalancerStatus
|
(Optional)
LoadBalancer contains the current status of the load-balancer.
This is to be superseded by the combination of |
publicLoadBalancer
LoadBalancerStatus
|
(Optional)
PublicLoadBalancer contains the current status of the load-balancer. |
privateLoadBalancer
LoadBalancerStatus
|
(Optional)
PrivateLoadBalancer contains the current status of the load-balancer. |
IngressTLS
(Appears on: IngressSpec)
IngressTLS describes the transport layer security associated with an Ingress.
Field | Description |
---|---|
hosts
[]string
|
(Optional)
Hosts is a list of hosts included in the TLS certificate. The values in this list must match the name/s used in the tlsSecret. Defaults to the wildcard host setting for the loadbalancer controller fulfilling this Ingress, if left unspecified. |
secretName
string
|
SecretName is the name of the secret used to terminate SSL traffic. |
secretNamespace
string
|
SecretNamespace is the namespace of the secret used to terminate SSL traffic. |
serverCertificate
string
|
(Optional)
ServerCertificate identifies the certificate filename in the secret.
Defaults to |
privateKey
string
|
(Optional)
PrivateKey identifies the private key filename in the secret.
Defaults to |
IngressVisibility
(string
alias)
(Appears on: IngressRule, IngressSpec)
IngressVisibility describes whether the Ingress should be exposed to public gateways or not.
LoadBalancerIngressStatus
(Appears on: LoadBalancerStatus)
LoadBalancerIngressStatus represents the status of a load-balancer ingress point: traffic intended for the service should be sent to an ingress point.
Field | Description |
---|---|
ip
string
|
(Optional)
IP is set for load-balancer ingress points that are IP based (typically GCE or OpenStack load-balancers) |
domain
string
|
(Optional)
Domain is set for load-balancer ingress points that are DNS based (typically AWS load-balancers) |
domainInternal
string
|
(Optional)
DomainInternal is set if there is a cluster-local DNS name to access the Ingress. NOTE: This differs from K8s Ingress, since we also desire to have a cluster-local DNS name to allow routing in case of not having a mesh. |
meshOnly
bool
|
(Optional)
MeshOnly is set if the Ingress is only load-balanced through a Service mesh. |
LoadBalancerStatus
(Appears on: IngressStatus)
LoadBalancerStatus represents the status of a load-balancer.
Field | Description |
---|---|
ingress
[]LoadBalancerIngressStatus
|
(Optional)
Ingress is a list containing ingress points for the load-balancer. Traffic intended for the service should be sent to these ingress points. |
ServerlessServiceOperationMode
(string
alias)
(Appears on: ServerlessServiceSpec)
ServerlessServiceOperationMode is an enumeration of the modes of operation for the ServerlessService.
ServerlessServiceSpec
(Appears on: ServerlessService)
ServerlessServiceSpec describes the ServerlessService.
Field | Description |
---|---|
mode
ServerlessServiceOperationMode
|
Mode describes the mode of operation of the ServerlessService. |
objectRef
Kubernetes core/v1.ObjectReference
|
ObjectRef defines the resource that this ServerlessService is responsible for making “serverless”. |
ProtocolType
knative.dev/serving/pkg/apis/networking.ProtocolType
|
The application-layer protocol. Matches |
ServerlessServiceStatus
(Appears on: ServerlessService)
ServerlessServiceStatus describes the current state of the ServerlessService.
Field | Description |
---|---|
Status
knative.dev/pkg/apis/duck/v1.Status
|
(Members of |
serviceName
string
|
(Optional)
ServiceName holds the name of a core K8s Service resource that load balances over the pods backing this Revision (activator or revision). |
privateServiceName
string
|
(Optional)
PrivateServiceName holds the name of a core K8s Service resource that load balances over the user service pods backing this Revision. |
serving.knative.dev/v1
Resource Types:
Configuration
Configuration represents the “floating HEAD” of a linear history of Revisions. Users create new Revisions by updating the Configuration’s spec. The “latest created” revision’s name is available under status, as is the “latest ready” revision’s name. See also: https://github.com/knative/serving/blob/master/docs/spec/overview.md#configuration
Field | Description | ||
---|---|---|---|
apiVersion
string |
serving.knative.dev/v1
|
||
kind
string
|
Configuration |
||
metadata
Kubernetes meta/v1.ObjectMeta
|
(Optional)
Refer to the Kubernetes API documentation for the fields of the
metadata field.
|
||
spec
ConfigurationSpec
|
(Optional)
|
||
status
ConfigurationStatus
|
(Optional) |
Revision
Revision is an immutable snapshot of code and configuration. A revision references a container image. Revisions are created by updates to a Configuration.
See also: https://github.com/knative/serving/blob/master/docs/spec/overview.md#revision
Field | Description | ||||||
---|---|---|---|---|---|---|---|
apiVersion
string |
serving.knative.dev/v1
|
||||||
kind
string
|
Revision |
||||||
metadata
Kubernetes meta/v1.ObjectMeta
|
(Optional)
Refer to the Kubernetes API documentation for the fields of the
metadata field.
|
||||||
spec
RevisionSpec
|
(Optional)
|
||||||
status
RevisionStatus
|
(Optional) |
Route
Route is responsible for configuring ingress over a collection of Revisions. Some of the Revisions a Route distributes traffic over may be specified by referencing the Configuration responsible for creating them; in these cases the Route is additionally responsible for monitoring the Configuration for “latest ready revision” changes, and smoothly rolling out latest revisions. See also: https://github.com/knative/serving/blob/master/docs/spec/overview.md#route
Field | Description | ||
---|---|---|---|
apiVersion
string |
serving.knative.dev/v1
|
||
kind
string
|
Route |
||
metadata
Kubernetes meta/v1.ObjectMeta
|
(Optional)
Refer to the Kubernetes API documentation for the fields of the
metadata field.
|
||
spec
RouteSpec
|
(Optional)
Spec holds the desired state of the Route (from the client).
|
||
status
RouteStatus
|
(Optional)
Status communicates the observed state of the Route (from the controller). |
Service
Service acts as a top-level container that manages a Route and Configuration which implement a network service. Service exists to provide a singular abstraction which can be access controlled, reasoned about, and which encapsulates software lifecycle decisions such as rollout policy and team resource ownership. Service acts only as an orchestrator of the underlying Routes and Configurations (much as a kubernetes Deployment orchestrates ReplicaSets), and its usage is optional but recommended.
The Service’s controller will track the statuses of its owned Configuration and Route, reflecting their statuses and conditions as its own.
See also: https://github.com/knative/serving/blob/master/docs/spec/overview.md#service
Field | Description | ||||
---|---|---|---|---|---|
apiVersion
string |
serving.knative.dev/v1
|
||||
kind
string
|
Service |
||||
metadata
Kubernetes meta/v1.ObjectMeta
|
(Optional)
Refer to the Kubernetes API documentation for the fields of the
metadata field.
|
||||
spec
ServiceSpec
|
(Optional)
|
||||
status
ServiceStatus
|
(Optional) |
ConfigurationSpec
(Appears on: Configuration, Configuration, ServiceSpec)
ConfigurationSpec holds the desired state of the Configuration (from the client).
Field | Description |
---|---|
template
RevisionTemplateSpec
|
(Optional)
Template holds the latest specification for the Revision to be stamped out. |
ConfigurationStatus
(Appears on: Configuration, Configuration)
ConfigurationStatus communicates the observed state of the Configuration (from the controller).
Field | Description |
---|---|
Status
knative.dev/pkg/apis/duck/v1.Status
|
(Members of |
ConfigurationStatusFields
ConfigurationStatusFields
|
(Members of |
ConfigurationStatusFields
(Appears on: ConfigurationStatus, ServiceStatus)
ConfigurationStatusFields holds the fields of Configuration’s status that are not generally shared. This is defined separately and inlined so that other types can readily consume these fields via duck typing.
Field | Description |
---|---|
latestReadyRevisionName
string
|
(Optional)
LatestReadyRevisionName holds the name of the latest Revision stamped out from this Configuration that has had its “Ready” condition become “True”. |
latestCreatedRevisionName
string
|
(Optional)
LatestCreatedRevisionName is the last revision that was created from this Configuration. It might not be ready yet, for that use LatestReadyRevisionName. |
RevisionSpec
(Appears on: Revision, Revision, RevisionSpec, RevisionTemplateSpec)
RevisionSpec holds the desired state of the Revision (from the client).
Field | Description |
---|---|
PodSpec
Kubernetes core/v1.PodSpec
|
(Members of |
containerConcurrency
int64
|
(Optional)
ContainerConcurrency specifies the maximum allowed in-flight (concurrent)
requests per container of the Revision. Defaults to |
timeoutSeconds
int64
|
(Optional)
TimeoutSeconds holds the max duration the instance is allowed for responding to a request. If unspecified, a system default will be provided. |
RevisionStatus
(Appears on: Revision, Revision)
RevisionStatus communicates the observed state of the Revision (from the controller).
Field | Description |
---|---|
Status
knative.dev/pkg/apis/duck/v1.Status
|
(Members of |
serviceName
string
|
(Optional)
ServiceName holds the name of a core Kubernetes Service resource that load balances over the pods backing this Revision. |
logUrl
string
|
(Optional)
LogURL specifies the generated logging url for this particular revision based on the revision url template specified in the controller’s config. |
imageDigest
string
|
(Optional)
ImageDigest holds the resolved digest for the image specified within .Spec.Container.Image. The digest is resolved during the creation of Revision. This field holds the digest value regardless of whether a tag or digest was originally specified in the Container object. It may be empty if the image comes from a registry listed to skip resolution. |
RevisionTemplateSpec
(Appears on: ConfigurationSpec)
RevisionTemplateSpec describes the data a revision should have when created from a template. Based on: https://github.com/kubernetes/api/blob/e771f807/core/v1/types.go#L3179-L3190
Field | Description | ||||||
---|---|---|---|---|---|---|---|
metadata
Kubernetes meta/v1.ObjectMeta
|
(Optional)
Refer to the Kubernetes API documentation for the fields of the
metadata field.
|
||||||
spec
RevisionSpec
|
(Optional)
|
RouteSpec
(Appears on: Route, Route, ServiceSpec)
RouteSpec holds the desired state of the Route (from the client).
Field | Description |
---|---|
traffic
[]TrafficTarget
|
(Optional)
Traffic specifies how to distribute traffic over a collection of revisions and configurations. |
RouteStatus
RouteStatus communicates the observed state of the Route (from the controller).
Field | Description |
---|---|
Status
knative.dev/pkg/apis/duck/v1.Status
|
(Members of |
RouteStatusFields
RouteStatusFields
|
(Members of |
RouteStatusFields
(Appears on: RouteStatus, ServiceStatus)
RouteStatusFields holds the fields of Route’s status that are not generally shared. This is defined separately and inlined so that other types can readily consume these fields via duck typing.
Field | Description |
---|---|
url
knative.dev/pkg/apis.URL
|
(Optional)
URL holds the url that will distribute traffic over the provided traffic targets. It generally has the form http[s]://{route-name}.{route-namespace}.{cluster-level-suffix} |
address
knative.dev/pkg/apis/duck/v1.Addressable
|
(Optional)
Address holds the information needed for a Route to be the target of an event. |
traffic
[]TrafficTarget
|
(Optional)
Traffic holds the configured traffic distribution. These entries will always contain RevisionName references. When ConfigurationName appears in the spec, this will hold the LatestReadyRevisionName that we last observed. |
ServiceSpec
(Appears on: Service, Service)
ServiceSpec represents the configuration for the Service object. A Service’s specification is the union of the specifications for a Route and Configuration. The Service restricts what can be expressed in these fields, e.g. the Route must reference the provided Configuration; however, these limitations also enable friendlier defaulting, e.g. Route never needs a Configuration name, and may be defaulted to the appropriate “run latest” spec.
Field | Description |
---|---|
ConfigurationSpec
ConfigurationSpec
|
(Members of ServiceSpec inlines an unrestricted ConfigurationSpec. |
RouteSpec
RouteSpec
|
(Members of ServiceSpec inlines RouteSpec and restricts/defaults its fields via webhook. In particular, this spec can only reference this Service’s configuration and revisions (which also influences defaults). |
ServiceStatus
(Appears on: Service, Service)
ServiceStatus represents the Status stanza of the Service resource.
Field | Description |
---|---|
Status
knative.dev/pkg/apis/duck/v1.Status
|
(Members of |
ConfigurationStatusFields
ConfigurationStatusFields
|
(Members of In addition to inlining ConfigurationSpec, we also inline the fields specific to ConfigurationStatus. |
RouteStatusFields
RouteStatusFields
|
(Members of In addition to inlining RouteSpec, we also inline the fields specific to RouteStatus. |
TrafficTarget
(Appears on: RouteSpec, RouteStatusFields, TrafficTarget)
TrafficTarget holds a single entry of the routing table for a Route.
Field | Description |
---|---|
tag
string
|
(Optional)
Tag is optionally used to expose a dedicated url for referencing this target exclusively. |
revisionName
string
|
(Optional)
RevisionName of a specific revision to which to send this portion of traffic. This is mutually exclusive with ConfigurationName. |
configurationName
string
|
(Optional)
ConfigurationName of a configuration to whose latest revision we will send this portion of traffic. When the “status.latestReadyRevisionName” of the referenced configuration changes, we will automatically migrate traffic from the prior “latest ready” revision to the new one. This field is never set in Route’s status, only its spec. This is mutually exclusive with RevisionName. |
latestRevision
bool
|
(Optional)
LatestRevision may be optionally provided to indicate that the latest ready Revision of the Configuration should be used for this traffic target. When provided LatestRevision must be true if RevisionName is empty; it must be false when RevisionName is non-empty. |
percent
int64
|
(Optional)
Percent indicates that percentage based routing should be used and
the value indicates the percent of traffic that is be routed to this
Revision or Configuration. |
url
knative.dev/pkg/apis.URL
|
(Optional)
URL displays the URL for accessing named traffic targets. URL is displayed in status, and is disallowed on spec. URL must contain a scheme (e.g. http://) and a hostname, but may not contain anything else (e.g. basic auth, url path, etc.) |
Generated with gen-crd-api-reference-docs
on git commit 804b3bb85
.
Feedback
Was this page helpful?
Glad to hear it! Please tell us how we can improve.
Sorry to hear that. Please tell us how we can improve.