亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 數據庫 > MySQL > 正文

Mysql優化之Zabbix分區優化

2024-07-24 13:15:05
字體:
來源:轉載
供稿:網友

使用zabbix最大的瓶頸在于數據庫,維護好zabbix的數據存儲,告警,就能很好地應用zabbix去構建監控系統。目前zabbix的數據主要存儲在history和trends的2個表中,隨著時間的推移,這兩個表變得非常大,性能會非常差,影響監控的使用。對MySQL進行調優,能夠極大的提升Zabbix的性能,本文采用對MySQL進行分區的方法進行調優。

原理

對zabbix中的history和trends等表進行分區,按日期進行分區,每天一個,共保留90天分區。

操作詳細步驟

操作影響: 可以在線操作,MySQL的讀寫變慢,Zabbix性能變慢,影響時間根據數據的小而變化,一般在2個小時左右。

第一步

登錄zabbix server的數據庫,統一MySQL的配置

cat > /etc/my.cnf<<EOF[mysqld]datadir=/data/mysqlsocket=/var/lib/mysql/mysql.sockdefault-storage-engine = innodbcollation-server = utf8_general_ciinit-connect = 'SET NAMES utf8'character-set-server = utf8symbolic-links=0max_connections=4096innodb_buffer_pool_size=12Gmax_allowed_packet = 32Mjoin_buffer_size=2Msort_buffer_size=2M query_cache_size = 64M  query_cache_limit = 4M  thread_concurrency = 8table_open_cache=1024innodb_flush_log_at_trx_commit = 0long_query_time = 1log-slow-queries =/data/mysql/mysql-slow.log [mysqld_safe]log-error=/var/log/mariadb/mariadb.logpid-file=/var/run/mariadb/mariadb.pid#[mysql]#socket=/data/mysql/mysql.sock## include all files from the config directory#!includedir /etc/my.cnf.dEOF

注意:一定要修改innodb_buffer_pool_size=物理內存的1/3

第二步

先確認zabbix的版本,本操作zabbix的版本一定要大于3.2.0。小于3.2的版本不能安裝此操作,線上默認是zabbix-3.2.6。

a、 導入存儲過程

#cat partition.sqlDELIMITER $$CREATE PROCEDURE `partition_create`(SCHEMANAMEvarchar(64), TABLENAME varchar(64), PARTITIONNAME varchar(64), CLOCK int)BEGIN    /*     SCHEMANAME = The DB schema in which to make changes     TABLENAME = The table with partitions to potentially delete     PARTITIONNAME = The name of the partition to create    */    /*     Verify that the partition does not already exist    */    DECLARE RETROWS INT;    SELECT COUNT(1) INTO RETROWS    FROM information_schema.partitions    WHERE table_schema = SCHEMANAME AND table_name = TABLENAME ANDpartition_description >= CLOCK;    IF RETROWS = 0 THEN        /*          1. Print a messageindicating that a partition was created.          2. Create the SQL to createthe partition.          3. Execute the SQL from #2.        */        SELECT CONCAT( "partition_create(", SCHEMANAME, ",",TABLENAME, ",", PARTITIONNAME, ",", CLOCK, ")" )AS msg;        SET @sql = CONCAT( 'ALTER TABLE ', SCHEMANAME, '.', TABLENAME, ' ADDPARTITION (PARTITION ', PARTITIONNAME, ' VALUES LESS THAN (', CLOCK, '));' );        PREPARE STMT FROM @sql;        EXECUTE STMT;        DEALLOCATE PREPARE STMT;    END IF;END$$DELIMITER ;DELIMITER $$CREATE PROCEDURE `partition_drop`(SCHEMANAMEVARCHAR(64), TABLENAME VARCHAR(64), DELETE_BELOW_PARTITION_DATE BIGINT)BEGIN    /*      SCHEMANAME = The DB schema in which tomake changes     TABLENAME = The table with partitions to potentially delete     DELETE_BELOW_PARTITION_DATE = Delete any partitions with names that aredates older than this one (yyyy-mm-dd)    */    DECLARE done INT DEFAULT FALSE;    DECLARE drop_part_name VARCHAR(16);    /*     Get a list of all the partitions that are older than the date     in DELETE_BELOW_PARTITION_DATE. All partitions are prefixed with      a "p", so use SUBSTRING TOget rid of that character.    */    DECLARE myCursor CURSOR FOR        SELECT partition_name        FROM information_schema.partitions        WHERE table_schema = SCHEMANAME AND table_name = TABLENAME ANDCAST(SUBSTRING(partition_name FROM 2) AS UNSIGNED) <DELETE_BELOW_PARTITION_DATE;    DECLARE CONTINUE HANDLER FOR NOT FOUND SET done = TRUE;    /*     Create the basics for when we need to drop the partition. Also, create     @drop_partitions to hold a comma-delimited list of all partitions that     should be deleted.    */    SET @alter_header = CONCAT("ALTER TABLE ", SCHEMANAME,".", TABLENAME, " DROP PARTITION ");    SET @drop_partitions = "";    /*     Start looping through all the partitions that are too old.    */    OPEN myCursor;    read_loop: LOOP        FETCH myCursor INTO drop_part_name;        IF done THEN            LEAVE read_loop;        END IF;        SET @drop_partitions = IF(@drop_partitions = "",drop_part_name, CONCAT(@drop_partitions, ",", drop_part_name));    END LOOP;    IF @drop_partitions != "" THEN        /*          1. Build the SQL to drop allthe necessary partitions.          2. Run the SQL to drop thepartitions.          3. Print out the tablepartitions that were deleted.        */        SET @full_sql = CONCAT(@alter_header, @drop_partitions, ";");        PREPARE STMT FROM @full_sql;        EXECUTE STMT;        DEALLOCATE PREPARE STMT;        SELECT CONCAT(SCHEMANAME, ".", TABLENAME) AS `table`,@drop_partitions AS `partitions_deleted`;    ELSE        /*          No partitions are beingdeleted, so print out "N/A" (Not applicable) to indicate          that no changes were made.        */        SELECT CONCAT(SCHEMANAME, ".", TABLENAME) AS `table`,"N/A" AS `partitions_deleted`;    END IF;END$$DELIMITER ;DELIMITER $$CREATE PROCEDURE`partition_maintenance`(SCHEMA_NAME VARCHAR(32), TABLE_NAME VARCHAR(32),KEEP_DATA_DAYS INT, HOURLY_INTERVAL INT, CREATE_NEXT_INTERVALS INT)BEGIN    DECLARE OLDER_THAN_PARTITION_DATE VARCHAR(16);    DECLARE PARTITION_NAME VARCHAR(16);    DECLARE OLD_PARTITION_NAME VARCHAR(16);    DECLARE LESS_THAN_TIMESTAMP INT;    DECLARE CUR_TIME INT;    CALL partition_verify(SCHEMA_NAME,TABLE_NAME, HOURLY_INTERVAL);    SET CUR_TIME = UNIX_TIMESTAMP(DATE_FORMAT(NOW(), '%Y-%m-%d 00:00:00'));    SET @__interval = 1;    create_loop: LOOP        IF @__interval > CREATE_NEXT_INTERVALS THEN            LEAVE create_loop;        END IF;        SET LESS_THAN_TIMESTAMP = CUR_TIME + (HOURLY_INTERVAL * @__interval *3600);        SET PARTITION_NAME = FROM_UNIXTIME(CUR_TIME + HOURLY_INTERVAL *(@__interval - 1) * 3600, 'p%Y%m%d%H00');        IF(PARTITION_NAME != OLD_PARTITION_NAME) THEN            CALLpartition_create(SCHEMA_NAME, TABLE_NAME, PARTITION_NAME, LESS_THAN_TIMESTAMP);        END IF;        SET @__interval=@__interval+1;        SET OLD_PARTITION_NAME = PARTITION_NAME;    END LOOP;    SET OLDER_THAN_PARTITION_DATE=DATE_FORMAT(DATE_SUB(NOW(), INTERVALKEEP_DATA_DAYS DAY), '%Y%m%d0000');    CALL partition_drop(SCHEMA_NAME, TABLE_NAME, OLDER_THAN_PARTITION_DATE);END$$DELIMITER ;DELIMITER $$CREATE PROCEDURE `partition_verify`(SCHEMANAMEVARCHAR(64), TABLENAME VARCHAR(64), HOURLYINTERVAL INT(11))BEGIN    DECLARE PARTITION_NAME VARCHAR(16);    DECLARE RETROWS INT(11);    DECLARE FUTURE_TIMESTAMP TIMESTAMP;    /*    * Check if any partitions exist for the given SCHEMANAME.TABLENAME.    */    SELECT COUNT(1) INTO RETROWS    FROM information_schema.partitions    WHERE table_schema = SCHEMANAME AND table_name = TABLENAME ANDpartition_name IS NULL;    /*    * If partitions do not exist, go ahead and partition the table    */    IFRETROWS = 1 THEN        /*        * Take the current date at 00:00:00 and add HOURLYINTERVAL to it. This is the timestamp below which we willstore values.        * We begin partitioning based on the beginning of a day. This is because we don't want to generate arandom partition        * that won't necessarily fall in line with the desired partition naming(ie: if the hour interval is 24 hours, we could        * end up creating a partition now named "p201403270600" whenall other partitions will be like "p201403280000").        */        SET FUTURE_TIMESTAMP = TIMESTAMPADD(HOUR, HOURLYINTERVAL,CONCAT(CURDATE(), " ", '00:00:00'));        SET PARTITION_NAME = DATE_FORMAT(CURDATE(), 'p%Y%m%d%H00');        -- Create the partitioning query        SET @__PARTITION_SQL = CONCAT("ALTER TABLE ", SCHEMANAME,".", TABLENAME, " PARTITION BY RANGE(`clock`)");        SET @__PARTITION_SQL = CONCAT(@__PARTITION_SQL, "(PARTITION ",PARTITION_NAME, " VALUES LESS THAN (",UNIX_TIMESTAMP(FUTURE_TIMESTAMP), "));");        -- Run the partitioning query        PREPARE STMT FROM @__PARTITION_SQL;        EXECUTE STMT;        DEALLOCATE PREPARE STMT;    END IF;END$$DELIMITER ;DELIMITER $$CREATE PROCEDURE`partition_maintenance_all`(SCHEMA_NAME VARCHAR(32))BEGIN        CALL partition_maintenance(SCHEMA_NAME, 'history', 90, 24, 14);        CALL partition_maintenance(SCHEMA_NAME, 'history_log', 90, 24, 14);        CALL partition_maintenance(SCHEMA_NAME, 'history_str', 90, 24, 14);        CALL partition_maintenance(SCHEMA_NAME, 'history_text', 90, 24, 14);        CALLpartition_maintenance(SCHEMA_NAME, 'history_uint', 90, 24, 14);        CALL partition_maintenance(SCHEMA_NAME, 'trends', 730, 24, 14);        CALL partition_maintenance(SCHEMA_NAME, 'trends_uint', 730, 24, 14);END$$DELIMITER ;

上面內容包含了創建分區的存儲過程,將上面內容復制到partition.sql中,然后執行如下:

mysql -uzabbix -pzabbix zabbix < partition.sql

b、 添加crontable,每天執行01點01分執行,如下:

crontab -l > crontab.txt cat >> crontab.txt <<EOF#zabbix partition_maintenance01 01 * * * mysql -uzabbix -pzabbix zabbix -e"CALL partition_maintenance_all('zabbix')" &>/dev/nullEOFcat crontab.txt |crontab

注意: mysql的zabbix用戶的密碼部分按照實際環境配置

c、首先執行一次(由于首次執行的時間較長,請使用nohup執行),如下:

nohup  mysql -uzabbix -pzabbix zabbix -e "CALLpartition_maintenance_all('zabbix')" &> /root/partition.log&

注意:觀察/root/partition.log的輸出

d、 查看結果

登錄mysql,查看history等表, 如下:

MariaDB [zabbix]> showcreate table history| history | CREATE TABLE `history` ( `itemid` bigint(20) unsigned NOT NULL, `clock`int(11) NOT NULL DEFAULT '0', `value`double(16,4) NOT NULL DEFAULT '0.0000', `ns`int(11) NOT NULL DEFAULT '0', KEY`history_1` (`itemid`,`clock`)) ENGINE=InnoDB DEFAULT CHARSET=utf8/*!50100 PARTITION BY RANGE (`clock`)(PARTITION p201708280000 VALUES LESS THAN(1503936000) ENGINE = InnoDB, PARTITION p201708290000 VALUES LESS THAN(1504022400) ENGINE = InnoDB, PARTITION p201708300000 VALUES LESS THAN(1504108800) ENGINE = InnoDB, PARTITION p201708310000 VALUES LESS THAN(1504195200) ENGINE = InnoDB, PARTITION p201709010000 VALUES LESS THAN(1504281600) ENGINE = InnoDB, PARTITION p201709020000 VALUES LESS THAN(1504368000) ENGINE = InnoDB, PARTITION p201709030000 VALUES LESS THAN(1504454400) ENGINE = InnoDB, PARTITION p201709040000 VALUES LESS THAN(1504540800) ENGINE = InnoDB, PARTITION p201709050000 VALUES LESS THAN(1504627200) ENGINE = InnoDB, PARTITION p201709060000 VALUES LESS THAN(1504713600) ENGINE = InnoDB, PARTITION p201709070000 VALUES LESS THAN(1504800000) ENGINE = InnoDB, PARTITION p201709080000 VALUES LESS THAN(1504886400) ENGINE = InnoDB, PARTITION p201709090000 VALUES LESS THAN(1504972800) ENGINE = InnoDB, PARTITION p201709100000 VALUES LESS THAN(1505059200) ENGINE = InnoDB, PARTITION p201709110000 VALUES LESS THAN(1505145600) ENGINE = InnoDB) */ |

發現了大量PARTITION字段,說明配置正確。注意觀察Mysql的Slow Query,一般到執行操作的第二天,Slow Query幾乎就會有了,此時Zabbix的Dashboard響應速度應該非常流暢了。


注:相關教程知識閱讀請移步到MYSQL教程頻道。
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
亚洲激情在线视频| 在线观看国产精品日韩av| 国产男人精品视频| 久久精品精品电影网| 中文字幕日韩欧美精品在线观看| 欧美日韩美女在线| 欧美国产日产韩国视频| 久久精品国产一区二区电影| 国产欧美一区二区三区视频| 亚洲色图美腿丝袜| 成人午夜在线影院| 色www亚洲国产张柏芝| 亚洲图片在区色| 久久精品视频va| 性欧美在线看片a免费观看| 中文字幕精品久久| 色爱av美腿丝袜综合粉嫩av| 中文字幕日韩欧美| 午夜精品福利视频| 欧美精品在线视频观看| 欧美整片在线观看| 国产精品91在线观看| 91美女高潮出水| 国产+成+人+亚洲欧洲| 欧美一级在线亚洲天堂| 国产精品中文久久久久久久| 欧美成人免费全部观看天天性色| 91理论片午午论夜理片久久| 欧美在线www| 亚洲电影免费观看高清完整版在线观看| 九九热最新视频//这里只有精品| 欧美日韩亚洲视频一区| 亚洲色图欧美制服丝袜另类第一页| 欧美一区三区三区高中清蜜桃| 亚洲国产精品va在看黑人| 成人黄色网免费| 亚洲美女中文字幕| www.亚洲一区| 国产成人一区二| 视频一区视频二区国产精品| 亚洲精品ady| 成人欧美一区二区三区在线| 福利视频一区二区| 国产午夜精品美女视频明星a级| 国产精品久久激情| 88xx成人精品| 亚洲精品国产精品乱码不99按摩| 亚洲激情视频网站| 日韩精品久久久久久久玫瑰园| 日韩中文视频免费在线观看| 欧美华人在线视频| 久久天天躁夜夜躁狠狠躁2022| 少妇高潮久久77777| 国产成人精品亚洲精品| 清纯唯美亚洲综合| 久久久久久com| 国产精品狠色婷| 久久九九免费视频| 成人久久18免费网站图片| 一本色道久久88综合日韩精品| 在线视频欧美日韩| 亚洲最大av网| 亚洲第一区在线| 91精品国产99久久久久久| 日韩免费高清在线观看| 日韩精品免费在线视频| 欧美黑人xxx| 久久视频在线直播| 国产欧美日韩中文| 中文字幕欧美日韩va免费视频| 欧美激情综合亚洲一二区| 久久精品亚洲国产| 国产福利精品在线| 97免费中文视频在线观看| 一本大道亚洲视频| 亚洲www在线| www.欧美三级电影.com| 中文综合在线观看| 日韩禁在线播放| 国产成人一区二区三区小说| 亚洲高清一二三区| 不卡毛片在线看| 欧美日韩激情视频| 成人福利在线观看| 国产在线a不卡| 欧美日韩性生活视频| 精品成人av一区| 黄色成人av在线| 成人美女免费网站视频| 欧美大片免费观看| 欧美成年人视频| 国产91在线高潮白浆在线观看| 欧美一区二区大胆人体摄影专业网站| 中文字幕日本精品| 欧美乱妇高清无乱码| 97久久久免费福利网址| 欧美激情视频一区| 美日韩精品免费观看视频| 久久久亚洲影院你懂的| 欧美日本在线视频中文字字幕| 久久成人精品电影| 欧美一区二区三区四区在线| 亚洲国产精品国自产拍av秋霞| 亚洲xxxxx性| 国产精品一区二区三| 激情成人中文字幕| 亚洲欧美日韩成人| 国产91精品高潮白浆喷水| 欧亚精品在线观看| 亚洲欧美成人精品| 国产精品久久久久久久久久久新郎| 日韩黄色高清视频| 亚洲精品欧美日韩| 国产一区二区色| 亚洲日本成人女熟在线观看| 欧美丰满少妇xxxx| 97久久久免费福利网址| 日韩电影免费观看在线观看| 国产精品久久久久久久久久免费| 亚洲性69xxxbbb| 精品久久久久久中文字幕一区奶水| 97在线免费观看| 姬川优奈aav一区二区| 在线成人中文字幕| 日本韩国欧美精品大片卡二| 国产日韩在线播放| 日韩欧美在线第一页| 国产精品激情av在线播放| 欧美成人一区在线| 国产又爽又黄的激情精品视频| 亚洲美女性视频| 欧美丰满老妇厨房牲生活| 亚洲精品自拍视频| 亚洲精品在线91| 这里只有精品在线观看| 国产精品电影网| 九色成人免费视频| 国产成人精品一区| 亚洲激情第一页| 精品国产自在精品国产浪潮| 国产成人涩涩涩视频在线观看| 久久中文字幕视频| 久久久久中文字幕2018| 精品中文字幕在线观看| 亚洲天堂av女优| 欧美成人高清视频| 国产综合在线看| 欧美激情图片区| 欧美精品免费在线观看| 国产精品一区二区三区成人| 高清欧美性猛交| 日韩欧美国产视频| 精品久久久久久久久中文字幕| 91久久精品日日躁夜夜躁国产| 亚洲jizzjizz日本少妇| 亚洲加勒比久久88色综合| 日韩欧美一区二区在线| 久久久av亚洲男天堂| 精品久久香蕉国产线看观看亚洲| 性欧美在线看片a免费观看| 黄色成人在线免费| 日韩国产欧美精品在线| 色综合男人天堂| 欧美高清激情视频|