zabbix监控实践解析(历史记录附近乱码、图表显示乱码)

本文涉及的产品
RDS MySQL Serverless 基础系列,0.5-2RCU 50GB
云数据库 RDS MySQL,集群系列 2核4GB
推荐场景:
搭建个人博客
云数据库 RDS PostgreSQL,集群系列 2核4GB
简介:

   在很早以前就了解过一些开源的监控工具,例如nagios、ganglia、cacti、zabbix,目前zabbix好像更受欢迎一点,我们所有的业务主要在阿里云上,平时主要用的阿里云的一些监控,随着业务的发展,想着将监控这一部分具体完善一下,所以就选择了zabbix,在使用的过程中也遇到了一些问题,在此记录,供以后参考。

环境:lamp (centos 6.5 + apache2+mysql5.1+php)

zabbix版本:2.4.8

问题一、语言设置中文后乱码

wKiom1kDDM-ScXn2AAE3NjleV6o412.png-wh_50

 如图上面的历史记录部分是乱码的,这个主要是我们创建数据库以及初始化时,选择的字符集不合适,这里需要注意是当我们初次安装的时候,创建数据库字符集一定要选择为UTF8,这样整体后期就不会出现乱码。

检查数据库字符集

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
1.查看当前的默认字符集
mysql> show  create  database  zabbix;
+ ----------+-------------------------------------------------------------------+
Database  Create  Database                                                    |
+ ----------+-------------------------------------------------------------------+
| zabbix   |  CREATE  DATABASE  `zabbix` /*!40100  DEFAULT  CHARACTER  SET  latin1 */ |
+ ----------+-------------------------------------------------------------------+
1 row  in  set  (0.00 sec)
#安装时在导入三个sql文件时,zabbix数据库中创建的表的字符集也是latin1
mysql> show variables  like  'character%' ;
+ --------------------------+----------------------------+
| Variable_name            | Value                      |
+ --------------------------+----------------------------+
| character_set_client     | latin1                     |
| character_set_connection | latin1                     |
| character_set_database   | latin1                     |
| character_set_filesystem |  binary                      |
| character_set_results    | latin1                     |
| character_set_server     | latin1                     |
| character_set_system     | utf8                       |
| character_sets_dir       | /usr/share/mysql/charsets/ |
+ --------------------------+----------------------------+

这一块就是由于数据库字符集的原因导致的,因为只一块主要是历史记录,所以我们现在可以直接更改,更改方法如下:

1、将zabbix数据库使用mysqldump逻辑备份,然后将文件里的字符集latin1更改为utf8。

2、更改数据库的默认字符集并重启数据库

3、删除之前的数据库,并创建新的zabbix库(默认字符集utf8)恢复数据。

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
  mysqldump  -u  root    zabbix>/tmp/zabbix20170428.sql #备份数据
  
  root@localhost alertscripts]# grep   "latin1"  /tmp/zabbix20170428.sql  #检查哪些表字符集为latin1
) ENGINE=InnoDB  DEFAULT  CHARSET=latin1;
) ENGINE=InnoDB  DEFAULT  CHARSET=latin1;
) ENGINE=InnoDB  DEFAULT  CHARSET=latin1;
) ENGINE=InnoDB  DEFAULT  CHARSET=latin1;
) ENGINE=InnoDB  DEFAULT  CHARSET=latin1;
) ENGINE=InnoDB  DEFAULT  CHARSET=latin1;
) ENGINE=InnoDB  DEFAULT  CHARSET=latin1;
) ENGINE=InnoDB  DEFAULT  CHARSET=latin1;
) ENGINE=InnoDB  DEFAULT  CHARSET=latin1;
) ENGINE=InnoDB  DEFAULT  CHARSET=latin1;
) ENGINE=InnoDB  DEFAULT  CHARSET=latin1;
) ENGINE=InnoDB  DEFAULT  CHARSET=latin1;
) ENGINE=InnoDB  DEFAULT  CHARSET=latin1;
替换字符集
sed -i  's/latin1/utf8/g'    /tmp/zabbix20170428.sql 
替换完再检查
grep   "latin1"  /tmp/zabbix20170428.sql 
结果为空
 
更改数据库默认字符集,并重启数据库
[mysqld]
datadir=/var/lib/mysql
socket=/var/lib/mysql/mysql.sock
user =mysql
log-bin=/var/lib/mysql/log_bin
default - character - set  = utf8
 
 
删除原先的数据库,并重新创建数据库
mysql>  drop   database   zabbix
     -> ;
Query OK, 104  rows  affected (5.14 sec)
 
create   database   zabbix   default   character  set   utf8;#创建zabbix数据库
 
mysql  -u  root zabbix < /tmp/zabbix20170428.sql #恢复数据
登录检查

wKiom1kDEiLQGLNsAAHUVj4hALw424.png-wh_50

经过检查已经解决了乱码的问题,虽然这里的乱码不会影响我们功能的使用,但是看着很难受,所以痛下杀手,直接将它给更改过来了。

问题二、图标显示很多小方块

wKiom1kDE2qBs_80AADCtJKjNqA376.png-wh_50

                                         显示方块

其实这里是有汉字的,当我们将其语言格式调整为英文的时候显示就会正常,这里我们就需要考虑更改字体。

wKioL1kDFAyAVBEmAACnuOyVjSs323.png-wh_50

                                        显示正常

解决方法:

将windows(C:\Windows\Fonts)微软雅黑或者楷体这类字体替换,替换zabbix的web界面的font里面的字体,为了简单我们可以直接将原先字体文件名替换。

wKiom1kDFNPhoLQUAACYfqnEKV4529.png-wh_50

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
[root@localhost fonts] # ll
total  11512
lrwxrwxrwx  1  root root        33  Apr  26  11 : 12  graphfont.ttf  - / etc / alternatives / zabbix - web - font  #默认
- rw - r - - r - -  1   777  root  11785184  Jun  11   2009  msyh.tt   #刚上传的微软雅黑
更改文件名:
[root@localhost fonts] # cp  graphfont.ttf  graphfont20170428.ttf  #备份数据
[root@localhost fonts] # ls 
graphfont20170428.ttf  graphfont.ttf  msyh.ttf 
[root@localhost fonts] # mv  msyh.ttf   graphfont.ttf   #覆盖文件
mv: overwrite `graphfont.ttf'? y
[root@localhost fonts] # ll
total  12216
- rw - r - - r - -  1  root root    720012  Apr  28  18 : 13  graphfont20170428.ttf
- rw - r - - r - -  1   777  root  11785184  Jun  11   2009  graphfont.ttf
[root@localhost fonts]
界面检查

wKioL1kDFpDAZnA1AACb8vdSic0804.png-wh_50

接触了一下发现zabbix其实还是比较简单的,接下来就需要攻克监控数据库以及tomcat和redis等应用程序,任重而道远,加油!



本文转自 tianya1993 51CTO博客,原文链接:http://blog.51cto.com/dreamlinux/1920598,如需转载请自行联系原作者

相关文章
|
6天前
|
存储 JSON API
深入解析RESTful API设计原则与实践
【9月更文挑战第21天】在数字化时代,后端开发不仅仅是编写代码那么简单。它关乎于如何高效地连接不同的系统和服务。RESTful API作为一套广泛采用的设计准则,提供了一种优雅的解决方案来简化网络服务的开发。本文将带你深入了解RESTful API的核心设计原则,并通过实际代码示例展示如何将这些原则应用于日常的后端开发工作中。
|
10天前
|
PHP 开发者
PHP 7新特性深度解析与实践应用
【9月更文挑战第17天】本文将深入探讨PHP 7的新特性及其对开发者的实际影响,同时通过实例演示如何有效利用这些特性优化代码和提高性能。我们将从类型声明的增强开始,逐步深入到其他关键改进点,最后通过一个综合案例展示如何将这些新特性应用于日常开发中。
|
10天前
|
消息中间件 Java Apache
RocketMQ消息回溯实践与解析
在分布式系统和高并发应用的开发中,消息队列扮演着至关重要的角色,而RocketMQ作为阿里巴巴开源的一款高性能消息中间件,以其高吞吐量、高可用性和灵活的配置能力,在业界得到了广泛应用。本文将围绕RocketMQ的消息回溯功能进行实践与解析,分享工作学习中的技术干货。
42 3
|
7天前
|
Linux iOS开发 Docker
Docker:容器化技术的领航者 —— 从基础到实践的全面解析
在云计算与微服务架构日益盛行的今天,Docker作为容器化技术的佼佼者,正引领着一场软件开发与部署的革命。它不仅极大地提升了应用部署的灵活性与效率,还为持续集成/持续部署(CI/CD)提供了强有力的支撑。
176 69
|
7天前
|
传感器 C# Android开发
深度解析Uno Platform中的事件处理机制与交互设计艺术:从理论到实践的全方位指南,助您构建响应迅速、交互流畅的跨平台应用
Uno Platform 是一款开源框架,支持使用 C# 和 XAML 开发跨平台原生 UI 应用,兼容 Windows、iOS、Android 及 WebAssembly。本文将介绍 Uno Platform 中高效的事件处理方法,并通过示例代码展示交互设计的核心原则与实践技巧,帮助提升应用的用户体验。事件处理让应用能响应用户输入,如点击、触摸及传感器数据变化。通过 XAML 或 C# 添加事件处理器,可确保及时反馈用户操作。示例代码展示了一个按钮点击事件处理过程。此外,还可运用动画和过渡效果进一步增强应用交互性。
110 57
|
6天前
|
编解码 开发工具 UED
QT Widgets模块源码解析与实践
【9月更文挑战第20天】Qt Widgets 模块是 Qt 开发中至关重要的部分,提供了丰富的 GUI 组件,如按钮、文本框等,并支持布局管理、事件处理和窗口管理。这些组件基于信号与槽机制,实现灵活交互。通过对源码的解析及实践应用,可深入了解其类结构、布局管理和事件处理机制,掌握创建复杂 UI 界面的方法,提升开发效率和用户体验。
48 12
|
25天前
|
监控 关系型数据库 MySQL
zabbix agent集成percona监控MySQL的插件实战案例
这篇文章是关于如何使用Percona监控插件集成Zabbix agent来监控MySQL的实战案例。
29 2
zabbix agent集成percona监控MySQL的插件实战案例
|
5天前
|
设计模式 数据库连接 PHP
PHP中的设计模式:单例模式的深入解析与实践
在PHP开发中,设计模式是提高代码可维护性、扩展性和复用性的关键技术之一。本文将深入探讨单例模式——一种确保类只有一个实例,并提供该实例的全局访问点的设计模式。我们将从单例模式的基本概念入手,剖析其在PHP中的应用方式,并通过实际案例展示如何在不同场景下有效利用单例模式来优化应用架构。
|
8天前
|
PHP
PHP 7新特性解析与实践
【9月更文挑战第19天】在这篇文章中,我们将深入探讨PHP 7的新特性,以及如何在实际开发中应用这些新特性。我们将通过代码示例,详细解析PHP 7的性能提升,新的操作符,空合并操作符,标量类型声明等新特性,并分享一些实践经验和技巧。无论你是PHP新手还是老手,这篇文章都将帮助你更好地理解和掌握PHP 7的新特性。
|
10天前
|
设计模式 人工智能 算法
PHP中的设计模式:策略模式的深入解析与实践软件测试中的人工智能革命:提升效率与准确性的新篇章
在PHP开发中,理解并运用设计模式是提升代码质量和可维护性的重要途径。本文聚焦于策略模式(Strategy Pattern),一种行为型设计模式,它允许在运行时选择算法或业务规则。通过本文,我们将深入探讨策略模式的定义、结构、使用场景以及如何在PHP项目中有效地实现和利用策略模式。不同于性能优化等技术性摘要,本文着重于提供对策略模式全面而实用的理解,助力开发者编写出更加灵活和可扩展的应用程序。 本文深入探讨了人工智能在软件测试领域的应用,揭示了其如何显著提高测试过程的效率和准确性。通过实际案例分析,展示了AI技术在自动化测试、缺陷检测及结果分析中的关键作用,并讨论了实施AI测试策略时面临的挑
16 3