scaoping 发表于 2019-1-25 13:06:33

zabbix 之 mysql优化

  zabbix运行的性能怎么样,有很大一部分是由mysql数据库的性能决定的。因为zabbix实时收集监控数据,数据库一直在增长,因此,监控系统上线一段时间后,就会发现各类问题都与mysql数据库有关。
  在这里我记录了zabbix监控系统上线后对mysql数据库所做的一些操作,有些内容不是提高mysql运行性能,也就不讲究是否切题了,只是觉得经常用到,也就如实记录下来,后面碰到类似操作也好查阅和参考。

  

  

  1、修改mysql的root账号的密码(在忘记密码或者不知道密码的时候有用):
  先停止mysql服务:
    service mysqld stop  使用--skip-grant-tables忽略密码启动:
    mysqld_safe --skip-grant-tables &  进入mysql修改密码:
    use mysql
    update user set password=password('mysql') where user='root';
    flush privileges;  

  

  2、清理大表数据。
  1)查看表占用空间情况:
         select table_name, (data_length+index_length)/1024/1024 as total_mb, table_rows from information_schema.tables where table_schema='zabbix';  

  2)备份表trends_uint、history_uint、history。我在实际生产环境中,只保留上次的备份,没有留存更早的备份,因为更早以前的数据,没有留存的价值。
      mysqldump -uroot -p zabbix history> history.sql
      mysqldump -uroot -p zabbix trends_uint> trends_uint.sql
      mysqldump -uroot -p zabbix history_uint> history_uint.sql  

  3)清空表trends_uint、history_uint、history中的数据:
      truncate table trends_uint;
      truncate table history;
      truncate table history_uint;  

  3、修改单独表空间:
  1)备份数据
    mysqldump -uroot -p zabbix > zabbix.sql  2)删除数据库:
    drop database zabbix;  3)停止数据库:
    service mysqld stop  4)删除共享表空间数据文件
    $ cd /var/lib/mysql
    $ rm ib*  5)增加innodb_file_per_table参数
    vi /etc/my.cnf  6)在下设置
  innodb_file_per_table=1
  7)重启数据库:
    service mysqld start  8)重新创建数据库:
    mysql -uroot -p    create database zabbix character set utf8;
    grant all privileges on zabbix.* to zabbix@localhost identified by 'zabbix';
    flush privileges;  

  9)导入zabbix数据库:
    mysql -uzabbix -pzabbix zabbix/dev/null  

  下面是mysql_trunc_mysql.sh文件内容:
    vim /backup/mysql_trunc_zabbix.sh #!/bin/bash
    #truncate 3 big tables :trends_uint,history,history_unit .
    #Every month's 1th 3:00 excute this script
    #Writen by yuweibing ,phonenumber:18080116652
    service zabbix_server stop
    echo "truncate table trends_uint;"   |mysql -uzabbix -pzabbix zabbix
    echo "truncate table history;"       |mysql -uzabbix -pzabbix zabbix
    echo "truncate table history_uint;"|mysql -uzabbix -pzabbix zabbix
    sleep 1
    mysqldump -uroot -pmysql zabbix > /backup/zabbix.sql
    if [ $? -eq 0 ]
    then
    echo "drop database zabbix;"|mysql-uroot -pmysql
    else
    exit 1
    fi
    echo "create database zabbix character set utf8;"|mysql-uroot -pmysql
    echo "grant all privileges on zabbix.* to zabbix@localhost identified by 'zabbix';"|mysql-uroot -pmysql
    echo "flush privileges;"|mysql-uroot -pmysql
    mysql -uzabbix -pzabbix zabbix
页: [1]
查看完整版本: zabbix 之 mysql优化