• Zabbix的history相关数据表数据太大,执行表分区操作过程


    一、查询zabbix数据库大小

    复制代码
    mysql> select table_schema, concat(truncate(sum(data_length)/1024/1024,2),' mb') as data_size,concat(truncate(sum(index_length)/1024/1024,2),'mb') as index_size from information_schema.tables group by table_schema order by data_size desc;
    +--------------------+------------+------------+
    | table_schema       | data_size  | index_size |
    +--------------------+------------+------------+
    | zabbix             | 8326.06 mb | 3031.85mb  |
    | jumpserver         | 26.57 mb   | 8.21mb     |
    | mysql              | 2.49 mb    | 0.21mb     |
    | information_schema | 0.15 mb    | 0.00mb     |
    | sys                | 0.01 mb    | 0.00mb     |
    | performance_schema | 0.00 mb    | 0.00mb     |
    +--------------------+------------+------------+
    6 rows in set (0.40 sec)
    复制代码

    发现Zabbix数据占用了8G空间

    二、查询Zabbix数据库里所有表大小

    复制代码
    mysql> select table_name, (data_length+index_length)/1024/1024 as total_mb,table_rows from information_schema.tables where table_schema='zabbix' order by total_mb desc;
    +----------------------------+---------------+------------+
    | table_name                 | total_mb      | table_rows |
    +----------------------------+---------------+------------+
    | history_uint               | 5487.29687500 |   56075683 |
    | history                    | 4843.39062500 |   51787332 |
    | trends_uint                |  526.92187500 |    7440029 |
    | history_str                |  251.39062500 |    2393973 |
    | trends                     |  215.87500000 |    2978883 |
    | items                      |    6.21875000 |      10033 |
    | events                     |    4.93750000 |       7922 |
    | alerts                     |    4.67187500 |       5030 |
    | items_applications         |    2.35937500 |      11510 |
    | triggers                   |    1.89062500 |       4359 |
    | auditlog                   |    1.85937500 |       6803 |
    | images                     |    1.53125000 |        138 |
    | functions                  |    0.67187500 |       4746 |
    | item_discovery             |    0.57812500 |       3921 |
    | graphs_items               |    0.51562500 |       3773 |
    | graphs                     |    0.50000000 |       1561 |
    | auditlog_details           |    0.42187500 |       2620 |
    | event_recovery             |    0.32812500 |       2936 |
    | applications               |    0.29687500 |       2345 |
    | item_preproc               |    0.29687500 |       3668 |
    | application_template       |    0.28125000 |       1989 |
    | sessions                   |    0.23437500 |       1064 |
    | hosts                      |    0.17187500 |        167 |
    | profiles                   |    0.15625000 |        564 |
    | sysmaps_elements           |    0.15625000 |         95 |
    | mappings                   |    0.12500000 |        820 |
    | widget_field               |    0.10937500 |        170 |
    | graph_discovery            |    0.10937500 |        887 |
    | problem                    |    0.09375000 |        104 |
    | item_condition             |    0.07812500 |        446 |
    | sysmaps                    |    0.07812500 |         13 |
    | trigger_depends            |    0.07812500 |        401 |
    | httptest                   |    0.07812500 |         41 |
    | event_suppress             |    0.06250000 |          0 |
    | escalations                |    0.06250000 |          8 |
    | sysmaps_links              |    0.06250000 |          0 |
    | scripts                    |    0.06250000 |          3 |
    | trigger_discovery          |    0.06250000 |        648 |
    | hostmacro                  |    0.06250000 |        297 |
    | group_prototype            |    0.06250000 |          7 |
    | acknowledges               |    0.06250000 |        207 |
    | slides                     |    0.04687500 |          0 |
    | rights                     |    0.04687500 |          4 |
    | maintenances_groups        |    0.04687500 |          0 |
    | host_discovery             |    0.04687500 |          2 |
    | httpstepitem               |    0.04687500 |        123 |
    | item_application_prototype |    0.04687500 |         23 |
    | autoreg_host               |    0.04687500 |          0 |
    | task                       |    0.04687500 |          0 |
    | maintenances               |    0.04687500 |          0 |
    | dservices                  |    0.04687500 |         30 |
    | sysmap_element_trigger     |    0.04687500 |          0 |
    | tag_filter                 |    0.04687500 |          0 |
    | drules                     |    0.04687500 |          8 |
    | slideshows                 |    0.04687500 |          0 |
    | users_groups               |    0.04687500 |          5 |
    | services_links             |    0.04687500 |          0 |
    | opcommand_hst              |    0.04687500 |          0 |
    | optemplate                 |    0.04687500 |          0 |
    | interface                  |    0.04687500 |         82 |
    | slideshow_usrgrp           |    0.04687500 |          0 |
    | opcommand_grp              |    0.04687500 |          0 |
    | opmessage_usr              |    0.04687500 |         22 |
    | sysmaps_link_triggers      |    0.04687500 |          0 |
    | service_alarms             |    0.04687500 |          0 |
    | opmessage_grp              |    0.04687500 |          4 |
    | hosts_templates            |    0.04687500 |        263 |
    | icon_mapping               |    0.04687500 |          0 |
    | application_prototype      |    0.04687500 |         23 |
    | dashboard_usrgrp           |    0.04687500 |          0 |
    | media                      |    0.04687500 |          9 |
    | hosts_groups               |    0.04687500 |        211 |
    | icon_map                   |    0.04687500 |          0 |
    | application_discovery      |    0.04687500 |          8 |
    | sysmap_usrgrp              |    0.04687500 |          0 |
    | dashboard_user             |    0.04687500 |          0 |
    | opgroup                    |    0.04687500 |          0 |
    | httptestitem               |    0.04687500 |        123 |
    | sysmap_user                |    0.04687500 |          0 |
    | screens                    |    0.04687500 |         12 |
    | actions                    |    0.04687500 |         16 |
    | screen_usrgrp              |    0.04687500 |          0 |
    | maintenances_windows       |    0.04687500 |          0 |
    | correlation                |    0.04687500 |          0 |
    | slideshow_user             |    0.04687500 |          0 |
    | config                     |    0.04687500 |          0 |
    | screen_user                |    0.04687500 |          0 |
    | maintenances_hosts         |    0.04687500 |          0 |
    | group_discovery            |    0.03125000 |          0 |
    | conditions                 |    0.03125000 |         30 |
    | sysmap_element_url         |    0.03125000 |          0 |
    | problem_tag                |    0.03125000 |          0 |
    | regexps                    |    0.03125000 |          5 |
    | httpstep_field             |    0.03125000 |         26 |
    | interface_discovery        |    0.03125000 |          0 |
    | services_times             |    0.03125000 |          0 |
    | maintenance_tag            |    0.03125000 |          0 |
    | history_text               |    0.03125000 |         22 |
    | graph_theme                |    0.03125000 |          4 |
    | httpstep                   |    0.03125000 |         41 |
    | dhosts                     |    0.03125000 |         31 |
    | widget                     |    0.03125000 |         23 |
    | users                      |    0.03125000 |          3 |
    | services                   |    0.03125000 |          0 |
    | hstgrp                     |    0.03125000 |         27 |
    | history_log                |    0.03125000 |          0 |
    | dchecks                    |    0.03125000 |          8 |
    | valuemaps                  |    0.03125000 |         75 |
    | opcommand                  |    0.03125000 |          0 |
    | usrgrp                     |    0.03125000 |          8 |
    | media_type                 |    0.03125000 |         11 |
    | opmessage                  |    0.03125000 |         30 |
    | globalmacro                |    0.03125000 |          0 |
    | trigger_tag                |    0.03125000 |          0 |
    | screens_items              |    0.03125000 |         51 |
    | proxy_history              |    0.03125000 |          0 |
    | corr_condition_group       |    0.03125000 |          0 |
    | expressions                |    0.03125000 |         10 |
    | dashboard                  |    0.03125000 |          3 |
    | proxy_dhistory             |    0.03125000 |          0 |
    | corr_condition             |    0.03125000 |          0 |
    | operations                 |    0.03125000 |         32 |
    | httptest_field             |    0.03125000 |          0 |
    | sysmap_url                 |    0.03125000 |          0 |
    | proxy_autoreg_host         |    0.03125000 |          0 |
    | sysmap_shape               |    0.03125000 |          0 |
    | opconditions               |    0.03125000 |          0 |
    | event_tag                  |    0.03125000 |          0 |
    | corr_operation             |    0.03125000 |          0 |
    | timeperiods                |    0.01562500 |          0 |
    | corr_condition_tagvalue    |    0.01562500 |          0 |
    | task_remote_command_result |    0.01562500 |          0 |
    | corr_condition_tagpair     |    0.01562500 |          0 |
    | task_remote_command        |    0.01562500 |          0 |
    | corr_condition_tag         |    0.01562500 |          0 |
    | task_close_problem         |    0.01562500 |          0 |
    | task_check_now             |    0.01562500 |          0 |
    | housekeeper                |    0.01562500 |          0 |
    | ids                        |    0.01562500 |         52 |
    | globalvars                 |    0.01562500 |          0 |
    | dbversion                  |    0.01562500 |          0 |
    | task_acknowledge           |    0.01562500 |          0 |
    | opinventory                |    0.01562500 |          0 |
    | host_inventory             |    0.01562500 |         20 |
    +----------------------------+---------------+------------+
    144 rows in set (0.02 sec)
    
    mysql> 
    复制代码

    发现history和trends相关表数据量很大,一个是历史数据,一个是趋势数据

    需要对这些表进行分区操作,提高效率

    三、下载分区脚本

    复制代码
    drwxr-xr-x. 4 root root  4096 12月 26 2018 share
    [root@zabbix_server zabbix-4.0.3]# wget https://dl.cactifans.com/zabbix/partitiontables_gt_zbx34.sh
    --2019-06-28 11:20:28--  https://dl.cactifans.com/zabbix/partitiontables_gt_zbx34.sh
    正在解析主机 dl.cactifans.com... 222.186.135.67
    正在连接 dl.cactifans.com|222.186.135.67|:443... 已连接。
    已发出 HTTP 请求,正在等待回应... 200 OK
    长度:15458 (15K) [application/octet-stream]
    正在保存至: “partitiontables_gt_zbx34.sh.1”
    
    100%[===========================================================================================>] 15,458      --.-K/s   in 0s      
    
    2019-06-28 11:20:28 (428 MB/s) - 已保存 “partitiontables_gt_zbx34.sh.1” [15458/15458])
    
    [root@zabbix_server zabbix-4.0.3]# 
    复制代码

    四、编辑脚本相关参数

    脚本默认详情数据保留30天,趋势数据保留12个月,如需修改,请修改以下内容:

    daily_history_min=30
    monthly_history_min=12
     
    脚本默认连接数据库信息,更改成你的:
    DBHOST=localhost
    DBUSER=zabbix
    DBPASS=zabbix
    [root@zabbix_server zabbix-4.0.3]# chmod +x partitiontables_gt_zbx34.sh

    五、执行分区脚本

     停止zabbix_server服务

     12130 12129 12128) 正在运行...
    [root@zabbix_server zabbix-4.0.3]# service zabbix_server stop
    Shutting down zabbix_server: [确定]
    [root@zabbix_server zabbix-4.0.3]# service zabbix_server status
    zabbix_server 已停

    执行脚本

    [root@zabbix_server zabbix-4.0.3]# ./partitiontables_gt_zbx34.sh 
    Ready to partition tables.
    
    Ready to update permissions of Zabbix user to create routines
    
    Enter root DB user: 

    输入数据库用户名和密码

    复制代码
    Enter root DB user: root
    Enter root password: xxxxxxxx
    mysql: [Warning] Using a password on the command line interface can be insecure.
    ERROR 1133 (42000) at line 1: Can't find any matching row in the user table
    
    
    
    Do you want to backup the database (recommended) (Y/n): n
    Are you certain you have a backup (y/N): 
    y
    
    
    Ready to proceed:
    
    Starting yearly partioning at: 2019
    and ending at: 2019
    With 30 days of daily history
    复制代码
    复制代码
    Ready to proceed (Y/n): 
    y
    Altering table: history
    Altering table: history_log
    Altering table: history_str
    Altering table: history_text
    Altering table: history_uint
    Altering table: trends
    Altering table: trends_uint
    Creating monthly partitions for table: trends
    Creating monthly partitions for table: trends_uint
    Creating daily partitions for table: history
    Creating daily partitions for table: history_log
    Creating daily partitions for table: history_str
    Creating daily partitions for table: history_text
    Creating daily partitions for table: history_uint
    
    
    Ready to apply script to database, this may take a while.(Y/n): 
    复制代码
    复制代码
    Ready to apply script to database, this may take a while.(Y/n): 
    y
    mysql: [Warning] Using a password on the command line interface can be insecure.
    Altering tables
    history
    history_log
    history_str
    history_text
    history_uint
    trends
    trends_uint
    trends
    trends_uint
    history
    history_log
    history_str
    history_text
    history_uint
    Installing procedures
    
    If Zabbix Version = 2.0 
    Do you want to update the /etc/zabbix/zabbix_server.conf
    to disable housekeeping (Y/n): 
    复制代码

    这里会耗费很长时间,大概是1个小时左右

    复制代码
    If Zabbix Version = 2.0 
    Do you want to update the /etc/zabbix/zabbix_server.conf
    to disable housekeeping (Y/n): n
    
    Do you want to update the crontab (Y/n): y
    The crontab entry can be either in /etc/cron.daily, or added
    to the crontab for root
    
    Do you want to add this to the /etc/cron.daily directory (Y/n): y
    
    Enter email of who should get the daily housekeeping reports: chengpeng@9500.cn
    [root@zabbix_server zabbix-4.0.3]# 
    复制代码

    到此,脚本执行完毕

    六、查看生成的定时任务

    上面的脚本会在/etc/cron.daily目录下生成一个名称为zabbixhousekeeping的脚本

    [root@zabbix_server zabbix-4.0.3]# vim /etc/cron.daily/zabbixhousekeeping
     1 #!/bin/bash
      2 /usr/local/zabbix/cron.d/housekeeping.sh

    里面是执行了usr/local/zabbix/cron.d/housekeeping.sh脚本,打开这个脚本

    复制代码
    [root@zabbix_server zabbix-4.0.3]# vim /usr/local/zabbix/cron.d/housekeeping.sh
    #!/bin/bash
    
    MAILTO=chengpeng@9500.cn
    tmpfile=/tmp/housekeeping$$
    
    date >$tmpfile
    /usr/bin/mysql --skip-column-names -B -h localhost -uroot -pxxxxxx zabbix -e "CALL create_zabbix_partitions();" >>$tmpfile 2>&1
    /usr/bin/mail -s "Zabbix MySql Partition Housekeeping" $MAILTO <$tmpfile
    rm -f $tmpfile
    复制代码

    这个脚本是调用了Mysql的创建分区表存储过程

    七、查看分区结果

    1、首选查看zabbix数据库大小,

    分区之前

    复制代码
    mysql> select table_schema, concat(truncate(sum(data_length)/1024/1024,2),' mb') as data_size,concat(truncate(sum(index_length)/1024/1024,2),'mb') as index_size from information_schema.tables group by table_schema order by data_size desc;
    +--------------------+------------+------------+
    | table_schema       | data_size  | index_size |
    +--------------------+------------+------------+
    | zabbix             | 8326.06 mb | 3031.85mb  |
    | jumpserver         | 26.57 mb   | 8.21mb     |
    | mysql              | 2.49 mb    | 0.21mb     |
    | information_schema | 0.15 mb    | 0.00mb     |
    | sys                | 0.01 mb    | 0.00mb     |
    | performance_schema | 0.00 mb    | 0.00mb     |
    +--------------------+------------+------------+
    rows in set (0.40 sec)
    复制代码

    分区之后

    复制代码
    mysql> select table_schema, concat(truncate(sum(data_length)/1024/1024,2),' mb') as data_size,concat(truncate(sum(index_length)/1024/1024,2),'mb') as index_size from information_schema.tables group by table_schema order by data_size desc;
    +--------------------+------------+------------+
    | table_schema       | data_size  | index_size |
    +--------------------+------------+------------+
    | zabbix             | 6173.34 mb | 3859.25mb  |
    | jumpserver         | 26.57 mb   | 8.21mb     |
    | mysql              | 2.50 mb    | 0.21mb     |
    | information_schema | 0.15 mb    | 0.00mb     |
    | sys                | 0.01 mb    | 0.00mb     |
    | performance_schema | 0.00 mb    | 0.00mb     |
    +--------------------+------------+------------+
    6 rows in set (0.30 sec)
    
    mysql> 
    复制代码

    可以看出,数据库由8G缩小到6G,节省空间25%

    查看history数据表的分区信息

    复制代码
    mysql> select partition_name ,partition_expression,partition_description,table_rows from information_schema.partitions where table_schema=schema() and table_name='history';
    +----------------+----------------------+-----------------------+------------+
    | partition_name | partition_expression | partition_description | table_rows |
    +----------------+----------------------+-----------------------+------------+
    | p20190529      |  clock               | 1559145600            |    6532933 |
    | p20190530      |  clock               | 1559232000            |     713544 |
    | p20190531      |  clock               | 1559318400            |     821808 |
    | p20190601      |  clock               | 1559404800            |     862368 |
    | p20190602      |  clock               | 1559491200            |     801216 |
    | p20190603      |  clock               | 1559577600            |     757224 |
    | p20190604      |  clock               | 1559664000            |     802152 |
    | p20190605      |  clock               | 1559750400            |     711048 |
    | p20190606      |  clock               | 1559836800            |     769080 |
    | p20190607      |  clock               | 1559923200            |     755976 |
    | p20190608      |  clock               | 1560009600            |     621504 |
    | p20190609      |  clock               | 1560096000            |     709176 |
    | p20190610      |  clock               | 1560182400            |     777192 |
    | p20190611      |  clock               | 1560268800            |     806520 |
    | p20190612      |  clock               | 1560355200            |     839592 |
    | p20190613      |  clock               | 1560441600            |     840840 |
    | p20190614      |  clock               | 1560528000            |     941616 |
    | p20190615      |  clock               | 1560614400            |    1120080 |
    | p20190616      |  clock               | 1560700800            |     987085 |
    | p20190617      |  clock               | 1560787200            |    1106976 |
    | p20190618      |  clock               | 1560873600            |    1124136 |
    | p20190619      |  clock               | 1560960000            |    1118520 |
    | p20190620      |  clock               | 1561046400            |    1019437 |
    | p20190621      |  clock               | 1561132800            |    3016416 |
    | p20190622      |  clock               | 1561219200            |    3108162 |
    | p20190623      |  clock               | 1561305600            |    3152510 |
    | p20190624      |  clock               | 1561392000            |    3090047 |
    | p20190625      |  clock               | 1561478400            |    3286296 |
    | p20190626      |  clock               | 1561564800            |    3281930 |
    | p20190627      |  clock               | 1561651200            |    3124056 |
    | p20190628      |  clock               | 1561737600            |    1766947 |
    | p20190629      |  clock               | 1561824000            |          0 |
    | p20190630      |  clock               | 1561910400            |          0 |
    +----------------+----------------------+-----------------------+------------+
    33 rows in set (0.00 sec)
    
    mysql> 
    复制代码

    查看趋势数据表分区信息

    复制代码
    mysql> select partition_name ,partition_expression,partition_description,table_rows from information_schema.partitions where table_schema=schema() and table_name='trends';
    +----------------+----------------------+-----------------------+------------+
    | partition_name | partition_expression | partition_description | table_rows |
    +----------------+----------------------+-----------------------+------------+
    | p201901        |  clock               | 1548950400            |     172494 |
    | p201902        |  clock               | 1551369600            |     313390 |
    | p201903        |  clock               | 1554048000            |     412587 |
    | p201904        |  clock               | 1556640000            |     461279 |
    | p201905        |  clock               | 1559318400            |     533022 |
    | p201906        |  clock               | 1561910400            |     994819 |
    | p201907        |  clock               | 1564588800            |          0 |
    +----------------+----------------------+-----------------------+------------+
    7 rows in set (0.00 sec)
    复制代码

    表分区成功,重启zabbix服务

    [root@zabbix_server zabbix-4.0.3]# service  zabbix_server start
    Starting zabbix_server:  [确定]
    [root@zabbix_server zabbix-4.0.3]# 
  • 相关阅读:
    AIX配置时间服务器(NTP)
    weblogic的集群与配置
    Linux平台块设备到字符设备(裸设备)的三种映射方式(转载)
    什么是条带化(striping) ?(转载)
    ORACLE directory 目录--转载
    Linux安装MySQL的两种方法
    Goldengate trial队列维护
    Oracle GoldenGate 11.2 OGG-01168(转)
    编程之美---最大公约数
    敏感词过滤的算法原理之DFA算法
  • 原文地址:https://www.cnblogs.com/xzlive/p/11534854.html
Copyright © 2020-2023  润新知