国产激情自拍_国产9色视频_丁香花在线电影小说观看 _久久久久国产精品嫩草影院

首頁 > 數(shù)據(jù)庫 > MySQL > 正文

Mysql優(yōu)化之Zabbix分區(qū)優(yōu)化

2024-07-24 13:15:05
字體:
供稿:網(wǎng)友

使用zabbix最大的瓶頸在于數(shù)據(jù)庫,維護(hù)好zabbix的數(shù)據(jù)存儲,告警,就能很好地應(yīng)用zabbix去構(gòu)建監(jiān)控系統(tǒng)。目前zabbix的數(shù)據(jù)主要存儲在history和trends的2個表中,隨著時間的推移,這兩個表變得非常大,性能會非常差,影響監(jiān)控的使用。對MySQL進(jìn)行調(diào)優(yōu),能夠極大的提升Zabbix的性能,本文采用對MySQL進(jìn)行分區(qū)的方法進(jìn)行調(diào)優(yōu)。

原理

對zabbix中的history和trends等表進(jìn)行分區(qū),按日期進(jìn)行分區(qū),每天一個,共保留90天分區(qū)。

操作詳細(xì)步驟

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

第一步

登錄zabbix server的數(shù)據(jù)庫,統(tǒng)一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=物理內(nèi)存的1/3

第二步

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

a、 導(dǎo)入存儲過程

#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 ;

上面內(nèi)容包含了創(chuàng)建分區(qū)的存儲過程,將上面內(nèi)容復(fù)制到partition.sql中,然后執(zhí)行如下:

mysql -uzabbix -pzabbix zabbix < partition.sql

b、 添加crontable,每天執(zhí)行01點(diǎn)01分執(zhí)行,如下:

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用戶的密碼部分按照實際環(huán)境配置

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

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

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

d、 查看結(jié)果

登錄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) */ |

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


注:相關(guān)教程知識閱讀請移步到MYSQL教程頻道。
發(fā)表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發(fā)表
国产激情自拍_国产9色视频_丁香花在线电影小说观看 _久久久久国产精品嫩草影院
久久久久久久久亚洲精品| 九九热免费视频| 黄色国产网站在线播放| 伊人色综合网| 日本高清中文字幕二区在线| 女同一区二区免费aⅴ| 超碰在线中文| 国产在线拍揄自揄拍视频| 超碰在线网站| 国产日韩欧美精品一区二区三区 | 国产xxxxx| av一级在线| 高清视频一区二区三区四区| 中文字幕国产在线| 亚洲高清在线免费| 国产美女极品在线| 国产成免费视频| 免费不卡中文字幕视频| 精品网站www| 丁香婷婷激情| 日本三级视频网站| 精品亚洲综合| 国产美女高潮| www.狠狠操.com| 国产精品18久久久久网站| 狠狠操五月天| 青青草观看免费视频在线| 国产欧美日韩第一页| 国产在线视频网站| 青青久草在线| 免费视频二区| 精品av中文字幕在线毛片| 中文字幕免费中文| 午夜免费福利在线观看| 欧美色第一页| 亚洲高清在线免费| 在线免费观看你懂的| 2020亚洲男人天堂| 在线中文字幕第一页| 国产a级网站| 国产精品69一区二区三区| 国产污污在线观看| 国产丝袜在线| 国产盗摄精品一区二区酒店| 国产视频福利| 51成人精品网站| 天堂在线免费av| 天天操天天射天天插| 国产系列在线观看| 国产福利在线| 伊人网站在线| 免费看成年人视频在线观看| 欧美艹逼视频| 国产免费视频| 91九色在线看| 欧美一级久久久久久久久大| 黄色毛片在线观看| 国产一卡2卡3卡免费网站| 国产网友自拍电影在线 | 国产黄色一级电影| 国产精品四虎| 亚洲精品在线视频免费| 亚洲欧美自拍另类| 国产麻豆精品高清在线播放| 最近中文av字幕在线中文| 国产一卡二卡3卡4卡四卡在线| 国产精品四虎| 亚洲精品午夜级久久久久| 久久久久久久久久久久久91| 国产午夜电影| av在线不卡网站| 国产女王在线**视频| 精品麻豆国产| 免费不卡中文字幕视频| 国产视频一二| av网址在线看| 中文字幕不卡| 波多野结衣中文字幕久久| 国产一区二区在线|播放| v天堂福利视频在线观看| 国产美女高潮| 牛牛精品视频在线| 亚洲欧美日韩成人网| 国产精品国产国产aⅴ| 免费的黄网站在线观看| 18av在线播放| 国产永久免费高清在线观看| av大片在线播放| 18加网站在线| 丁香婷婷在线| 九九久久久2| 开心快乐六月丁香婷婷| 天堂√中文在线| 国产福利在线视频| 国产一二区视频| 五月综合网站| 国产日产一区二区| 国产亚洲精品午夜高清影院| 18加网站在线| 国产呻吟对白刺激无套视频在线| 久草一本av| 开心快乐六月丁香婷婷| 伊人伊人av电影| 中文视频在线| 亚洲成a人v欧美综合天堂麻豆| 99热99re6国产在线播放| 国产91久久久久| 69久久精品| 中文在线有码| 亚洲综合在线不卡| 亚洲欧美日韩综合精品网| 在线免费观看黄色av| 在线观看的网站你懂的| 性网站在线观看| 久久精品国产亚洲777| 成人av小说网| 高清欧美精品xxxxx在线看| 久久久久久久久久久久网站| 最近中文字幕mv免费高清电影| 国产人成高清视频观看| 中文乱码字幕av网站| www.三区| 国产精品你懂的在线观看| 91亚洲欧美| 日本成人网址| 国产私拍精品| 日本高清中文字幕在线| 国产亚洲精品久久久久久青梅| 国产高清视频在线观看| 四虎影院成人| 最近中文字幕av免费高清| 亚洲视频在线网| 欧美黑人乱大交ⅹxxxxx| 国产视频xxx| 开心丁香婷婷深爱五月| 9999在线视频| 中文字幕有码在线视频| 超碰91在线| 国产高潮av| 国产老肥熟xxxx在线观看| 天天插天天色| 91中文在线| 国产午夜三区视频在线| 欧美人成在线观看网站高清| 国产福利微拍精品一区二区| 粉嫩av一区| 免费在线看v| 国产h色视频在线观看| 国产男女av| 激情小说 在线视频| 三级小说一区| 影音先锋中文字幕在线| 国产视频1区| 国产视频xxxx| 国产色在线观看| 国产尤物视频在线| 国产在线一二三| 九九精品九九| 狠狠色丁香婷婷| 九色在线网站| 国产91大片| 国产美女在线播放| 快射av在线播放一区| 免费三级毛片| 成年人在线观看| 国产在线一二三| 丁香综合五月| 国产一级片麻豆| 国产精品伦一区二区三区视频| 中文字幕成人乱码在线电影| 丁香花高清在线观看完整版| 高清色视频在线观看| 1区不卡电影| 国产激情二区| 日本国产在线| 99视频免费| 精精国产xxxx视频在线动漫| 国产精品186在线观看在线播放| 国产精品二线| 一本久中文高清| 久久国产综合视频| 国产三级在线免费观看| 精品极品三级久久久久| 日本高清中文字幕| 天天操夜夜操天天射| 国产不卡视频| 成 人免费视频播放| 国产极品一区二区三区 | 在线观看免费观看在线91| 亚洲www色| 国产字幕在线看| 6699久久国产精品免费| 欧美性猛交xxxx免费看蜜桃| 尤物网在线观看| 影音先锋日韩| 最新黄网在线观看| 欧美性猛交xxxx免费看蜜桃| 国产日产一区二区三区| www.99av| 在线观看中文字幕一区|