Prometheus简介:
略
部署Prometheus Server:
1.下载Prometheus: root@dokcer:~# wget https://github.com/prometheus/prometheus/releases/download/v2.37.0/prometheus-2.37.0.linux-amd64.tar.gz 2.解压Prometheus: root@dokcer:~# tar -xzvf prometheus-2.37.0.linux-amd64.tar.gz -C /usr/local/ 3.建立软连接: root@dokcer:~# ln -sv /usr/local/prometheus-2.37.0.linux-amd64/ /usr/local/prometheus 4.启动Prometheus,启用默认配置文件: root@dokcer:~# /usr/local/prometheus/prometheus --config.file=/usr/local/prometheus/prometheus.yml & & 表示命令在后台运行 5.如果出现端口占用情况,先确认9090端口是否被占用: root@dokcer:~# netstat -tulp | grep 9090 #端口9090已经开启被prometheus占用 tcp6 0 0 [::]:9090 [::]:* LISTEN 27047/prometheus root@dokcer:~# lsof -i:9090 COMMAND PID USER FD TYPE DEVICE SIZE/OFF NODE NAME prometheu 27047 root 3u IPv6 58459 0t0 TCP dokcer:9090->192.168.0.5:60420 (ESTABLISHED) prometheu 27047 root 7u IPv6 58455 0t0 TCP *:9090 (LISTEN) root@dokcer:~# ss -natlp | grep 9090 LISTEN 0 128 *:9090 *:* users:(("prometheus",pid=27047,fd=7)) Prometheus作为一个时间序列数据库,收集的数据会以文件的形式存储在本地中,默认的存储路径为 ~/data 通过--storage.tsdb.path="path"修改数据文件地址
浏览器查看prometheus界面:
访问地址http://:IP:9090
data:image/s3,"s3://crabby-images/7a86c/7a86c8a4386d2261590d5336b7b58d13bbc7c975" alt="notion image"
data:image/s3,"s3://crabby-images/5903a/5903a4bc94d582dccd1126ee8dc712c9985d6001" alt="notion image"
查看监控的机器:
data:image/s3,"s3://crabby-images/ff5cc/ff5cccf3cbbe5dac8f6012e855cb30fa9031212d" alt="notion image"
目前只有本地的机器被监控,访问http://IP:9090/metrics,就可以看到被监控机器的各种数据
data:image/s3,"s3://crabby-images/56716/56716c27e36180eb8cb451da8969b2eebf7dc2eb" alt="notion image"
data:image/s3,"s3://crabby-images/31a11/31a1171256f24c8de7b1585e3efd1d7a01d6b72d" alt="notion image"
输入表达式进行数据的过滤,并可以选择使用图标的形式来查看数据
data:image/s3,"s3://crabby-images/de760/de7600f6899a9bfb950333683147a45255e140c9" alt="notion image"
部署被监控机器agent:
被监控的远程主机只需要安装node_exporter组件,就可以通过http://被监控机器IP:9100/metrics,查看到被监控机器的数据指标(cpu,内存,网络)。
1.下载node_exporter: root@dokcer:~# wget https://github.com/prometheus/node_exporter/releases/download/v1.3.1/node_exporter-1.3.1.linux-amd64.tar.gz 2.解压到/usr/local/ root@dokcer:~# tar -xzvf node_exporter-1.3.1.linux-amd64.tar.gz -C /usr/local/ 3.创建软连接: root@dokcer:~# ln -sv /usr/local/node_exporter-1.3.1.linux-amd64/node_exporter /usr/local/bin/node_exporter '/usr/local/bin/node_exporter' -> '/usr/local/node_exporter-1.3.1.linux-amd64/node_exporter' 4.运行node_exporter root@dokcer:~# nohup node_exporter & #用nohup后台运行node_exporter root@dokcer:~# nohup node_exporter & [1] 27954 root@dokcer:~# jobs -l #查看当前终端的nohup运行的命令,其他的supervisord,screen命令也可以 [1]+ 27954 Running nohup node_exporter & root@dokcer:~# nohup: ignoring input and appending output to 'nohup.out' #可以看到后台运行命令的输出信息 5.查看端口占用状态: root@dokcer:~# netstat -tulp | grep 9100 #服务开启成功 tcp6 0 0 [::]:9100 [::]:* LISTEN 27954/node_exporter root@dokcer:~# lsof -i:9100 COMMAND PID USER FD TYPE DEVICE SIZE/OFF NODE NAME node_expo 27954 root 3u IPv6 63234 0t0 TCP *:9100 (LISTEN) root@dokcer:~# ss -natlp | grep 9100 LISTEN 0 128 *:9100 *:* users:(("node_exporter",pid=27954,fd=3)) 6.prometheus server配置文件添加被控端: 编辑/usr/local/prometheus/prometheus.yml 文件添加内容: scrape_configs: # The job name is added as a label `job=<job_name>` to any timeseries scraped from this config. - job_name: "prometheus" # metrics_path defaults to '/metrics' # scheme defaults to 'http'. static_configs: - targets: ["localhost:9090"] - job_name: "agent" static_configs: - targets: ["192.168.0.50:9100"] ~ 7.重启prometheus server root@dokcer:~# pkill prometheus #关闭prometheus server / kill prometheus pid root@dokcer:~# lsof -i:9090 #查看端口状态 root@dokcer:~# /usr/local/prometheus/prometheus --config.file=/usr/local/prometheus/prometheus.yml &
打开http://IP:9090 → Status → Targets, 就可以看到被添加上的被监控的主机:
data:image/s3,"s3://crabby-images/e4c07/e4c0770f80247ff2538c14083f69ae95deba80cb" alt="notion image"
部署Prometheus图形显示界面Grafana
Grafana可以使用web界面直观显示出Prometheus所监控的机器的数据指标:
1.添加apt源: root@dokcer:~# wget -q -O - https://packages.grafana.com/gpg.key | sudo apt-key add - OK root@dokcer:~# echo "deb https://packages.grafana.com/enterprise/deb stable main" | sudo tee -a /etc/apt/sources.list.d/grafana.list root@dokcer:~# sudo apt-get update root@dokcer:~# sudo apt-get install grafana-enterprise root@dokcer:~# dpkg -l gra* #查看是否安装成功 Desired=Unknown/Install/Remove/Purge/Hold | Status=Not/Inst/Conf-files/Unpacked/halF-conf/Half-inst/trig-aWait/Trig-pend |/ Err?=(none)/Reinst-required (Status,Err: uppercase=bad) ||/ Name Version Architecture Description +++-==============================-====================-====================-================================================================= un grafana <none> <none> (no description available) ii grafana-enterprise 9.0.3 amd64 Grafana 2.启动grafana server root@dokcer:~# systemctl start grafana-server root@dokcer:~# lsof -i:3000 COMMAND PID USER FD TYPE DEVICE SIZE/OFF NODE NAME grafana-s 29257 grafana 8u IPv6 68427 0t0 TCP *:3000 (LISTEN) root@dokcer:~# sudo systemctl status grafana-server #查看grafana server是否已经启动 root@dokcer:~# systemctl enable grafana-server.service #设置开机自启 Synchronizing state of grafana-server.service with SysV service script with /lib/systemd/systemd-sysv-install. Executing: /lib/systemd/systemd-sysv-install enable grafana-server Created symlink /etc/systemd/system/multi-user.target.wants/grafana-server.service → /usr/lib/systemd/system/grafana-server.service. root@dokcer:~# systemctl is-enabled grafana-server #服务已经开机自启 enabled
浏览器访问http://IP:3000就可以看到grafana-server界面:
data:image/s3,"s3://crabby-images/35b2c/35b2c4711a7e04ea808c02bb90b6b3c14c8e21e7" alt="notion image"
data:image/s3,"s3://crabby-images/23733/2373330aa139f1c0ba34a35df242252033955acc" alt="notion image"
data:image/s3,"s3://crabby-images/f8237/f8237c307d2bbdf84a80dd20810fa7022d5a60c8" alt="notion image"
data:image/s3,"s3://crabby-images/2f0c2/2f0c21d9b8a7ae30227721116a15360994d4fbfb" alt="notion image"
data:image/s3,"s3://crabby-images/5e265/5e2653bc3403a20e09dd957da8640a1452959076" alt="notion image"
data:image/s3,"s3://crabby-images/841f7/841f7772b1677a873c99de140ceb4c9da77b5b38" alt="notion image"
data:image/s3,"s3://crabby-images/d1b9f/d1b9f08bcedfbf1d6d21fbf1ca86f16902799452" alt="notion image"
data:image/s3,"s3://crabby-images/fa8a1/fa8a1b477a56d468f0135a9ef291baded577ec33" alt="notion image"
data:image/s3,"s3://crabby-images/7d2f2/7d2f262f03cf8c23f8ef6ff4a01a8b1b7c1a9180" alt="notion image"
已经可以显示出采集到的数据了:
data:image/s3,"s3://crabby-images/54dcc/54dcc7800266d58bd36bb42e6ff4737d247b00ca" alt="notion image"
可以自定义查询和显示采集到的数据:
data:image/s3,"s3://crabby-images/fa8ee/fa8ee32750cb456a720bca52c990c19cbf21963e" alt="notion image"
带可以选择导入现成的模板文件导入,这样就不用自己定义视图了,方便快捷:
data:image/s3,"s3://crabby-images/f0a98/f0a98d9b56910fe1ca58be42814694c2b2a40592" alt="notion image"
上传模板json文件:
data:image/s3,"s3://crabby-images/d83d7/d83d7ecbdbe39afc7901dad197e6b03ccfecad11" alt="notion image"
显示效果:
data:image/s3,"s3://crabby-images/35daf/35daf951561114465a73d112341b7e21ed8ee0ef" alt="notion image"
可以Ctrl +/-调整浏览器缩放以达到设置显示面板大小的作用
参考资料:
Prometheus service文件制作:
编辑service文件: vim /usr/lib/systemd/system/prometheus.service 或者 /etc/systemd/system/prometheus.service [Unit] Description=prometheus.io [Service] Restart=on-failure ##ExecStart=/usr/local/mysql_exporter/mysqld_exporter --config.my-cnf=.my.cnf ExecStart=/usr/local/prometheus/prometheus --config.file=/usr/local/prometheus/prometheus.yml [Install] WantedBy=multi-user.target 启动prometheus.service systemctl start prometheus.service
Node_exporter service:
[Unit] Description=node_exporter [Service] Restart=on-failure ##ExecStart=/usr/local/mysql_exporter/mysqld_exporter --config.my-cnf=.my.cnf ExecStart=node_exporter [Install] WantedBy=multi-user.target
Prometheus监控内容:
监控级别 | 监控内容 | Exporter |
网络 | 网络协议:http、dns、tcp、icmp;网络硬件:路由器,交换机等 | BlackBox Exporter;SNMP Exporter |
主机 | 资源用量 | node exporter |
容器 | 资源用量 | cAdvisor |
应用(Library) | 延迟,错误,QPS,内部状态等 | 代码中集成Prmometheus Client |
中间件 | 资源用量,以及服务状态 | 代码中集成Prmometheus Client |
编排工具 | 集群资源用量,调度等 | Kubernetes Components |