目录
[2.OpenEuler 部署 Prometheus](#2.OpenEuler 部署 Prometheus)
[3.OpenEuler 部署 Grafana](#3.OpenEuler 部署 Grafana)
一、实验
1.环境
(1)主机
表1 主机
|-------|--------------|---------------|-------------------------------------------------------------|-----------|
| 系统 | 架构 | 版本 | IP | 备注 |
| Linux | openEuler | 22.03 LTS SP2 | 192.168.204.145(动态) 192.168.204.141(静态) 192.168.204.142(静态) | |
| | docker | 25.0.3 | | |
| | cpolar (客户端) | 3.12 | | 服务器端 3.22 |
(2)查看系统版本
bash
[root@localhost ~]# cat /etc/os-release
data:image/s3,"s3://crabby-images/423ea/423ea03813dfd96308966d8976fe75ada1d6d381" alt=""
(3) 查看网络ip
bash
[root@localhost ~]# ip addr
data:image/s3,"s3://crabby-images/26a02/26a02b2bac21f0fb0d8cf5adcee581c9d905bf43" alt=""
(4) 查看docker版本
bash
[root@localhost ~]# docker --version
data:image/s3,"s3://crabby-images/0734f/0734fca9ef061283672a1fc8777c2f3db3a2b593" alt=""
2.OpenEuler 部署 Prometheus
(1) 拉取Prometheus镜像
bash
[root@localhost ~]# docker pull prom/prometheus
data:image/s3,"s3://crabby-images/ef226/ef226817c2079d84539a2e7a0c7aa1a601e1ba6a" alt=""
(2)拉取数据收集镜像
用于机器系统数据收集
bash
[root@localhost ~]# docker pull prom/node-exporter
data:image/s3,"s3://crabby-images/e4207/e4207ebaf348e07d753c6a116242c15d187ff0e7" alt=""
用于收集宿主机上的docker容器数据
bash
[root@localhost ~]# docker pull google/cadvisor
data:image/s3,"s3://crabby-images/7745c/7745c8e2b5f1319f6f15df6498a0adf69e955401" alt=""
(3)创建node-exporter容器
bash
[root@localhost ~]# docker run -d --name node-exporter --restart=always -p 9100:9100 -v "/proc:/host/proc:ro" -v "/sys:/host/sys:ro" -v "/:/rootfs:ro" prom/node-exporter
data:image/s3,"s3://crabby-images/783d4/783d4916062ab5593c1832bc5534991851b14d2d" alt=""
(4)监听端口
bash
[root@localhost ~]# netstat -antlp | grep 9100
data:image/s3,"s3://crabby-images/df0c7/df0c73d6a070a97c1fe40eff5a334f5045ed719d" alt=""
(5)访问
bash
http://192.168.204.141:9100/metrics
data:image/s3,"s3://crabby-images/86b09/86b09df340bd776f04466248fab7939ec85daf73" alt=""
(6)创建cadvisor容器
bash
[root@localhost ~]# docker run -v /:/rootfs:ro -v /var/run:/var/run:rw -v /sys:/sys:ro -v /var/lib/docker/:/var/lib/docker:ro -v /dev/disk/:/dev/disk:ro -p 8080:8080 -d --name=cadvisor --restart=always google/cadvisor:latest
data:image/s3,"s3://crabby-images/d183a/d183a7710c7763fbcd443b5ab2e404357738ecf7" alt=""
(7) 监听端口
bash
[root@localhost ~]# netstat -antlp | grep 8080
data:image/s3,"s3://crabby-images/520a1/520a11453fa65b4c4f62bb29f2264ba6835a655a" alt=""
(8)访问
bash
http://192.168.204.141:8080/metrics
data:image/s3,"s3://crabby-images/7e74a/7e74a0faf5b2b4b8131ae554d0de49128f7c1a14" alt=""
(9)创建配置文件
bash
[root@localhost ~]# mkdir /opt/prometheus
[root@localhost ~]# cd /opt/prometheus/
[root@localhost prometheus]# vim prometheus.yml
data:image/s3,"s3://crabby-images/b7b7d/b7b7d88c6e587381c4b8cafdc1441d2f26007695" alt=""
第一种方式:(容器地址)
bash
global:
scrape_interval: 60s
evaluation_interval: 60s
scrape_configs:
- job_name: prometheus
static_configs:
- targets: ['localhost:9090']
labels:
instance: prometheus
- job_name: linux
static_configs:
- targets: ['172.17.0.7:9100']
labels:
instance: localhost
- job_name: cadvisor
static_configs:
- targets: ['172.17.0.8:8080']
labels:
instance: cAdvisor
data:image/s3,"s3://crabby-images/b89f4/b89f455c9385dc962e8302cc899bbd5552c95803" alt=""
第二种方式:(宿主机地址)
bash
global:
scrape_interval: 60s
evaluation_interval: 60s
scrape_configs:
- job_name: prometheus
static_configs:
- targets: ['localhost:9090']
labels:
instance: prometheus
- job_name: linux
static_configs:
- targets: ['192.168.204.141:9100']
labels:
instance: localhost
- job_name: cadvisor
static_configs:
- targets: ['192.168.204.141:8080']
labels:
instance: cAdvisor
data:image/s3,"s3://crabby-images/8787f/8787fd5dcdf1759307f29d950980ab54cba403c8" alt=""
(10) 创建Prometheus容器
bash
[root@localhost prometheus]# docker run -d --name prometheus --restart=always -p 9090:9090 -v /opt/prometheus/prometheus.yml:/etc/prometheus/prometheus.yml prom/prometheus
data:image/s3,"s3://crabby-images/51e4d/51e4d89ff894e6bc6acbe2b515322ef1d18255d5" alt=""
(11)监听端口
bash
[root@localhost prometheus]# netstat -antlp | grep 9090
data:image/s3,"s3://crabby-images/e9626/e9626d041f3c8c591e69e43797c98e50db039aec" alt=""
(12)访问
bash
http://192.168.204.141:9090/graph
data:image/s3,"s3://crabby-images/afb11/afb11dbdc77262cd6ee065b7bf0619dcded14892" alt=""
访问targets(第一种方式的宿主机地址)
bash
http://192.168.204.141:9090/targets
data:image/s3,"s3://crabby-images/aae71/aae7192dc35ccefd22a0e5369c42c6ef38b0148f" alt=""
访问targets(第二种方式的容器地址)
bash
http://192.168.204.141:9090/targets
data:image/s3,"s3://crabby-images/2e9fe/2e9fe58d800049d4825923539cec89d325cd27eb" alt=""
3.OpenEuler 部署 Grafana
(1)拉取Grafana镜像
bash
[root@localhost ~]# docker pull grafana/grafana
data:image/s3,"s3://crabby-images/2c7c5/2c7c5734ea68e931d90d9bcc5daf0f2f5ee447db" alt=""
(2)创建目录
授权
bash
[root@localhost ~]# mkdir /opt/grafana-storage
[root@localhost ~]# chmod 777 -R /opt/grafana-storage
data:image/s3,"s3://crabby-images/59b83/59b83c3003266992edcf2f4f6c29ce87e8c7e0d2" alt=""
(3)创建Grafana容器
bash
[root@localhost ~]# docker run -d --name grafana --restart=always -p 3000:3000 --name=grafana -v /opt/grafana-storage:/var/lib/grafana grafana/grafana
(4)监听端口
bash
[root@localhost ~]# netstat -antlp | grep 3000
data:image/s3,"s3://crabby-images/acc5f/acc5fb4537050e2793d78b0af4b4c99d0128fb1b" alt=""
(5)访问
bash
http://192.168.204.141:3000
data:image/s3,"s3://crabby-images/74f66/74f66b45a51238ef9ae956a9d2bcfdb7d8fa8e36" alt=""
(6)登录
默认的用户名和密码都是admin
data:image/s3,"s3://crabby-images/af1af/af1afeea2000b4df717b41d4322ca1cb385372c2" alt=""
设置新密码
data:image/s3,"s3://crabby-images/aa3da/aa3da962e2bafe7fffb890724f43c348d1430e94" alt=""
跳转首页
data:image/s3,"s3://crabby-images/066fc/066fc18a41675d3e5be5f9ef98bc51e29bdae5c3" alt=""
(7)添加数据源
data:image/s3,"s3://crabby-images/b3bc3/b3bc399c338ada34344598a320fc5ff9b2c3a227" alt=""
弹出页面
选择Prometheus
输入URL
data:image/s3,"s3://crabby-images/61616/61616b4f67586e0767827f2e8ded747f3e32027d" alt=""
保存并测试
data:image/s3,"s3://crabby-images/73a2d/73a2d6007f5189a061ca58ee7603b2b4cb6556e5" alt=""
data:image/s3,"s3://crabby-images/45e87/45e87c2f491c059ddcb9b685bec0bfb6681ec7a1" alt=""
(8)查看Grafana监控模板的官网
bash
https://grafana.com/grafana/dashboards/
(9)导入Grafana监控模板(主机)
选择
data:image/s3,"s3://crabby-images/55292/552929f8bbb4113fd54ee6720484892ccf7cfc59" alt=""
弹出页面
data:image/s3,"s3://crabby-images/b0a72/b0a7211363c2eaf410a7a01a8279d743a33e6086" alt=""
导入
data:image/s3,"s3://crabby-images/bedde/bedde34f893e637957eb54f42a83dc5c3f6f0250" alt=""
导入主机的监控模板,模板id为8919
data:image/s3,"s3://crabby-images/d29f7/d29f7207e5707c533eb103acc540a9c5ecc6cf89" alt=""
修改
data:image/s3,"s3://crabby-images/90fd5/90fd505fecc54907bf649270aedb0938fec6b1cd" alt=""
完成
data:image/s3,"s3://crabby-images/f7820/f7820eecfa09d25234152ae6a323bb3a3abfd873" alt=""
4.使用cpolar内网穿透
(1)固定二级子域名地址
登录cpolar官网,点击左侧的预留,找到保留二级子域名,为远程服务器连接保留一个固定二级子域名地址
bash
https://dashboard.cpolar.com/get-started
data:image/s3,"s3://crabby-images/7a3a2/7a3a217952ec66d20fe617466ec5f553ce6e02bd" alt=""
(2)创建隧道
bash
域名类型:选择二级子域名
预留的http地址:复制粘贴官网保留成功的地址,Prometheus
地区选择:China VIP
data:image/s3,"s3://crabby-images/9e2a0/9e2a080cfbafd37d5b0a9f19cd542ed96fd3b95d" alt=""
(3) 查看隧道列表
data:image/s3,"s3://crabby-images/95458/954583f69dcdff4bf4873a0f6eef45b7a413ab2e" alt=""
(4)查看在线隧道列表
data:image/s3,"s3://crabby-images/f1ded/f1ded480d0b89787eb45872527cea383da499ce3" alt=""
(5)二级子域名地址访问
bash
http://prometheus.vip.cpolar.cn/graph
data:image/s3,"s3://crabby-images/9f8c9/9f8c9524966300a6f73cf4f5166f716e5bdfc69f" alt=""
bash
http://prometheus.vip.cpolar.cn/targets
data:image/s3,"s3://crabby-images/ab687/ab68772efa9a7bb99b0d2f4f197003945f7827dd" alt=""
(6) Grafana添加数据源
bash
http://prometheus.vip.cpolar.cn
data:image/s3,"s3://crabby-images/85ccd/85ccd6937158532ea04f29b19c8bde245e80c6fc" alt=""
保存并测试
data:image/s3,"s3://crabby-images/ec514/ec514d049fc5d67361b88d30630a2f3804805c95" alt=""
data:image/s3,"s3://crabby-images/83f8a/83f8a87ec76202f1a55777280fe3c27f179d0860" alt=""
导入
data:image/s3,"s3://crabby-images/7fe58/7fe5890c18fe263f1b704f36ab55aa3d514e132e" alt=""
(7)导入主机的监控模板
模板id为8919
data:image/s3,"s3://crabby-images/c9061/c906165965c2ce02ffcbf2670796f3becde42cb2" alt=""
完成
data:image/s3,"s3://crabby-images/a2934/a293422205f8c4b0cd2e62988061aaa24e072a53" alt=""
二、问题
1.拉取镜像失败
(1)报错
bash
Get "https://registry-1.docker.io/v2/": tls: failed to verify certificate: x509: certificate has expired or is not yet valid: current time 2024-04-01T14:17:15+08:00 is before 2024-04-04T00:00:00Z
data:image/s3,"s3://crabby-images/e767c/e767cb1d6c9c53b1193f16f3514213178025f4bb" alt=""
(2)原因分析
时间未同步。
(3)解决方法
同步时间:
bash
[root@localhost ~]# ntpdate cn.pool.ntp.org
data:image/s3,"s3://crabby-images/3e6fd/3e6fde00f63cd1b9341e02782dd905c743223cff" alt=""
成功:
data:image/s3,"s3://crabby-images/a4664/a4664555d06165d32bc2f60d267c60c808afcf4c" alt=""
2.如何导入Grafana监控模板(ES)
添加数据源
data:image/s3,"s3://crabby-images/2a9c6/2a9c64939391568fb3f3e75c2496c57ad60fed7a" alt=""
data:image/s3,"s3://crabby-images/7501e/7501e3799e84ed7fa20d6c72d2fbdb99f24cf8e5" alt=""
保存并测试
data:image/s3,"s3://crabby-images/1fba2/1fba25f28134eff86d9a826dbc86459f8829592f" alt=""
data:image/s3,"s3://crabby-images/a2a4f/a2a4f4aee89d09e9b9e4147c24fd9233fad5aa12" alt=""
导入
data:image/s3,"s3://crabby-images/a166e/a166e9da8c7224f9bced3c3bceacf859b4409d88" alt=""
导入ES的监控模板,模板id为878
data:image/s3,"s3://crabby-images/4c407/4c40731366b8dc4d1db46b6d00cb1eabfbd905fc" alt=""
修改
data:image/s3,"s3://crabby-images/5ecc4/5ecc42075e996b470649b254e2441829316d703e" alt=""