热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

k8s笔记12grafana的配置和常见使用

k8s笔记12--grafana的配置和常见使用1介绍2安装和配置3注意事项4说明1介绍Grafana是用Go语言开发的开源数据可视化应用,其可以做数据监控和数据统

k8s笔记12--grafana的配置和常见使用

  • 1 介绍
  • 2 安装和配置
  • 3 注意事项
  • 4 说明


1 介绍

Grafana 是用Go语言开发的开源数据可视化应用,其可以做数据监控和数据统计,且带有告警功能, 它当前最流行的指标可视化开源软件。
根据官方介绍,Grafana允许我们查询、可视化、警告和理解指标,不论它们存储在哪里;它能让我们的团队一起创建、探索和分享漂亮的仪表板,并培养一种数据驱动的文化。
本文根据需要在k8s集群中创建grafana,并对接Prometheus的数据源;后续笔者也会持续在本文中更新grafana相关的常见使用方法和注意事项。

2 安装和配置

新建deployment

vim dep-grafana.yaml
apiVersion: apps/v1
kind: Deployment
metadata:creationTimestamp: nulllabels:app: grafananame: grafananamespace: lens-metrics
spec:replicas: 1selector:matchLabels:app: grafanastrategy: {}template:metadata:creationTimestamp: nulllabels:app: grafanaspec:containers:- image: grafana/grafana:7.5.3name: grafanaports:- containerPort: 3000name: grafanaresources: {}
status: {}kubectl apply -f dep-grafana.yaml

创建service

cat svc-grafana.yaml
apiVersion: v1
kind: Service
metadata:creationTimestamp: nulllabels:app: grafananame: grafana-svc
spec:ports:- port: 3000protocol: TCPtargetPort: 3000selector:app: grafanatype: NodePort
status:loadBalancer: {}kubectl -n lens-metrics apply -f svc-grafana.yaml

创建成功后可以通过lens查看到service的信息,此处使用NodePort类型,方便外部访问
在这里插入图片描述
通过ip 和 NodePort http://192.168.2.21:30190/ 即可访问grafana,默认账号/密码为 admin/admin, 如下图所示:
在这里插入图片描述
正常登录到grafana后,我们就可以给其添加数据了,此处添加Prometheus数据,在Configuration
->Data Sources->Add data source->选择Prometheus即可;
此处为了方便测试将Prometheus的service type 也设置为 NodePort了,实际项目中可以对Prometheus单独设置一个域名或者加一个LB。
在这里插入图片描述
添加后就可以新建dashboard 并按需添加各类图表了,如下添加了一个统计pod数量的曲线
在这里插入图片描述

3 注意事项
  1. grafana 数据吃就化

    默认pod重启后grafana就被初始化了,一因此我们需要将其持久化, 在容器启动后将 /var/lib/grafana /usr/share/grafana /etc/grafana/grafana.ini 拷贝到本地,然后更新 deployment 将其挂载到容器中,具体配置如下apiVersion: apps/v1
    kind: Deployment
    metadata:creationTimestamp: nulllabels:app: grafananame: grafananamespace: lens-metrics
    spec:replicas: 1selector:matchLabels:app: grafanastrategy: {}template:metadata:creationTimestamp: nulllabels:app: grafanaspec:containers:- image: grafana/grafana:8.5.2name: grafanaports:- containerPort: 3000name: grafanaresources: {}volumeMounts:- mountPath: /var/lib/grafananame: var-lib-grafana- mountPath: /usr/share/grafananame: usr-share-grafana- mountPath: /etc/grafana/grafana.ininame: grafana-inivolumes:- name: usr-share-grafanahostPath:path: /home/xg/data/grafana/usr/share/grafanatype: "Directory"- name: var-lib-grafanahostPath:path: /home/xg/data/grafana/var/lib/grafanatype: "Directory"- name: grafana-inihostPath:path: /home/xg/data/grafana/etc/grafana/grafana.initype: "File"nodeSelector:node-type: knode
    status: {}

  2. 重置admin密码

    cd /usr/share/grafana
    grafana-cli admin reset-admin-password admin
    然后重启pod(前提需要将grafana核心数据持久化到本地存储)


4 说明
  1. 软件版本
    quay.io/prometheus/prometheus:v2.19.3
    grafana/grafana:7.5.3
    k8s 19.4
  2. 参考文档
    grafana.com/docs
    grafana 添加数据源
    docs/prometheus/latest/querying/basics

推荐阅读
  • 在Kubernetes上部署多个Mitmproxy代理服务器以实现高效流量管理 ... [详细]
  • 本文详细介绍了 Kubernetes 集群管理工具 kubectl 的基本使用方法,涵盖了一系列常用的命令及其应用场景,旨在帮助初学者快速掌握 kubectl 的基本操作。 ... [详细]
  • Envoy 流量分配策略优化
    在本研究中,我们对Envoy的流量分配策略进行了优化,旨在提高系统的稳定性和性能。实验环境包括一个前端代理服务(Envoy,IP地址为172.31.57.10)和五个后端服务。通过调整Envoy的配置,实现了更高效的流量分发和负载均衡,显著提升了整体系统的响应速度和可靠性。 ... [详细]
  • 前言: 网上搭建k8s的文章很多,但很多都无法按其说明在阿里云ecs服务器成功搭建,所以我就花了些时间基于自己成功搭建k8s的步骤写了个操作手册,希望对想搭建k8s环境的盆友有所帮 ... [详细]
  • CentOS 7.6环境下Prometheus与Grafana的集成部署指南
    本文旨在提供一套详细的步骤,指导读者如何在CentOS 7.6操作系统上成功安装和配置Prometheus 2.17.1及Grafana 6.7.2-1,实现高效的数据监控与可视化。 ... [详细]
  • 本文档详细介绍了在 Kubernetes 集群中部署 ETCD 数据库的过程,包括实验环境的准备、ETCD 证书的生成及配置、以及集群的启动与健康检查等关键步骤。 ... [详细]
  • 本文基于《Linux命令行与Shell脚本编程大全》第三版的第十一章内容,探讨了如何构建基本的Shell脚本,包括命令组合、脚本创建、消息显示、变量使用、输入输出重定向、管道、数学运算及脚本退出等方面的知识。 ... [详细]
  • 深入探讨配置文件的管理与优化
    尽管配置文件的重要性不言而喻,但其管理和安全性问题却常被忽视。本文将详细讨论配置文件的不同管理策略及其优缺点。 ... [详细]
  • 本文详细介绍了如何利用go-zero框架从需求分析到最终部署至Kubernetes的全过程,特别聚焦于微服务架构中的网关设计与实现。项目采用了go-zero及其生态组件,涵盖了从API设计到RPC调用,再到生产环境下的监控与维护等多方面内容。 ... [详细]
  • 在 Kubernetes 中,Pod 的调度通常由集群的自动调度策略决定,这些策略主要关注资源充足性和负载均衡。然而,在某些场景下,用户可能需要更精细地控制 Pod 的调度行为,例如将特定的服务(如 GitLab)部署到特定节点上,以提高性能或满足特定需求。本文深入解析了 Kubernetes 的亲和性调度机制,并探讨了多种优化策略,帮助用户实现更高效、更灵活的资源管理。 ... [详细]
  • prometheus09-k8s部署grafana
    1.部署grafana?apiVersion:?appsv1?kind:?StatefulSet?metadata:??name:?grafana??namespace:?kube-systemspec:??serviceName:?grafana??repl ... [详细]
  • 在寻找轻量级Ruby Web框架的过程中,您可能会遇到Sinatra和Ramaze。两者都以简洁、轻便著称,但它们之间存在一些关键区别。本文将探讨这些差异,并提供详细的分析,帮助您做出最佳选择。 ... [详细]
  • 58同城的Elasticsearch应用与平台构建实践
    本文由58同城高级架构师于伯伟分享,由陈树昌编辑整理,内容源自DataFunTalk。文章探讨了Elasticsearch作为分布式搜索和分析引擎的应用,特别是在58同城的实施案例,包括集群优化、典型应用实例及自动化平台建设等方面。 ... [详细]
  • 本文详细介绍了 InfluxDB、collectd 和 Grafana 的安装与配置流程。首先,按照启动顺序依次安装并配置 InfluxDB、collectd 和 Grafana。InfluxDB 作为时序数据库,用于存储时间序列数据;collectd 负责数据的采集与传输;Grafana 则用于数据的可视化展示。文中提供了 collectd 的官方文档链接,便于用户参考和进一步了解其配置选项。通过本指南,读者可以轻松搭建一个高效的数据监控系统。 ... [详细]
  • 本书《.NET Core 2.* 开发者指南》是面向开发者的全面学习与实践手册,涵盖了从基础到高级的各个层面。书中详细解析了 .NET Core 的核心概念,包括如何创建 .NET Core 网站,并通过视频教程直观展示操作过程。此外,还深入探讨了 Startup 类的作用、项目目录结构的组织方式以及如何在应用中使用静态文件等内容。对于希望深入了解 .NET Core 架构和开发技巧的开发者来说,本书提供了丰富的实践案例和详尽的技术指导。 ... [详细]
author-avatar
好几个健康2002_408
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有