监控

监控就是实时的帮助我们来监控或者探测我们部署的服务是否正常运行

常用的监控

  • zabbix(基于数据库的)
  • 组件比较全,缺点性能不高
  • 当数据库中的一个表的数据超过2000W时,数据库性能急剧下降
  • 阿里云云监控
  • 腾讯云蓝鲸监控
  • 普罗米修斯(prometeus)
  • 性能比较高,底层使用时序数据库
  • 原生支持监控容器

 

普罗米修斯监控流程

普罗米修斯监控分为两种情况:
1、携带metrics接口的服务 (kubernetes、ETCD、docker)
2、不携带mertrics接口的服务(nginx、mysql、linux主机)针对于不携带mertrics接口的服务,我们需要安装一个exporter插件。

# 下载
[root@prometheus opt]# wget https://github.com/prometheus/prometheus/releases/download/v2.27.1/prometheus-2.27.1.linux-amd64.tar.gz

# 解压
[root@prometheus opt]# tar -xf prometheus-2.25.0.linux-amd64.tar.gz -C /usr/local/

# 建立超链接
[root@prometheus local]# ln -s /usr/local/prometheus-2.25.0.linux-amd64 /usr/local/prometheus

# 创建环境变量
[root@prometheus local]# cat >> /etc/profile <<EOF
export PROMETHEUS_HOME=/usr/local/prometheus
PATH=$PATH:$PROMETHEUS_HOME
export PATH
EOF
[root@prometheus ~]# source /etc/profile

# 测试
[root@prometheus ~]# prometheus --version
prometheus, version 2.25.0 (branch: HEAD, revision: a6be548dbc17780d562a39c0e4bd0bd4c00ad6e2)
  build user:       root@615f028225c9
  build date:       20210217-14:17:24
  go version:       go1.15.8
  platform:         linux/amd64

使用普罗米修斯监控一台Linux主机

web服务器

# 下载
[root@web01 opt]# wget https://github.com/prometheus/node_exporter/releases/download/v1.1.2/node_exporter-1.1.2.linux-amd64.tar.gz

[root@web01 opt]# tar -xf node_exporter-1.1.2.linux-amd64.tar.gz -C /usr/local/

[root@web01 local]# ln -s /usr/local/node_exporter-1.1.2.linux-amd64/ /usr/local/node_exporter

export NODE_EXPORTER=/usr/local/node_exporter
export PATH=$PATH:$NODE_EXPORTER

[root@web01 ~]# source /etc/profile
[root@web01 ~]# node_exporter

prometheus主机
[root@prometheus prometheus]# vim /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: 'web01'
    static_configs:
      - targets: ['192.168.1.7:9100'] 
     
[root@prometheus prometheus]# prometheus --config.file=/usr/local/prometheus/prometheus.yml
最后一段出现以下内容即为正确   level=info ts=2021-06-02T02:49:57.047Z caller=main.go:959 msg="Completed loading of configuration file" filename=/usr/local/prometheus/prometheus.yml totalDuration=2.682531ms remote_storage=25.802µs web_handler=457ns query_engine=17.121µs scrape=1.593395ms scrape_sd=99.713µs notify=77.917µs notify_sd=11.912µs rules=18.563µs
level=info ts=2021-06-02T02:49:57.047Z caller=main.go:751 msg="Server is ready to receive web requests."

最后在浏览器输入prometheus主机的ip+端口号即可:http://192.168.1.71:9090/出现以下界面即为成功

prometheus监控mysql数据库 prometheus监控进程_linux


点击status—>targets会出现以下界面

prometheus监控mysql数据库 prometheus监控进程_linux_02

为监控添加更加直观且美观的画面(grafana)

1、将grafanna下载到prometheus主机上(此处我是从桌面上传到prometheus主机上的)
[root@prometheus opt]# ls
grafana-7.3.6-1.x86_64.rpm

2、安装grafana
[root@prometheus opt]# yum install -y grafana-7.3.6-1.x86_64.rpm

3、启动grafana
[root@prometheus ~]# systemctl start grafana-server.service

4、查看端口是否开启
[root@prometheus ~]# netstat -ntlp
tcp6 0 0 :::3000 ::😗 LISTEN 7503/grafana-server

5、浏览器访问

http://192.168.1.71:3000/ 出现以下界面即为成功,输入账户admin,密码admin即可登录

prometheus监控mysql数据库 prometheus监控进程_linux_03


改密后登录

prometheus监控mysql数据库 prometheus监控进程_linux_04


点击左边设置按钮-------》点击datasources-------->点击add datasource---------->点击prometheus

prometheus监控mysql数据库 prometheus监控进程_github_05


点击保存后,浏览器访问grafana官网:https://grafana.com/grafana/

prometheus监控mysql数据库 prometheus监控进程_数据库_06


点击dashboard,如图所示,选择自己喜欢的模板

prometheus监控mysql数据库 prometheus监控进程_数据库_07


prometheus监控mysql数据库 prometheus监控进程_数据库_08


点击箭头处,然后点击import

prometheus监控mysql数据库 prometheus监控进程_数据库_09


点击load------>点击import

prometheus监控mysql数据库 prometheus监控进程_github_10


prometheus监控mysql数据库 prometheus监控进程_github_11