部署前提:我们已经在一台能联网的机器上将PMM-Server的镜像已经拉取到本地了,然后从拉取成功的机器上打包镜像,这样在不能联网的服务器中的docker中创建容器时就不需要远程拉取从而实现断网安装,如果机器能联网就就直接安装就行,省去打包步骤。 1.下载最新docker rpm包 rpm包 docker 官网教程 官网教程 导入导出镜像文件 导出教程 部署docke创建容器以及运行PMM-server 部署安装

2.复制到虚拟机安装、

[root@localhost docker]#
 rpm -ivh docker-1.12.6-32.git88a4867.el7.centos.x86_64.rpm

3.启动docker

service docker start

设置开机启动:

chkconfig docker on

查看 MySQL 服务是否开机启动

[root@localhost ~]# systemctl is-enabled mysql.service;echo $?
enabled
0

如果是 enabled 则说明是开机自动,如果不是,执行

chkconfig --levels 235 docker  on

4,记载PMM镜像文件(从其他机器打包或者从官网下载)

[root@localhost docker]# docker load -i 1.tar

Docker目录下的1.tar是从其他机器打包出来的PMM镜像文件

查看安装的版本: docker version

查看镜像id

sudo docker images

mysql 监控里面command 是Sleep什么意思_mysql

2. 选择要打包的镜像,执行打包命令

[root@localhost ~]# docker save -o /home/1.tar docker.io/percona/pmm-server

会在/home/目录下生成导出文件1.tar,然后将此文件下载到本地

  1. 在开发环境导入上述打包的镜像
[root@localhost docker]# docker load -i 1.tar

至此,可以使用本地镜像了!

5,查看已有镜像:

mysql 监控里面command 是Sleep什么意思_监控工具_02

docker ps

6,创建数据容器

docker create \
   -v /opt/prometheus/data \
   -v /opt/consul-data \
   -v /var/lib/mysql \
   -v /var/lib/grafana \
   --name pmm-data \
   percona/pmm-server:latest /bin/true

7.创建PMMserver容器

docker run -d \
   -p 80:80 \
   --volumes-from pmm-data \
   --name pmm-server \
   --restart always \
   percona/pmm-server:latest

这里如果90端口被占用就换其他的端口

docker run -d \
   -p 8090:80 \
   --volumes-from pmm-data \
   --name pmm-server \
   --restart always \
   --e METRICS_MEMORY=4194304\   4G  实际使用会在6G
   --e METRICS_RETENTION=192h  \   数据保存时间8天
   percona/pmm-server:latest
说明:
    控制PMM的内存消耗: --e METRICS_MEMORY=4194304
    默认情况下,PMM Server中的 Prometheus 最多可以使用256 MB的内存来存储最近使用的数据块。根据进入普罗米修斯的数据量,您可能需要更高的限制才能避免限制数据吞吐,或者如果其他进程需要更少的内存消耗。
您可以通过METRICS_MEMORY在创建和运行PMM Server容器时传递环境变量来控制Prometheus允许的内存消耗。要设置环境变量,请使用该-e选项。该值必须以千字节为单位传递。例如,将限制设置为4 GB内存:
    - e  METRICS_MEMORY = 4194304
    注意:
    限制仅影响为数据块保留的内存。普罗米修斯的实际RAM使用率更高。建议将此限制设置为您计划允许使用普罗米修斯的总内存的大约2/3。所以在前面的例子中,如果将限制设置为4 GB,那么普罗米修斯将使用最多6 GB的内存。

官网说明

8.访问127.0.0.1看是否能进入

mysql 监控里面command 是Sleep什么意思_断网_03

PMM-Client安装与PMM-Server数据互通

1、安装pmm-client rpm 官网找与PMM-Server对应的版本下载

2、安装客户端[root@localhost PMM-Client]#

rpm -ivh  pmm-client-1.2.0-1.x86_64.rpm

3、连接服务器

[root@localhost PMM-Client]#
 pmm-admin config --server 192.168.174.129(PMMserver的ip)

mysql 监控里面command 是Sleep什么意思_断网_04

问题:无法连接PMMserver,提示信息还是非常清晰的,可以访问提供的url查看或者按照提示检查,服务是否启动,是否启用ssl,是否开启防火墙等等,通常就是没启动服务或者防火墙开启。

连接成功:

mysql 监控里面command 是Sleep什么意思_监控工具_05

4,查看已有list

pmm-admin list

mysql 监控里面command 是Sleep什么意思_mysql_06

5,增加MySQL监控服务

[root@localhost PMM-Client]# 
pmm-admin add mysql --user root --password 123456 --host  192.168.174.128 --create-user(数据库所在的ip)
--create-user 创建一个仅具有收集数据所需权限的用户

mysql 监控里面command 是Sleep什么意思_mysql_07

添加成功,这里pmm-admin add mysql –help(

https://www.percona.com/doc/percona-monitoring-and-management/pmm-admin.html#pmm-admin-options

)这个是pmm-admin add的help不懂得可以参考

mysql 监控里面command 是Sleep什么意思_percona_08

这里要说明下:就是我们使用help命令查看全局配置文件默认在 “/usr/local/percona/pmm-client/pmm.yml”下,我们打开这个文件,发现里边的信息就是我们注册的服务器和客户端信息,还有client_name: test-1,这里就是显示在监控界面的mysql的名字,如果有需要就修改我的默认是localhost.localdomain 再次使用pmm-admin list查看:

mysql 监控里面command 是Sleep什么意思_mysql_09

说明已经添加成功系统和mysql的监控

6,服务端刷新页面发现没有添加的客户端信息,可能添加报错,官方很周到提供了连接check命令

[localhost PMM-Client]# pmm-admin check-network

mysql 监控里面command 是Sleep什么意思_percona_10

我们发现server到client的down了,可以访问提供的url或者可以看里边的信息,明显使用42000和42002端口,但是我们并没有开放,所以不能连接。

开放端口

firewall-cmd --permanent --zone=public --add-port=42000/tcp
 firewall-cmd --permanent --zone=public --add-port=42000/udp
And:
 firewall-cmd --permanent --zone=public --add-port=42002/tcp
 firewall-cmd --permanent --zone=public --add-port=42002/udp

firewall-cmd --reload

再次刷新服务端发现已经出现了并且数据监控也有数据了

常见错误

打开 PMM Query Analytics报 “QAN API error: “qh.Profile: No query classes for selected instance and time range.错误。 完整报错信息如下:

There is no data for the selected MySQL instance, time range or search query.

QAN API error: “qh.Profile: No query classes for selected instance and time range. Please check whether your MySQL settings match the recommended.”.

Check the /var/log/qan-api.log file in docker container for more information.

解决方法:PMM使用slow log作为查询源,需要开启慢日志。

vim /etc/my.cnf
slow_query_log=1  #开启慢查询日志
long_query_time=2  #超过多少秒的查询就写入日志

打开Query Analytics翻看的时候我遇到了一个类似46191-error-agent-executable-file-not-found-in-path的错误。 解决方法:需要安装percona-toolkit包。

$ apt-get install percona-toolkit

问题:已经配置过与一个server连接后,要修改与另一个服务连接报错不能连接 提示信息中有提示这个命令 执行下就行了:

pmm-admin repair