Grafana
Grafana 是一个开源的监控解决方案,可以用来为 Istio 配置仪表板。您可以使用 Grafana 来监控 Istio 及部署在服务网格内的应用程序。
配置
尽管可以构建自己的仪表板,但 Istio 同时也提供了一组预先配置的仪表板用来监视网格和控制平面的所有最重要的指标。
- Mesh Dashboard 为运行在网格中的所有服务提供概览视图。
- Service Dashboard 为服务提供详细的分类指标。
- Workload Dashboard 为负载提供详细的分类指标。
- Performance Dashboard 监控网格资源使用情况。
- Control Plane Dashboard 监控控制面的健康状况及性能指标.
可以通过多种方法来配置 Grafana 来使用这些仪表板:
方法1:快速开始
Istio 提供了一个基本的安装示例,以快速让 Grafana 启动和运行,与所有已经安装的 Istio 仪表板捆绑在一起:
$ kubectl apply -f https://raw.githubusercontent.com/istio/istio/release-1.15/samples/addons/grafana.yaml
通过 kubectl apply 方式将 Grafana 部署到集群中。该策略仅用于演示,并没有针对性能或安全性进行调优。
方法2:从 grafana.com
导入已经部署的 Deployment
如果想要快速地将Istio仪表板导入到现有的Grafana实例中,您可以使用 Grafana UI 中的 Import 按钮 来添加上面的仪表板链接。当导入仪表板时,请注意必须选择一个 Prometheus 数据源。
也可以使用脚本一次导入所有仪表板。例如:
$ # Address of Grafana
$ GRAFANA_HOST="http://localhost:3000"
$ # Login credentials, if authentication is used
$ GRAFANA_CRED="USER:PASSWORD"
$ # The name of the Prometheus data source to use
$ GRAFANA_DATASOURCE="Prometheus"
$ # The version of Istio to deploy
$ VERSION=1.15.3
$ # Import all Istio dashboards
$ for DASHBOARD in 7639 11829 7636 7630 7645; do
$ REVISION="$(curl -s https://grafana.com/api/dashboards/${DASHBOARD}/revisions -s | jq ".items[] | select(.description | contains(\"${VERSION}$\")) | .revision")"
$ curl -s https://grafana.com/api/dashboards/${DASHBOARD}/revisions/${REVISION}/download > /tmp/dashboard.json
$ echo "Importing $(cat /tmp/dashboard.json | jq -r '.title') (revision ${REVISION}, id ${DASHBOARD})..."
$ curl -s -k -u "$GRAFANA_CRED" -XPOST \
$ -H "Accept: application/json" \
$ -H "Content-Type: application/json" \
$ -d "{\"dashboard\":$(cat /tmp/dashboard.json),\"overwrite\":true, \
$ \"inputs\":[{\"name\":\"DS_PROMETHEUS\",\"type\":\"datasource\", \
$ \"pluginId\":\"prometheus\",\"value\":\"$GRAFANA_DATASOURCE\"}]}" \
$ $GRAFANA_HOST/api/dashboards/import
$ echo -e "\nDone\n"
$ done
方法3:特定的实现方法
Grafana 可以通过其他方法进行安装和配置。要导入 Istio 仪表板,请参考文档中的安装方法。例如:
- Grafana provisioning 官方文档.
- Importing dashboards
stable/grafana
Helm chart 文档.