docs/serving
Joseph Burnett c182e544c6 Update accessing-metrics.md with knative-metrics namespace. (#435) 2018-10-30 17:33:33 -07:00
..
fluentd Move the document and fluent image sample from serving repo to docs repo (#259) 2018-09-18 15:23:19 -07:00
images Document installation and usage of logging, monitoring and tracing components (#92) 2018-07-10 12:39:19 -07:00
samples Update references to monitoring namespace (#407) (#416) 2018-10-30 17:30:34 -07:00
README.md How to use paid SSL cert with Knative (#146) 2018-07-19 15:33:33 -07:00
accessing-logs.md Reverting the namespace rename knative-monitoring (#486) 2018-10-30 16:54:33 -07:00
accessing-metrics.md Update accessing-metrics.md with knative-metrics namespace. (#435) 2018-10-30 17:33:33 -07:00
accessing-traces.md Add license footer and text (#204) 2018-07-19 12:05:32 -07:00
debugging-application-issues.md Update references to monitoring namespace (#407) (#416) 2018-10-30 17:30:34 -07:00
debugging-performance-issues.md Add license footer and text (#204) 2018-07-19 12:05:32 -07:00
gke-assigning-static-ip-address.md Update docs to use kubectl long flags (#372) 2018-09-12 09:46:03 -07:00
installing-logging-metrics-traces.md Reverting the namespace rename knative-monitoring (#486) 2018-10-30 16:54:33 -07:00
outbound-network-access.md Updating Container Engine to new name (#439) 2018-10-04 09:43:24 -07:00
setting-up-a-logging-plugin.md Reverting the namespace rename knative-monitoring (#486) 2018-10-30 16:54:33 -07:00
using-a-custom-domain.md Update docs to use kubectl long flags (#372) 2018-09-12 09:46:03 -07:00
using-an-ssl-cert.md Add instruction to use LetsEncrypt through CertManager. (#352) 2018-10-04 14:42:24 -07:00
using-cert-manager-on-gcp.md Add instruction to use LetsEncrypt through CertManager. (#352) 2018-10-04 14:42:24 -07:00
using-external-dns.md Update docs to use kubectl long flags (#372) 2018-09-12 09:46:03 -07:00

README.md

Knative Serving

Knative Serving builds on Kubernetes and Istio to support deploying and serving of serverless applications and functions. Serving is easy to get started with and scales to support advanced scenarios.

The Knative Serving project provides middleware primitives that enable:

  • Rapid deployment of serverless containers
  • Automatic scaling up and down to zero
  • Routing and network programming for Istio components
  • Point-in-time snapshots of deployed code and configurations

Serving resources

Knative Serving defines a set of objects as Kubernetes Custom Resource Definitions (CRDs). These objects are used to define and control how your serverless workload behaves on the cluster:

  • Service: The service.serving.knative.dev resource automatically manages the whole lifecycle of your workload. It controls the creation of other objects to ensure that your app has a route, a configuration, and a new revision for each update of the service. Service can be defined to always route traffic to the latest revision or to a pinned revision.
  • Route: The route.serving.knative.dev resource maps a network endpoint to a one or more revisions. You can manage the traffic in several ways, including fractional traffic and named routes.
  • Configuration: The configuration.serving.knative.dev resource maintains the desired state for your deployment. It provides a clean separation between code and configuration and follows the Twelve-Factor App methodology. Modifying a configuration creates a new revision.
  • Revision: The revision.serving.knative.dev resource is a point-in-time snapshot of the code and configuration for each modification made to the workload. Revisions are immutable objects and can be retained for as long as useful.

Diagram that displays how the Serving resources coordinate with each other.

Getting Started

To get started with Serving, check out one of the hello world sample projects. These projects use the Service resource, which manages all of the details for you.

With the Service resource, a deployed service will automatically have a matching route and configuration created. Each time the Service is updated, a new revision is created.

For more information on the resources and their interactions, see the Resource Types Overview in the Knative Serving repository.

More samples and demos

Setting up Logging and Metrics

Debugging Knative Serving issues

Configuration and Networking

Known Issues

See the Knative Serving Issues page for a full list of known issues.


Except as otherwise noted, the content of this page is licensed under the Creative Commons Attribution 4.0 License, and code samples are licensed under the Apache 2.0 License.