Skip to content

Commit

Permalink
Add feedback from Stefan and Sandor
Browse files Browse the repository at this point in the history
Signed-off-by: Alex Ellis (OpenFaaS Ltd) <[email protected]>
  • Loading branch information
alexellis committed Aug 11, 2019
1 parent e994467 commit dc69e97
Showing 1 changed file with 31 additions and 34 deletions.
65 changes: 31 additions & 34 deletions docs/tutorials/kubernetes-hpa.md
Original file line number Diff line number Diff line change
Expand Up @@ -91,43 +91,40 @@ queue-worker-544bcb7c67-72l72 1m 3Mi
### Disable auto-scaling with OpenFaaS

Disable auto-scaling by scaling alertmanager down to zero replicas, this will stop it from firing alerts.

```sh
kubectl scale -n openfaas deploy/alertmanager --replicas=0
```
You can either disable the OpenFaaS auto-scaling functionality completely, or just on a per-function basis

### Configure Prometheus to scrape the Kubernetes API server

The metrics available via kubectl top / pod can now be scraped with Prometheus. OpenFaaS ships with Prometheus, and you could reconfigure that version to do this task, but for the tutorial we will install it again.

```
kubectl create namespace prometheus
helm install stable/prometheus \
--name prometheus \
--namespace prometheus \
--set alertmanager.persistentVolume.enabled=false,server.persistentVolume.enabled=false,pushgateway.enabled=false
```
#### Disable auto-scaling from OpenFaaS on a per function basis

You will see that a number of pods have been created including "node-exporter" which fetches statistics about each node such as free disk space and CPU utilization.
If you want to mix OpenFaaS auto-scaling and HPAv2, then add the additional label when deploying your functions:

```
kubectl get pods -n prometheus
faas-cli deploy --label com.openfaas.scale.factor=0
```

Now port-forward the Prometheus dashboard:
Or add the label to your `stack.yml` YAML file:

```
kubectl --namespace=prometheus port-forward deploy/prometheus-server 9090
```yaml
version: 1.0
provider:
name: openfaas
gateway: http://127.0.0.1:31112
functions:
nodeinfo:
image: functions/nodeinfo:latest
skip_build: true
requests:
cpu: 10m
labels:
com.openfaas.scale.factor: 0
```
From here you can open a browser at `http://127.0.0.1:9090`
#### Disable auto-scaling from OpenFaaS on all functions
Prometheus has been configured to use the Kubernetes service discovery mechanism. It will find any Pods with metrics then scrape them.
Disable auto-scaling by scaling alertmanager down to zero replicas, this will stop it from firing alerts.
* See your targets at: http://127.0.0.1:9090/targets
* Enter query such as `container_memory_usage_bytes` on the Graph page.
```sh
kubectl scale -n openfaas deploy/alertmanager --replicas=0
```

### Deploy your first function

Expand Down Expand Up @@ -190,7 +187,7 @@ horizontalpodautoscaler.autoscaling/nodeinfo autoscaled

View the HPA record with:

```
```sh
kubectl get hpa/nodeinfo -n openfaas-fn

NAME REFERENCE TARGETS MINPODS MAXPODS REPLICAS AGE
Expand All @@ -203,7 +200,7 @@ kubectl get hpa/nodeinfo -n openfaas-fn -o yaml

You can use `kubectl describe hpa/nodeinfo -n openfaas-fn` to get detailed information including any events such as scaling up and down.

```
```sh
kubectl describe hpa/nodeinfo -n openfaas-fn

Name: nodeinfo
Expand All @@ -230,7 +227,7 @@ Events: <none>

Use the following command with hey

```
```sh
export OPENFAAS_URL=http://127.0.0.1:31112

hey -c 5 \
Expand All @@ -245,23 +242,23 @@ You should note that HPA is designed to react slowly to changes in traffic, both

Now in a new window monitor the progress:

```
```sh
kubectl describe hpa/nodeinfo -n openfaas
```

Or in an automated fashion:

```
```sh
# watch -n 5 "kubectl describe hpa/nodeinfo -n openfaas-fn"
```

You can also monitor the replicas of your function in the OpenFaaS UI or via the CLI:

```
```sh
watch -n 5 "faas-cli list"
```

Here is ane example of the replicas scaling up in response to the traffic created by `hey`:
Here is an example of the replicas scaling up in response to the traffic created by `hey`:

```sh
Name: nodeinfo
Expand Down Expand Up @@ -292,7 +289,7 @@ Note that whilst the scaling up was relatively quick, the scale-down may take si

## 3. Wrapping up

In this tutorial we disabled the auto-scaling built into OpenFaaS which uses Prometheus and Alertmanager, and added in Kubernetes' own HPAv2 mechanism, its metrics-server and another deployment of Prometheus.
In this tutorial we disabled the auto-scaling built into OpenFaaS which uses Prometheus and Alertmanager, and added in Kubernetes' own HPAv2 mechanism and its metrics-server.

### Notes and caveats

Expand Down

0 comments on commit dc69e97

Please sign in to comment.