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

Adding kubernetes-provider quickstart #853

Open
wants to merge 6 commits into
base: master
Choose a base branch
from
Open
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
243 changes: 243 additions & 0 deletions content/master/getting-started/provider-kubernetes.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,243 @@
---
title: Kubernetes Provider Quickstart
weight: 110
---

Connect Crossplane to in-cluster kubernetes to create and manage resources from Kubernetes
with the
[Upbound Kubernetes Provider](https://marketplace.upbound.io/providers/upbound/provider-kubernetes/).

## Prerequisites
This quickstart requires:
* a Kubernetes cluster with at least 2 GB of RAM
* permissions to create pods and secrets in the Kubernetes cluster
* [Helm](https://helm.sh/) version v3.2.0 or later
* CNI

{{<include file="/master/getting-started/install-crossplane-include.md" type="page" >}}

## Install the Kubernetes provider

Install the Kubernetes provider into the Kubernetes cluster with a Kubernetes configuration
file.

```yaml
cat <<EOF | kubectl apply -f -
apiVersion: pkg.crossplane.io/v1
kind: Provider
metadata:
name: provider-kubernetes
spec:
package: xpkg.upbound.io/upbound/provider-kubernetes:v0.16.0
Copy link
Collaborator

Choose a reason for hiding this comment

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

Suggested change
package: xpkg.upbound.io/upbound/provider-kubernetes:v0.16.0
package: xpkg.upbound.io/upbound/provider-kubernetes:v0.16.2

runtimeConfigRef:
apiVersion: pkg.crossplane.io/v1beta1
kind: DeploymentRuntimeConfig
name: provider-kubernetes
EOF
```
```yaml
cat <<EOF | kubectl apply -f -
apiVersion: pkg.crossplane.io/v1beta1
kind: DeploymentRuntimeConfig
metadata:
name: provider-kubernetes
spec:
serviceAccountTemplate:
metadata:
name: provider-kubernetes
EOF
---
Copy link
Collaborator

Choose a reason for hiding this comment

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

missing closing code block? or maybe one too much?

Copy link
Author

Choose a reason for hiding this comment

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

I don't quite know, this is what got it to work

Copy link
Collaborator

Choose a reason for hiding this comment

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

The triple backtick to close the code block in markdown.

Comment on lines +38 to +49
Copy link
Collaborator

Choose a reason for hiding this comment

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

🤔 looks we are missing a story here. What's going on? should the section Create a ProviderConfig below be dropped?

```yaml {label="ClusterRoleBinding",copy-lines="all"}
cat <<EOF | kubectl apply -f -
apiVersion: rbac.authorization.k8s.io/v1
kind: ClusterRoleBinding
metadata:
name: provider-kubernetes-cluster-admin
subjects:
- kind: ServiceAccount
name: provider-kubernetes
namespace: crossplane-system
roleRef:
kind: ClusterRole
name: cluster-admin
apiGroup: rbac.authorization.k8s.io
EOF
---
Copy link
Collaborator

Choose a reason for hiding this comment

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

missing close code block here too?

Copy link
Author

Choose a reason for hiding this comment

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

I don't understand

The Crossplane {{< hover label="provider" line="3" >}}Provider{{</hover>}}
installs the Kubernetes _Custom Resource Definitions_ (CRDs) representing Kubernetes objects.
These CRDs allow you to create resources inside Kubernetes.
Verify the provider installed with `kubectl get providers`.


```shell {copy-lines="1",label="getProvider"}
kubectl get providers
NAME INSTALLED HEALTHY PACKAGE AGE
provider-kubernetes True True xpkg.upbound.io/upbound/provider-kubernetes:v1.16.2 38s
```



## Create a ProviderConfig
A `ProviderConfig` customizes the settings of the Kubernetes Provider.

```yaml
cat <<EOF | kubectl apply -f -
apiVersion: kubernetes.crossplane.io/v1alpha1
kind: ProviderConfig
metadata:
name: kubernetes-provider
spec:
credentials:
source: InjectedIdentity
EOF
```



## Create a Composite resource definition
A `CompositeResourceDefinition` (XRDs) define the schema for a custom API.
Users create composite resources (XRs) and Claims (XCs) using the API schema defined by an XRD.

```yaml
cat <<EOF | kubectl apply -f -
apiVersion: apiextensions.crossplane.io/v1
kind: CompositeResourceDefinition
metadata:
name: xkubernetesapps.kubernetes.example.org
spec:
group: kubernetes.example.org
names:
kind: XKubernetesApp
plural: xkubernetesapps
versions:
- name: v1alpha1
served: true
referenceable: true
schema:
openAPIV3Schema:
type: object
properties:
spec:
type: object
properties:
replicas:
type: integer
default: 2
image:
type: string
default: nginx:latest
port:
type: integer
default: 80
hostname:
type: string
default: example.com
required:
- replicas
- image
- port
- hostname
EOF
```
## Create a Composition
A `Composition` is a template for creating multiple managed resources as a single object.
A Composition composes individual managed resources together into a larger, reusable, solution.

```yaml
cat <<EOF | kubectl apply -f -
apiVersion: apiextensions.crossplane.io/v1
kind: Composition
metadata:
name: xkubernetesapp-composition
spec:
compositeTypeRef:
apiVersion: kubernetes.example.org/v1alpha1
kind: XKubernetesApp
resources:
- name: deployment
base:
apiVersion: kubernetes.crossplane.io/v1alpha2
kind: Object
spec:
forProvider:
manifest:
apiVersion: apps/v1
kind: Deployment
metadata:
name: example-deployment
namespace: default
spec:
replicas: 1
selector:
matchLabels:
app: example-app
template:
metadata:
labels:
app: example-app
spec:
containers:
- name: example-container
image: nginx:latest
ports:
- containerPort: 80
providerConfigRef:
name: kubernetes-provider
patches:
- fromFieldPath: "spec.replicas"
toFieldPath: "spec.forProvider.manifest.spec.replicas"
- fromFieldPath: "spec.image"
toFieldPath: "spec.forProvider.manifest.spec.template.spec.containers[0].image"
- name: service
base:
apiVersion: kubernetes.crossplane.io/v1alpha2
kind: Object
spec:
forProvider:
manifest:
apiVersion: v1
kind: Service
metadata:
name: example-service
namespace: default
spec:
selector:
app: example-app
ports:
- protocol: TCP
port: 80
targetPort: 80
providerConfigRef:
name: kubernetes-provider
patches:
- fromFieldPath: "spec.port"
toFieldPath: "spec.forProvider.manifest.spec.ports[0].port"
EOF
```
## Create an Abstracted application
Leverage the composition to create an abstraction

```yaml
cat <<EOF | kubectl apply -f -
apiVersion: kubernetes.example.org/v1alpha1
kind: XKubernetesApp
metadata:
name: my-kubernetes-app
spec:
replicas: 3
image: nginx
port: 8080
hostname: my-app.example.com
EOF
```
```shell
kubectl get pods
NAME READY STATUS RESTARTS AGE
example-deployment-5f76bbff9b-c5n2r 1/1 Running 0 15s
example-deployment-5f76bbff9b-lch2p 1/1 Running 0 12s
example-deployment-5f76bbff9b-w5n9h 1/1 Running 0 20s
```
* Explore Kubernetes resources that Crossplane can configure in the
[Provider CRD reference](https://marketplace.upbound.io/providers/upbound/kubernetes-provider/).
* Join the [Crossplane Slack](https://slack.crossplane.io/) and connect with
Crossplane users and contributors.