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

首頁 > 數據庫 > MySQL > 正文

mysql tmp_table_size優化之設置多大合適

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

通過設置tmp_table_size選項來增加一張臨時表的大小,例如做高級GROUP BY操作生成的臨時表。如果調高該值,MySQL同時將增加heap表的大小,可達到提高聯接查詢速度的效果,建議盡量優化查詢,要確保查詢過程中生成的臨時表在內存中,避免臨時表過大導致生成基于硬盤的MyISAM表。

mysql> show global status like ‘created_tmp%‘;

+——————————–+———+

| Variable_name   | Value |

+———————————-+———+

| Created_tmp_disk_tables | 21197 |

| Created_tmp_files   | 58  |

| Created_tmp_tables  | 1771587 |

+——————————–+———–+

每次創建臨時表,Created_tmp_tables增加,如果臨時表大小超過tmp_table_size,則是在磁盤上創建臨時表,Created_tmp_disk_tables也增加,Created_tmp_files表示MySQL服務創建的臨時文件文件數,比較理想的配置是:

Created_tmp_disk_tables / Created_tmp_tables * 100% <= 25%比如上面的服務器Created_tmp_disk_tables / Created_tmp_tables * 100% =1.20%,應該相當好了

默認為16M,可調到64-256最佳,線程獨占,太大可能內存不夠I/O堵塞

如果動態頁面要調大點,100M以上,如果網站大部分都是靜態內容,一般64M足夠。

tmp_table_size優化

數據庫連接突然增多到1000的問題

查看了一下,未有LOCK操作語句。

但是明顯有好多copy to tmp table的SQL語句,這條語讀的時間比較長,且這個表會被加讀鎖,相關表的update語句會被排進隊列。如果多執行幾次這樣的copyt to tmp table 語句,會造成更多的語句被阻塞。
連接太多造成mysql處理慢。

copy to tmp talbe 語句產生的原因是查詢需要Order By 或者Group By等需要用到結果集時,參數中設置的臨時表的大小小于結果集的大小時,就會將該表放在磁盤上,這個時候在硬盤上的IO要比內銷差很多。所耗費的時間也多很多。另外Mysql的另外一個參數max_heap_table_size比tmp_table_size小時,則系統會把max_heap_table_size的值作為最大的內存臨時表的上限,大于這個時,改寫硬盤。
我們的mysql這兩個參數為:

tmp_table_size 33554432 (33.5M)
max_heap_table_size 16777216 (16.7M)
比較小。
建議增加到上百M。我們的內存應該夠吧。

另外join_buffer_size(影響 表之間join性能的緩存)為131072 (131K)較小,可以增加一點。

[root@mail ~]# vi /etc/my.cnf

[mysqld]
tmp_table_size=200M

mysql> show processlist;
mysql> show columns from wp_posts;

SQL 語句的第一個 LEFT JOIN ON 子句中: LEFT JOIN _myuser AS t3 ON t1.userid=t3.userid _mydata 的 userid 被參與了條件比較運算。為 _mydata 表根據字段 userid 建立了一個索引: mysql> ALTER TABLE `_mydata` ADD INDEX ( `userid` )  增加 tmp_table_size 值。
mysql 的配置文件中,tmp_table_size 的默認大小是 32M。如果一張臨時表超出該大小,MySQL產生一個 The table tbl_name is full 形式的錯誤,如果你做很多高級 GROUP BY 查詢,增加 tmp_table_size 值。 這是 mysql 官方關于此選項的解釋:

tmp_table_size

This variable determines the maximum size for a temporary table in memory. If the table becomes too large, a MYISAM table is created on disk. Try to avoid temporary tables by optimizing the queries where possible, but where this is not possible, try to ensure temporary tables are always stored in memory. Watching the processlist for queries with temporary tables that take too long to resolve can give you an early warning that tmp_table_size needs to be upped. Be aware that memory is also allocated per-thread. An example where upping this worked for more was a server where I upped this from 32MB (the default) to 64MB with immediate effect. The quicker resolution of queries resulted in less threads being active at any one time, with all-round benefits for the server, and available memory.
對 WHERE, JOIN, MAX(), MIN(), ORDER BY 等子句中的條件判斷中用到的字段,應該根據其建立索引INDEX。
索引被用來快速找出在一個列上用一特定值的行。沒有索引,MySQL不得不首先以第一條記錄開始并然后讀完整個表直到它找出相關的行。表越大,花費時間越多。如果表對于查詢的列有一個索引,MySQL能快速到達一個位置去搜尋到數據文件的中間,沒有必要考慮所有數據。如果一個表有1000行,這比順序讀取至少快100倍。所有的MySQL索引(PRIMARY、UNIQUE和INDEX)在B樹中存儲。
根據 mysql 的開發文檔:

索引 index 用于:
快速找出匹配一個WHERE子句的行
當執行聯結(JOIN)時,從其他表檢索行。
對特定的索引列找出MAX()或MIN()值
如果排序或分組在一個可用鍵的最左面前綴上進行(例如,ORDER BY key_part_1,key_part_2),排序或分組一個表。如果所有鍵值部分跟隨DESC,鍵以倒序被讀取。
在一些情況中,一個查詢能被優化來檢索值,不用咨詢數據文件。如果對某些表的所有使用的列是數字型的并且構成某些鍵的最左面前綴,為了更快,值可以從索引樹被檢索出來。
假定你發出下列SELECT語句:

mysql> select * FROM tbl_name WHERE col1=val1 AND col2=val2;如果一個多列索引存在于col1和col2上,適當的行可以直接被取出。如果分開的單行列索引存在于col1和col2上,優化器試圖通過決定哪個索引將找到更少的行并來找出更具限制性的索引并且使用該索引取行。
一般動態設置tmp_table_size的大小的時候,要使用:

set global tmp_table_size=64*1024*1024
set global tmp_table_size=64M
#1232 - Incorrect argument type to variable 'tmp_table_size'


注:相關教程知識閱讀請移步到MYSQL教程頻道。
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
成人精品一区二区三区电影黑人| 精品亚洲一区二区三区四区五区| 日韩欧美国产激情| 亚洲欧洲在线视频| 97人人模人人爽人人喊中文字| 久久99久国产精品黄毛片入口| 成人黄色av播放免费| 日韩在线免费观看视频| 日韩av在线网址| 中文字幕亚洲一区在线观看| 欧美野外猛男的大粗鳮| 国产精品电影在线观看| 日韩av中文在线| 国产91精品视频在线观看| 91精品国产自产在线观看永久| 久久久久久av| 亚洲福利小视频| 欧美乱大交xxxxx另类电影| 精品国产91久久久久久老师| 91精品美女在线| 国产精品吴梦梦| 亚洲精品国产精品久久清纯直播| 青草青草久热精品视频在线网站| 深夜福利国产精品| 精品国产999| www.xxxx欧美| 日韩精品在线视频观看| 亚洲美女精品久久| 久久久噜久噜久久综合| 国产精品中文字幕久久久| 欧美精品18videosex性欧美| 91国内精品久久| 亚洲国产精品99| 久久久久久成人精品| 国产精品久久久久久久久久久久久| 亚洲免费影视第一页| 国产精品www网站| 久久国产精品久久久久| 91精品久久久久久久久不口人| 欧美日韩国产综合视频在线观看中文| 亚洲精品欧美极品| 国产欧美精品在线| 色香阁99久久精品久久久| 69av在线播放| 午夜精品视频在线| 91免费欧美精品| 久久九九免费视频| 91国在线精品国内播放| 久99九色视频在线观看| 久久精品久久精品亚洲人| 日韩高清av在线| 伊人久久久久久久久久久久久| 欧美成人精品xxx| 91九色单男在线观看| 欧美主播福利视频| 亚洲国产精品成人av| 国产一区二区三区日韩欧美| 91精品久久久久久久久久久| 亚洲精品小视频| 精品一区二区亚洲| 91精品在线国产| 亚洲成色www8888| 亚洲国产成人久久综合| 国产精品777| 久久91超碰青草是什么| 欧美日韩国产综合视频在线观看中文| 亚洲国内高清视频| 国产亚洲精品美女| 中文字幕欧美视频在线| 国产成人91久久精品| 欧美成人精品不卡视频在线观看| 高潮白浆女日韩av免费看| 亚洲精品视频免费| 欧美日韩国产一区在线| 97在线视频免费播放| 隔壁老王国产在线精品| 国产精品一区专区欧美日韩| 久久国产精品99国产精| 国产精品大片wwwwww| 国产精品色视频| 亚洲精品国产品国语在线| 日韩性xxxx爱| 俺去了亚洲欧美日韩| 成人免费观看a| 亚洲欧美综合精品久久成人| 国产一区二区视频在线观看| 九九热精品视频| 最近2019年手机中文字幕| 亚洲a在线观看| 日韩精品免费视频| 国产精品久久久久久久久久| 国产欧美一区二区三区久久| 亚洲国产美女精品久久久久∴| 国产精品露脸自拍| 久久久久久久久久久成人| 日韩欧美国产视频| 亚洲伊人久久综合| 国产一区av在线| 亚洲乱码一区av黑人高潮| 日韩美女中文字幕| 国产一区二区三区18| 日韩av影片在线观看| 日韩精品视频在线观看免费| 欧美午夜片欧美片在线观看| 欧美劲爆第一页| 最近的2019中文字幕免费一页| 亚洲黄色www网站| 欧美日韩免费一区| 国产成人鲁鲁免费视频a| 2019av中文字幕| 国产精品电影在线观看| 91精品国产高清久久久久久91| 亚洲精品白浆高清久久久久久| www日韩欧美| 亚洲国模精品私拍| 欧美性xxxx极品高清hd直播| 中文字幕国产精品| 亚洲国产又黄又爽女人高潮的| 成人黄色免费在线观看| 国产有码一区二区| 亚洲电影免费观看高清| 国产经典一区二区| 国产精品视频最多的网站| 懂色av中文一区二区三区天美| 国产精品草莓在线免费观看| 国产午夜精品免费一区二区三区| 国产一区av在线| 日韩精品欧美国产精品忘忧草| 国产精品黄色av| 精品国内自产拍在线观看| 一区二区三区四区视频| 91性高湖久久久久久久久_久久99| 亚洲国产精品成人一区二区| 日韩女优在线播放| 欧美日韩中文字幕综合视频| 午夜精品一区二区三区在线播放| 亚洲影视中文字幕| 日韩av手机在线观看| 欧美大片在线免费观看| 亚洲女人天堂视频| 热久久99这里有精品| 91精品久久久久久久久中文字幕| 日韩视频永久免费观看| 国产成人欧美在线观看| 亚洲桃花岛网站| 亚洲理论电影网| 国产精品视频一区二区高潮| 成人日韩av在线| 国产精品视频最多的网站| 久久视频精品在线| 欧美午夜无遮挡| 亚洲第一视频在线观看| 日本久久久久亚洲中字幕| 欧美一级大片视频| 国产精品视频99| 欧美成人一区在线| 九九九热精品免费视频观看网站| 国产精品免费网站| 91精品视频网站| 精品呦交小u女在线| 亚洲成人中文字幕| 91av视频在线| 亚洲第一区中文字幕| 九色91av视频|