Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

#3935: Moving tag resolution docs to developer guide #3970

Merged
merged 4 commits into from
Jul 8, 2021
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
2 changes: 1 addition & 1 deletion config/nav.yml
Original file line number Diff line number Diff line change
Expand Up @@ -69,6 +69,7 @@ nav:
- Configure resource requests and limits: developer/serving/services/configure-requests-limits-services.md
- Traffic management: developer/serving/traffic-management.md
- Deploying from private registries: developer/serving/deploying-from-private-registry.md
- Tag resolution: developer/serving/tag-resolution.md
- Troubleshooting:
- Debugging application issues: developer/serving/troubleshooting/debugging-application-issues.md
- Knative Eventing:
Expand Down Expand Up @@ -111,7 +112,6 @@ nav:
- Knative Serving:
- Overview: serving/README.md
- Developer Topics:
- Tag resolution: serving/tag-resolution.md
- Gradually rolling out latest Revisions: serving/rolling-out-latest-revision.md
- Creating and using Subroutes: serving/using-subroutes.md
- Load balancing:
Expand Down
1 change: 1 addition & 0 deletions config/redirects.yml
Original file line number Diff line number Diff line change
@@ -1,6 +1,7 @@
plugins:
redirects:
redirect_maps:
serving/tag-resolution.md: developer/serving/tag-resolution.md
serving/deploying-from-private-registry.md: developer/serving/deploying-from-private-registry.md
serving/samples/blue-green-deployment.md: developer/serving/traffic-management.md
serving/samples/traffic-splitting/README.md: developer/serving/traffic-management.md
Expand Down
89 changes: 37 additions & 52 deletions docs/admin/install/operator/configuring-serving-cr.md
Original file line number Diff line number Diff line change
@@ -1,52 +1,42 @@
---
title: "Configuring the Serving Operator Custom Resource"
weight: 20
type: "docs"
aliases:
- /docs/operator/configuring-serving-cr/
---
# Configuring the Knative Serving Operator custom resource

# Configuring the Serving Operator Custom Resource
The Knative Serving Operator can be configured with the following options:

The Knative Serving operator can be configured with these options:

- [Version Configuration](#version-configuration)
- [Serving Configuration by ConfigMap](#serving-configuration-by-configmap)
- [Version configuration](#version-configuration)
- [Knative Serving configuration by ConfigMap](#knative-serving-configuration-by-configmap)
- [Private repository and private secret](#private-repository-and-private-secrets)
- [SSL certificate for controller](#ssl-certificate-for-controller)
- [Knative ingress gateway](#configuration-of-knative-ingress-gateway)
- [Cluster local gateway](#configuration-of-cluster-local-gateway)
- [High availability](#high-availability)
- [System Resource Settings](#system-resource-settings)
- [System resource settings](#system-resource-settings)
- [Override system deployments](#override-system-deployments)

## Version Configuration
## Version configuration

Cluster administrators can install a specific version of Knative Serving by using the `spec.version` field. For example,
if you want to install Knative Serving 0.16.0, you can apply the following `KnativeServing` custom resource:
Cluster administrators can install a specific version of Knative Serving by using the `spec.version` field.

```
For example, if you want to install Knative Serving v0.23.0, you can apply the following `KnativeServing` custom resource:

```yaml
apiVersion: operator.knative.dev/v1alpha1
kind: KnativeServing
metadata:
name: knative-serving
namespace: knative-serving
spec:
version: 0.16.0
version: 0.23.0
```

If `spec.version` is not specified, the Knative Operator will install the latest available version of Knative Serving.
If users specify an invalid or unavailable version, the Knative Operator will do nothing. The Knative Operator always
includes the latest 3 minor release versions. For example, if the current version of the Knative Operator is 0.16.x, the
earliest version of Knative Serving available through the Operator is 0.14.0.
If `spec.version` is not specified, the Knative Operator installs the latest available version of Knative Serving. If users specify an invalid or unavailable version, the Knative Operator will do nothing. The Knative Operator always includes the latest 3 minor release versions. For example, if the current version of the Knative Operator is v0.24.0, the earliest version of Knative Serving available through the Operator is v0.22.0.
Copy link
Contributor

@RichardJJG RichardJJG Jul 8, 2021

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Suggested change
If `spec.version` is not specified, the Knative Operator installs the latest available version of Knative Serving. If users specify an invalid or unavailable version, the Knative Operator will do nothing. The Knative Operator always includes the latest 3 minor release versions. For example, if the current version of the Knative Operator is v0.24.0, the earliest version of Knative Serving available through the Operator is v0.22.0.
If `spec.version` is not specified, the Knative Operator installs the latest available version of Knative Serving. If users specify an invalid or unavailable version, the Knative Operator does nothing.
The Knative Operator always includes the latest 3 minor release versions. For example, if the current version of the Knative Operator is v0.24.0, the earliest version of Knative Serving available through the Operator is v0.22.0.

Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

lol thought about doing this but wasn't sure whether to split it. Thanks.


If Knative Serving is already managed by the Operator, updating the `spec.version` field in the `KnativeServing` resource
enables upgrading or downgrading the Knative Serving version, without needing to change the Operator.

Note that the Knative Operator only permits upgrades or downgrades by one minor release version at a time. For example,
if the current Knative Serving deployment is version 0.14.x, you must upgrade to 0.15.x before upgrading to 0.16.x.
!!! important
The Knative Operator only permits upgrades or downgrades by one minor release version at a time. For example, if the current Knative Serving deployment is version v0.22.0, you must upgrade to v0.23.0 before upgrading to v0.24.0.

## Serving Configuration by ConfigMap
## Knative Serving configuration by ConfigMap

The Operator manages the Knative Serving installation. It overwrites any updates to ConfigMaps which are used to configure Knative Serving.
The KnativeServing custom resource (CR) allows you to set values for these ConfigMaps by using the Operator.
Expand All @@ -56,7 +46,7 @@ The `spec.config` in the KnativeServing CR has one `<name>` entry for each Confi
In the [setup a custom domain example](../../../serving/using-a-custom-domain.md), you can see the content of the ConfigMap
`config-domain` is:

```
```yaml
apiVersion: v1
kind: ConfigMap
metadata:
Expand All @@ -71,7 +61,7 @@ data:

Using the operator, specify the ConfigMap `config-domain` using the operator CR:

```
```yaml
apiVersion: operator.knative.dev/v1alpha1
kind: KnativeServing
metadata:
Expand All @@ -88,7 +78,7 @@ spec:

You can apply values to multiple ConfigMaps. This example sets `stable-window` to 60s in `config-autoscaler` as well as specifying `config-domain`:

```
```yaml
apiVersion: operator.knative.dev/v1alpha1
kind: KnativeServing
metadata:
Expand All @@ -110,7 +100,6 @@ unique entry point to edit all of them.

## Private repository and private secrets


You can use the `spec.registry` section of the operator CR to change the image references to point to a private registry or [specify imagePullSecrets](https://kubernetes.io/docs/concepts/containers/images/#specifying-imagepullsecrets-on-a-pod):

- `default`: this field defines a image reference template for all Knative images. The format
Expand Down Expand Up @@ -151,7 +140,7 @@ First, you need to make sure your images pushed to the following image tags:

Then, you need to define your operator CR with following content:

```
```yaml
apiVersion: operator.knative.dev/v1alpha1
kind: KnativeServing
metadata:
Expand All @@ -162,8 +151,7 @@ spec:
default: docker.io/knative-images/${NAME}:v0.13.0
```


### Download images individually without secrets:
### Download images individually without secrets

If your custom image links are not defined in a uniform format by default, you will need to individually include each
link in the CR.
Expand All @@ -181,9 +169,9 @@ For example, to given the following images:
| `net-istio-webhook` | `docker.io/knative-images-repo6/net-istio-webhooko:v0.13.0` |
| `queue-proxy` | `docker.io/knative-images-repo7/queue-proxy-suffix:v0.13.0` |

The operator CR should be modified to include the full list:
The Operator CR should be modified to include the full list:

```
```yaml
apiVersion: operator.knative.dev/v1alpha1
kind: KnativeServing
metadata:
Expand All @@ -203,10 +191,9 @@ spec:
```

!!! note
If the container name is not unique across all Deployments, DaemonSets and Jobs,
you can prefix the container name with the parent container name and a slash. For example, `istio-webhook/webhook`.
If the container name is not unique across all Deployments, DaemonSets and Jobs, you can prefix the container name with the parent container name and a slash. For example, `istio-webhook/webhook`.

### Download images with secrets:
### Download images with secrets

If your image repository requires private secrets for
access, include the `imagePullSecrets` attribute.
Expand All @@ -217,9 +204,9 @@ This example uses a secret named `regcred`. You must create your own private sec
- [From command line for docker credentials](https://kubernetes.io/docs/tasks/configure-pod-container/pull-image-private-registry/#create-a-secret-by-providing-credentials-on-the-command-line)
- [Create your own secret](https://kubernetes.io/docs/concepts/configuration/secret/#creating-your-own-secrets)

After you create this secret, edit your operator CR by appending the content below:
After you create this secret, edit the Operator CR by appending the content below:

```
```yaml
apiVersion: operator.knative.dev/v1alpha1
kind: KnativeServing
metadata:
Expand All @@ -234,7 +221,7 @@ spec:

The field `imagePullSecrets` expects a list of secrets. You can add multiple secrets to access the images as below:

```
```yaml
apiVersion: operator.knative.dev/v1alpha1
kind: KnativeServing
metadata:
Expand All @@ -251,18 +238,17 @@ spec:

## SSL certificate for controller

To [enable tag to digest resolution](../../../serving/tag-resolution.md), the Knative Serving controller needs to access the container registry.
To [enable tag to digest resolution](../../../developer/serving/tag-resolution.md), the Knative Serving controller needs to access the container registry.
To allow the controller to trust a self-signed registry cert, you can use the Operator to specify the certificate using a ConfigMap or Secret.

Specify the following fields in `spec.controller-custom-certs` to select a custom registry certificate:

- `name`: the name of the ConfigMap or Secret.
- `type`: either the string "ConfigMap" or "Secret".


If you create a ConfigMap named `testCert` containing the certificate, change your CR:

```
```yaml
apiVersion: operator.knative.dev/v1alpha1
kind: KnativeServing
metadata:
Expand All @@ -274,7 +260,6 @@ spec:
type: ConfigMap
```


## Configuration of Knative ingress gateway

To set up custom ingress gateway, follow [**Step 1: Create Gateway Service and Deployment Instance**](../../../serving/setting-up-custom-ingress-gateway.md).
Expand All @@ -283,7 +268,7 @@ To set up custom ingress gateway, follow [**Step 1: Create Gateway Service and D

Update `spec.ingress.istio.knative-ingress-gateway` to select the labels of the new ingress gateway:

```
```yaml
apiVersion: operator.knative.dev/v1alpha1
kind: KnativeServing
metadata:
Expand All @@ -302,7 +287,7 @@ spec:

Additionally, you will need to update the Istio ConfigMap:

```
```yaml
apiVersion: operator.knative.dev/v1alpha1
kind: KnativeServing
metadata:
Expand Down Expand Up @@ -339,7 +324,7 @@ If you create custom local gateway with a name other than `knative-local-gateway
This example shows a service and deployment `knative-local-gateway` in the namespace `istio-system`, with the
label `custom: custom-local-gw`:

```
```yaml
apiVersion: operator.knative.dev/v1alpha1
kind: KnativeServing
metadata:
Expand All @@ -363,7 +348,7 @@ By default, Knative Serving runs a single instance of each controller. The `spec

The following configuration specifies a replica count of 3 for the controllers and a minimum of 3 activators (which may scale higher if needed):

```
```yaml
apiVersion: operator.knative.dev/v1alpha1
kind: KnativeServing
metadata:
Expand All @@ -384,7 +369,7 @@ To override resource settings for a specific container, create an entry in the `

For example, the following KnativeServing resource configures the `activator` to request 0.3 CPU and 100MB of RAM, and sets hard limits of 1 CPU, 250MB RAM, and 4GB of local storage:

```
```yaml
apiVersion: operator.knative.dev/v1alpha1
kind: KnativeServing
metadata:
Expand All @@ -404,7 +389,7 @@ spec:

If you would like to add another container `autoscaler` with the same configuration, you need to change your CR as below:

```
```yaml
apiVersion: operator.knative.dev/v1alpha1
kind: KnativeServing
metadata:
Expand Down Expand Up @@ -440,7 +425,7 @@ Currently `replicas`, `labels`, `annotations` and `nodeSelector` are supported.
The following KnativeServing resource overrides the `webhook` deployment to have `3` Replicas, the label `mylabel: foo`, and the annotation `myannotataions: bar`,
while other system deployments have `2` Replicas by using `spec.high-availability`.

```
```yaml
apiVersion: operator.knative.dev/v1alpha1
kind: KnativeServing
metadata:
Expand All @@ -465,7 +450,7 @@ spec:

The following KnativeServing resource overrides the `webhook` deployment to use the `disktype: hdd` nodeSelector:

```
```yaml
apiVersion: operator.knative.dev/v1alpha1
kind: KnativeServing
metadata:
Expand Down
65 changes: 65 additions & 0 deletions docs/developer/serving/tag-resolution.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,65 @@
# Tag resolution

Knative Serving resolves image tags to a digest when you create a Revision. This
helps to provide consistency for Deployments. For more information, see the documentation on [Why we resolve tags in Knative](https://docs.google.com/presentation/d/e/2PACX-1vTgyp2lGDsLr_bohx3Ym_2mrTcMoFfzzd6jocUXdmWQFdXydltnraDMoLxvEe6WY9pNPpUUvM-geJ-g/pub).

!!! important
The Knative Serving controller must be configured to access the container registry to use this feature.

## Custom certificates

If you are using a registry that has a self-signed certificate, you must configure the Knative Serving controller to trust that certificate.

Knative Serving accepts the [`SSL_CERT_FILE` and `SSL_CERT_DIR`](https://golang.org/pkg/crypto/x509/#pkg-overview) environment variables.

You can configure trusting certificates by mounting your certificates into
the controller Deployment, and then setting the environment variable appropriately.

For example, if you are using a `custom-certs` secret that contains your CA certificates, the Deployment object is as follows:

```yaml
apiVersion: apps/v1
kind: Deployment
metadata:
name: controller
namespace: knative-serving
spec:
template:
spec:
containers:
- name: controller
volumeMounts:
- name: custom-certs
mountPath: /path/to/custom/certs
env:
- name: SSL_CERT_DIR
value: /path/to/custom/certs
volumes:
- name: custom-certs
secret:
secretName: custom-certs
```

## Corporate proxy

If you are behind a corporate proxy, you must proxy the tag resolution requests between the controller and your registry.

Knative accepts the [`HTTP_PROXY` and `HTTPS_PROXY`](https://golang.org/pkg/net/http/#ProxyFromEnvironment) environment variables, so you can configure the controller Deployment as follows:

```yaml
apiVersion: apps/v1
kind: Deployment
metadata:
name: controller
namespace: knative-serving
spec:
template:
spec:
containers:
- name: controller
env:
- name: HTTP_PROXY
value: http://proxy.example.com
- name: HTTPS_PROXY
value: https://proxy.example.com
```
Loading