From 0e27a3db68309c82ce2757160f09d12df9bdb7f9 Mon Sep 17 00:00:00 2001 From: goll <adrian.goll@gmail.com> Date: Thu, 18 Apr 2019 10:02:22 +0200 Subject: [PATCH] README fixes, Dockerfile bump --- README.md | 96 ++++++------- jsonnetfile.lock.json | 8 +- manifests/grafana-dashboardDefinitions.yaml | 142 +++++++++++++++++++- scripts/jsonnet/Dockerfile | 5 +- 4 files changed, 188 insertions(+), 63 deletions(-) diff --git a/README.md b/README.md index 8f1e8eb9..eb41d39b 100644 --- a/README.md +++ b/README.md @@ -58,17 +58,17 @@ This adapter is an Extension API Server and Kubernetes needs to be have this fea ### minikube -In order to just try out this stack, start minikube with the following command: +In order to just try out this stack, start [minikube](https://github.com/kubernetes/minikube) with the following command: -``` -$ minikube delete && minikube start --kubernetes-version=v1.13.2 --memory=4096 --bootstrapper=kubeadm --extra-config=kubelet.authentication-token-webhook=true --extra-config=kubelet.authorization-mode=Webhook --extra-config=scheduler.address=0.0.0.0 --extra-config=controller-manager.address=0.0.0.0 +```shell +$ minikube delete && minikube start --kubernetes-version=v1.13.5 --memory=4096 --bootstrapper=kubeadm --extra-config=kubelet.authentication-token-webhook=true --extra-config=kubelet.authorization-mode=Webhook --extra-config=scheduler.address=0.0.0.0 --extra-config=controller-manager.address=0.0.0.0 ``` -> The kube-prometheus stack includes a resource metrics API server, like the metrics-server does. So ensure the metrics-server plugin is disabled on minikube: -> -> ``` -> minikube addons disable metrics-server -> ``` +The kube-prometheus stack includes a resource metrics API server, like the metrics-server does. So ensure the metrics-server plugin is disabled on minikube: + +```shell +$ minikube addons disable metrics-server +``` ## Quickstart @@ -76,7 +76,7 @@ This project is intended to be used as a library (i.e. the intent is not for you Though for a quickstart a compiled version of the Kubernetes [manifests](manifests) generated with this library (specifically with `example.jsonnet`) is checked into this repository in order to try the content out quickly. To try out the stack un-customized run: * Simply create the stack: -``` +```shell $ kubectl create -f manifests/ # It can take a few seconds for the above 'create manifests' command to fully create the following resources, so verify the resources are ready before proceeding. @@ -87,7 +87,7 @@ $ kubectl apply -f manifests/ # This command sometimes may need to be done twice ``` * And to teardown the stack: -``` +```shell $ kubectl delete -f manifests/ ``` @@ -100,7 +100,7 @@ Prometheus, Grafana, and Alertmanager dashboards can be accessed quickly using ` Prometheus ```shell -kubectl --namespace monitoring port-forward svc/prometheus-k8s 9090 +$ kubectl --namespace monitoring port-forward svc/prometheus-k8s 9090 ``` Then access via [http://localhost:9090](http://localhost:9090) @@ -108,7 +108,7 @@ Then access via [http://localhost:9090](http://localhost:9090) Grafana ```shell -kubectl --namespace monitoring port-forward svc/grafana 3000 +$ kubectl --namespace monitoring port-forward svc/grafana 3000 ``` Then access via [http://localhost:3000](http://localhost:3000) and use the default grafana user:password of `admin:admin`. @@ -116,7 +116,7 @@ Then access via [http://localhost:3000](http://localhost:3000) and use the defau Alert Manager ```shell -kubectl --namespace monitoring port-forward svc/alertmanager-main 9093 +$ kubectl --namespace monitoring port-forward svc/alertmanager-main 9093 ``` Then access via [http://localhost:9093](http://localhost:9093) @@ -132,7 +132,7 @@ This section: The content of this project consists of a set of [jsonnet](http://jsonnet.org/) files making up a library to be consumed. Install this library in your own project with [jsonnet-bundler](https://github.com/jsonnet-bundler/jsonnet-bundler#install) (the jsonnet package manager): -``` +```shell $ mkdir my-kube-prometheus; cd my-kube-prometheus $ jb init # Creates the initial/empty `jsonnetfile.json` # Install the kube-prometheus dependency @@ -144,7 +144,9 @@ $ jb install github.com/coreos/kube-prometheus/jsonnet/kube-prometheus # Creates > An e.g. of how to install a given version of this library: `jb install github.com/coreos/prometheus-operator/contrib/kube-prometheus/jsonnet/kube-prometheus/@v0.22.0` In order to update the kube-prometheus dependency, simply use the jsonnet-bundler update functionality: -`$ jb update` +```shell +$ jb update +``` ### Compiling @@ -201,54 +203,41 @@ This script runs the jsonnet code, then reads each key of the generated json and ### Apply the kube-prometheus stack The previous steps (compilation) has created a bunch of manifest files in the manifest/ folder. -Now simply use kubectl to install Prometheus and Grafana as per your configuration: +Now simply use `kubectl` to install Prometheus and Grafana as per your configuration: -`kubectl apply -f manifests/` +```shell +$ kubectl apply -f manifests/ +``` Check the monitoring namespace (or the namespace you have specific in `namespace: `) and make sure the pods are running. Prometheus and Grafana should be up and running soon. ### Containerized Installing and Compiling If you don't care to have `jb` nor `jsonnet` nor `gojsontoyaml` installed, then build the `po-jsonnet` Docker image (this is something you'll need a copy of this repository for). Do the following from this `kube-prometheus` directory: -``` -$ make ../../hack/jsonnet-docker-image +```shell +$ make hack/jsonnet-docker-image ``` Then you can do commands such as the following: -``` -docker run \ - --rm \ - -v `pwd`:`pwd` \ - --workdir `pwd` \ - po-jsonnet jb init - -docker run \ - --rm \ - -v `pwd`:`pwd` \ - --workdir `pwd` \ - po-jsonnet jb install github.com/coreos/prometheus-operator/contrib/kube-prometheus/jsonnet/kube-prometheus - -docker run \ - --rm \ - -v `pwd`:`pwd` \ - --workdir `pwd` \ - po-jsonnet ./build.sh example.jsonnet +```shell +$ docker run --rm -v $(pwd):$(pwd) --workdir $(pwd) po-jsonnet jb update +$ docker run --rm -v $(pwd):$(pwd) --workdir $(pwd) po-jsonnet ./build.sh example.jsonnet ``` ## Update from upstream project You may wish to fetch changes made on this project so they are available to you. ### Update jb -jb may have been updated so it's a good idea to get the latest version of this binary +`jb` may have been updated so it's a good idea to get the latest version of this binary: -``` -go get -u github.com/jsonnet-bundler/jsonnet-bundler/cmd/jb +```shell +$ go get -u github.com/jsonnet-bundler/jsonnet-bundler/cmd/jb ``` ### Update kube-prometheus -The command below will sync with upstream project. -``` -jb update +The command below will sync with upstream project: +```shell +$ jb update ``` ### Compile the manifests and apply @@ -266,13 +255,13 @@ These are the available fields with their respective default values: namespace: "default", versions+:: { - alertmanager: "v0.16.1", + alertmanager: "v0.16.2", nodeExporter: "v0.17.0", kubeStateMetrics: "v1.5.0", kubeRbacProxy: "v0.4.1", addonResizer: "1.8.4", prometheusOperator: "v0.29.0", - prometheus: "v2.5.0", + prometheus: "v2.7.2", }, imageRepos+:: { @@ -408,12 +397,12 @@ To produce the `docker pull/tag/push` commands that will synchronize upstream im ```shell $ jsonnet -J vendor -S --tla-str repository=internal-registry.com/organization sync-to-internal-registry.jsonnet -docker pull k8s.gcr.io/addon-resizer:1.8.4 -docker tag k8s.gcr.io/addon-resizer:1.8.4 internal-registry.com/organization/addon-resizer:1.8.4 -docker push internal-registry.com/organization/addon-resizer:1.8.4 -docker pull quay.io/prometheus/alertmanager:v0.16.1 -docker tag quay.io/prometheus/alertmanager:v0.16.1 internal-registry.com/organization/alertmanager:v0.16.1 -docker push internal-registry.com/organization/alertmanager:v0.16.1 +$ docker pull k8s.gcr.io/addon-resizer:1.8.4 +$ docker tag k8s.gcr.io/addon-resizer:1.8.4 internal-registry.com/organization/addon-resizer:1.8.4 +$ docker push internal-registry.com/organization/addon-resizer:1.8.4 +$ docker pull quay.io/prometheus/alertmanager:v0.16.2 +$ docker tag quay.io/prometheus/alertmanager:v0.16.2 internal-registry.com/organization/alertmanager:v0.16.2 +$ docker push internal-registry.com/organization/alertmanager:v0.16.2 ... ``` @@ -626,7 +615,6 @@ the following process: 1. Make your changes in the respective `*.jsonnet` file. 2. Commit your changes (This is currently necessary due to our vendoring process. This is likely to change in the future). -3. Update the pinned kube-prometheus dependency in `jsonnetfile.lock.json`: `jb - update`. -3. Generate dependent `*.yaml` files: `make generate-in-docker`. +3. Update the pinned kube-prometheus dependency in `jsonnetfile.lock.json`: `jb update` +3. Generate dependent `*.yaml` files: `make generate-in-docker` 4. Commit the generated changes. diff --git a/jsonnetfile.lock.json b/jsonnetfile.lock.json index a6808e93..a04fa3de 100644 --- a/jsonnetfile.lock.json +++ b/jsonnetfile.lock.json @@ -8,7 +8,7 @@ "subdir": "jsonnet/kube-prometheus" } }, - "version": "cb4b913c32d053cddb5d4a2d572eaf11b55d8971" + "version": "4d91bed7405bcc6929f71452d7cc3735284da69d" }, { "name": "ksonnet", @@ -28,7 +28,7 @@ "subdir": "" } }, - "version": "c4acc6e194632ca134fe56de7e4e4e9c7cef2221" + "version": "6187d7dbbf4bf0b7d34d08e6773dc0e101676c58" }, { "name": "grafonnet", @@ -48,7 +48,7 @@ "subdir": "grafana-builder" } }, - "version": "11d1552f120f2d9e8d932a671faf67beae91503a" + "version": "233757a0a9047eb74993c977cd5b1be0fb54e8d6" }, { "name": "grafana", @@ -78,7 +78,7 @@ "subdir": "Documentation/etcd-mixin" } }, - "version": "f29b1ada19713544b698dab8c94c97cfa1e83dac" + "version": "cd7ffbe2270d5290e708f55edfbfae840ec879bb" } ] } diff --git a/manifests/grafana-dashboardDefinitions.yaml b/manifests/grafana-dashboardDefinitions.yaml index d07d6a06..5efcb65f 100644 --- a/manifests/grafana-dashboardDefinitions.yaml +++ b/manifests/grafana-dashboardDefinitions.yaml @@ -7299,6 +7299,13 @@ items: "intervalFactor": 2, "legendFormat": "load 15m", "refId": "C" + }, + { + "expr": "count(node_cpu_seconds_total{cluster=\"$cluster\", job=\"node-exporter\", instance=\"$instance\", mode=\"user\"})", + "format": "time_series", + "intervalFactor": 2, + "legendFormat": "logical cores", + "refId": "D" } ], "thresholds": [ @@ -8947,7 +8954,20 @@ items: ], "annotations": { "list": [ - + { + "builtIn": 1, + "datasource": "$datasource", + "enable": true, + "expr": "time() == BOOL timestamp(rate(kube_pod_container_status_restarts_total{job=\"kube-state-metrics\", cluster=\"$cluster\", namespace=\"$namespace\", pod=\"$pod\"}[2m]) > 0)", + "hide": false, + "iconColor": "rgba(215, 44, 44, 1)", + "name": "Restarts", + "showIn": 0, + "tags": [ + "restart" + ], + "type": "rows" + } ] }, "editable": false, @@ -9027,6 +9047,13 @@ items: "intervalFactor": 2, "legendFormat": "Limit: {{ container }}", "refId": "C" + }, + { + "expr": "sum by(container_name) (container_memory_cache{job=\"kubelet\", namespace=\"$namespace\", pod_name=~\"$pod\", container_name=~\"$container\", container_name!=\"POD\"})", + "format": "time_series", + "intervalFactor": 2, + "legendFormat": "Cache: {{ container_name }}", + "refId": "D" } ], "thresholds": [ @@ -9247,8 +9274,15 @@ items: "expr": "sort_desc(sum by (pod_name) (rate(container_network_receive_bytes_total{job=\"kubelet\", cluster=\"$cluster\", namespace=\"$namespace\", pod_name=\"$pod\"}[1m])))", "format": "time_series", "intervalFactor": 2, - "legendFormat": "{{ pod_name }}", + "legendFormat": "RX: {{ pod_name }}", "refId": "A" + }, + { + "expr": "sort_desc(sum by (pod_name) (rate(container_network_transmit_bytes_total{job=\"kubelet\", cluster=\"$cluster\", namespace=\"$namespace\", pod_name=\"$pod\"}[1m])))", + "format": "time_series", + "intervalFactor": 2, + "legendFormat": "TX: {{ pod_name }}", + "refId": "B" } ], "thresholds": [ @@ -9299,6 +9333,110 @@ items: "title": "Dashboard Row", "titleSize": "h6", "type": "row" + }, + { + "collapse": false, + "collapsed": false, + "panels": [ + { + "aliasColors": { + + }, + "bars": false, + "dashLength": 10, + "dashes": false, + "datasource": "$datasource", + "fill": 1, + "gridPos": { + + }, + "id": 5, + "legend": { + "alignAsTable": true, + "avg": true, + "current": true, + "max": false, + "min": false, + "rightSide": true, + "show": true, + "total": false, + "values": false + }, + "lines": true, + "linewidth": 1, + "links": [ + + ], + "nullPointMode": "null", + "percentage": false, + "pointradius": 5, + "points": false, + "renderer": "flot", + "repeat": null, + "seriesOverrides": [ + + ], + "spaceLength": 10, + "span": 12, + "stack": false, + "steppedLine": false, + "targets": [ + { + "expr": "max by (container) (kube_pod_container_status_restarts_total{job=\"kube-state-metrics\", cluster=\"$cluster\", namespace=\"$namespace\", pod=\"$pod\", container=~\"$container\"})", + "format": "time_series", + "intervalFactor": 2, + "legendFormat": "Restarts: {{ container }}", + "refId": "A" + } + ], + "thresholds": [ + + ], + "timeFrom": null, + "timeShift": null, + "title": "Total Restarts Per Container", + "tooltip": { + "shared": false, + "sort": 0, + "value_type": "individual" + }, + "type": "graph", + "xaxis": { + "buckets": null, + "mode": "time", + "name": null, + "show": true, + "values": [ + + ] + }, + "yaxes": [ + { + "format": "short", + "label": null, + "logBase": 1, + "max": null, + "min": 0, + "show": true + }, + { + "format": "short", + "label": null, + "logBase": 1, + "max": null, + "min": 0, + "show": true + } + ] + } + ], + "repeat": null, + "repeatIteration": null, + "repeatRowId": null, + "showTitle": false, + "title": "Dashboard Row", + "titleSize": "h6", + "type": "row" } ], "schemaVersion": 14, diff --git a/scripts/jsonnet/Dockerfile b/scripts/jsonnet/Dockerfile index d7bfb313..bf68d6fd 100644 --- a/scripts/jsonnet/Dockerfile +++ b/scripts/jsonnet/Dockerfile @@ -1,9 +1,8 @@ -FROM golang:1.11-stretch +FROM golang:1.12-stretch ENV JSONNET_VERSION 0.12.1 -RUN apt-get update -y && apt-get install -y g++ make git jq && \ - rm -rf /var/lib/apt/lists/* +RUN apt-get update -y && apt-get install -y jq && rm -rf /var/lib/apt/lists/* RUN curl -Lso - https://github.com/google/jsonnet/archive/v${JSONNET_VERSION}.tar.gz | \ tar xfz - -C /tmp && \ cd /tmp/jsonnet-${JSONNET_VERSION} && \ -- GitLab