精品欧美一区二区三区在线观看 _久久久久国色av免费观看性色_国产精品久久在线观看_亚洲第一综合网站_91精品又粗又猛又爽_小泽玛利亚一区二区免费_91亚洲精品国偷拍自产在线观看 _久久精品视频在线播放_美女精品久久久_欧美日韩国产成人在线

TiDB SQL調優案例之避免TiFlash幫倒忙

數據庫 其他數據庫
TiFlash雖然是個好東西,但是優化器還在進化當中,難免有判斷失誤的時候,那么會導致適得其反的效果,我們要及時通過人工手段介入。再給TiDB優化器一些時間。

背景

早上收到某系統的告警tidb節點掛掉無法訪問,情況十萬火急。登錄中控機查了一下display信息,4個TiDB、Prometheus、Grafana全掛了,某臺機器hang死無法連接,經過快速重啟后集群恢復,經排查后是昨天上線的某個SQL導致頻繁OOM。

于是開始亡羊補牢,來一波近期慢SQL巡檢 #手動狗頭#。。。

隨便找了一個出現頻率比較高的慢SQL,經過優化后竟然性能提升了1500倍以上,感覺有點東西,分享給大家。

分析過程

該慢SQL邏輯非常簡單,就是一個單表聚合查詢,但是耗時達到8s以上,必有蹊蹺。

脫敏后的SQL如下:

SELECT
cast( cast( CAST( SUM( num ) / COUNT( time ) AS CHAR ) AS DECIMAL ( 9, 2 )) AS signed ) speed,
... -- 此處省略n個字段
FROM
(
SELECT
DATE_FORMAT( receive_time, '%Y-%m-%d %H:%i:00' ) AS time,
COUNT(*) AS num
FROM
db1.table
WHERE
create_time > DATE_SUB( sysdate(), INTERVAL 20 MINUTE )
GROUP BY
time
ORDER BY
time
) speed;

碰到慢SQL不用多想,第一步先上執行計劃:

很明顯,這張900多萬行的表因為創建了TiFlash副本,在碰到聚合運算的時候優化器選擇了走列存查詢,最終結果就是在TiFlash完成暴力全表掃描、排序、分組、計算等一系列操作,返回給TiDB Server時基本已經加工完成,總共耗時8.02s。

咋一看好像沒啥優化空間,但仔細觀察會發現一個不合理的地方。執行計劃倒數第二排的Selection算子,也就是SQL里面子查詢的where過濾,實際有效數據1855行,卻掃描了整個表接近950W行,這是一個典型的適合索引加速的場景。但遺憾的是,在TiFlash里面并沒有索引的概念,所以只能默默地走全表掃描。

那么優化的第一步,先看過濾字段是否有索引,通常來說create_time這種十有八九都建過索引,檢查后發現確實有。

第二步,嘗試讓優化器走TiKV查詢,這里直接使用hint的方式:

SELECT /*+ READ_FROM_STORAGE(TIKV[db1.table]) */
cast( cast( CAST( SUM( num ) / COUNT( time ) AS CHAR ) AS DECIMAL ( 9, 2 )) AS signed ) speed,
... -- 此處省略n個字段
FROM
(
SELECT
DATE_FORMAT( receive_time, '%Y-%m-%d %H:%i:00' ) AS time,
COUNT(*) AS num
FROM
db1.table
WHERE
create_time > DATE_SUB( sysdate(), INTERVAL 20 MINUTE )
GROUP BY
time
ORDER BY
time
) speed;

再次生成執行計劃,發現還是走了TiFlash查詢。這里就引申出一個重要知識點,關于hint作用域的問題,也就是說hint只能在指定的查詢范圍內生效。具體到上面這個例子,雖然指定了db1.table走TiKV查詢,但是對于它所在的查詢塊來說,壓根不知道db1.table是誰直接就忽略掉了。所以正確的寫法是把hint寫到子查詢中:

SELECT
cast( cast( CAST( SUM( num ) / COUNT( time ) AS CHAR ) AS DECIMAL ( 9, 2 )) AS signed ) speed,
... -- 此處省略n個字段
FROM
(
SELECT /*+ READ_FROM_STORAGE(TIKV[db1.table]) */
DATE_FORMAT( receive_time, '%Y-%m-%d %H:%i:00' ) AS time,
COUNT(*) AS num
FROM
db1.table
WHERE
create_time > DATE_SUB( sysdate(), INTERVAL 20 MINUTE )
GROUP BY
time
ORDER BY
time
) speed;

對應的執行計劃為:

小提示:也可以通過set session tidb_isolation_read_engines = 'tidb,tikv';來讓優化器走tikv查詢。

發現這次雖然走了TiKV查詢,但還是用的TableFullScan算子,整體時間不降反升,和我們預期的有差距。

沒走索引那肯定是和查詢字段有關系,分析上面SQL的邏輯,開發是想查詢table表創建時間在最近20分鐘的數據,用了一個sysdate()函數獲取當前時間,問題就出在這。

獲取當前時間常用的函數有now()和sysdate(),但這兩者是有明顯區別的。引用自官網的解釋:

  • now()得到的是語句開始執行的時間,是一個固定值
  • sysdate()得到的是該函數實際執行的時間,是一個動態值

聽起來比較饒,來個栗子一看便知:

mysql> select now(),sysdate(),sleep(3),now(),sysdate();
+---------------------+---------------------+----------+---------------------+---------------------+
| now() | sysdate() | sleep(3) | now() | sysdate() |
+---------------------+---------------------+----------+---------------------+---------------------+
| 2023-03-16 15:55:18 | 2023-03-16 15:55:18 | 0 | 2023-03-16 15:55:18 | 2023-03-16 15:55:21 |
+---------------------+---------------------+----------+---------------------+---------------------+
1 row in set (3.06 sec)

這個動態時間就意味著TiDB優化器在估算的時候并不知道它是個什么值,走索引和不走索引哪個成本更高,最終導致索引失效。

從業務上來看,這個SQL用now()和sysdate()都可以,那么就嘗試改成now()看看效果:

SELECT
cast( cast( CAST( SUM( num ) / COUNT( time ) AS CHAR ) AS DECIMAL ( 9, 2 )) AS signed ) speed,
... -- 此處省略n個字段
FROM
(
SELECT /*+ READ_FROM_STORAGE(TIKV[db1.table]) */
DATE_FORMAT( receive_time, '%Y-%m-%d %H:%i:00' ) AS time,
COUNT(*) AS num
FROM
db1.table
WHERE
create_time > DATE_SUB( now(), INTERVAL 20 MINUTE )
GROUP BY
time
ORDER BY
time
) speed;

最終結果4.43ms搞定,從8.02s到4.43ms,1800倍的提升。

濫用函數,屬于是開發給自己挖的坑了。

解決方案

經過以上分析,優化思路已經很清晰了,甚至都是常規優化不值得專門拿出來講,但前后效果差異太大,很適合作為一個反面教材來提醒大家認真寫SQL。

其實就兩點:

  • 讓優化器不要走TiFlash查詢,改走TiKV,可通過hint或SQL binding解決
  • 非必須不要使用動態時間,避免帶來索引失效的問題

深度思考

優化完成之后,我開始思考優化器走錯執行計劃的原因。

在最開始的執行計劃當中,優化器對Selection算子的估算值estRows和實際值actRows相差非常大,再加上本身計算和聚合比較多,這可能是導致誤走TiFlash的原因之一。不清楚TiFlash的estRows計算原理是什么,如果在估算準確的情況并且索引正常的情況下會不會走TiKV呢?

另外,我還懷疑過動態時間導致優化器判斷失誤(認為索引失效才選擇走TiFlash),但是在嘗試只修改sysdate()為now()的情況下,發現依然走了TiFlash,說明這個可能性不大。

在索引字段沒問題的時候,按正常邏輯來說,我覺得一個成熟的優化器應該要能夠判斷出這種場景走TiKV更好。

總結

TiFlash雖然是個好東西,但是優化器還在進化當中,難免有判斷失誤的時候,那么會導致適得其反的效果,我們要及時通過人工手段介入。再給TiDB優化器一些時間。

良好的SQL習慣至關重要,這也是老生常談的問題了,再好的數據庫也扛不住亂造的SQL。?

責任編輯:武曉燕 來源: 今日頭條
相關推薦

2017-07-21 08:55:13

TomcatJVM容器

2011-01-21 08:38:20

2023-11-10 09:29:30

MySQLExplain

2011-09-02 14:05:25

SQL Server性能調優

2009-01-08 19:14:37

服務器應用程序SQL Server

2021-11-07 23:49:19

SQL數據庫工具

2009-11-17 13:45:12

Oracle SQL調

2011-03-21 09:35:38

LAMP調優網絡文件

2012-01-10 14:35:08

JavaJVM

2019-09-25 15:09:30

MySQL索引SQL

2009-01-08 19:06:13

服務器應用程序SQL Server

2009-01-08 19:11:39

服務器應用程序SQL Server

2020-06-10 10:40:03

JavaJMH字符串

2021-03-17 11:35:11

JVM代碼Java

2010-07-19 09:39:53

SQL Server

2010-07-19 13:35:51

SQL Server性

2010-04-12 17:30:44

Oracle SQL調

2021-07-15 08:00:47

系統性能調優cpunuma架構

2023-11-28 08:43:48

2021-03-04 08:39:21

SparkRDD調優
點贊
收藏

51CTO技術棧公眾號

成人久久视频在线观看| 国产精品地址| 欧美一区二区成人6969| 欧美午夜小视频| 日韩三级电影网| 久久国产福利国产秒拍| 国内精品免费午夜毛片| 在线观看亚洲大片短视频| 成人在线视频国产| 欧美性69xxxx肥| 国产av熟女一区二区三区| 黄色在线小视频| 成人性生交大片免费| 国产91免费观看| 免费毛片在线播放免费| 激情婷婷综合| 亚洲第一级黄色片| 黄色aaaaaa| av在线日韩| 亚洲国产美女搞黄色| 一本一本久久a久久精品综合妖精| 二区三区在线视频| 老司机精品视频导航| 91精品国产色综合| 成人免费视频网站入口::| 国产精品一区二区三区av麻| 亚洲国产成人精品女人久久久| av中文字幕网址| 日韩久久一区二区三区| 午夜精品久久久久久久久久| 日本一道在线观看| 久热国产在线| 国产精品久久久久久久久搜平片| 久久国产精品-国产精品| 亚洲乱码在线观看| 国产成人精品一区二区三区四区| 国产精品日韩欧美综合| 欧美特黄aaaaaa| 国产亚洲精品自拍| 97视频在线观看成人| 国产高潮国产高潮久久久91| 天天操夜夜操国产精品| 少妇高潮久久77777| 手机av免费看| 羞羞色国产精品网站| 亚洲国产精品成人va在线观看| 国产成人精品一区二区三区在线观看| 九九热这里有精品| 欧美日韩国产高清一区二区三区| 日日摸天天爽天天爽视频| 韩日成人影院| 在线观看免费视频综合| 我要看一级黄色大片| 福利精品一区| 884aa四虎影成人精品一区| 日本超碰在线观看| 久久丁香四色| 精品国产91久久久久久久妲己| 制服.丝袜.亚洲.中文.综合懂| 欧美2区3区4区| 日韩欧美国产系列| 毛茸茸free性熟hd| 亚洲精品动态| 色婷婷综合成人| 国精品无码一区二区三区| 欧美破处大片在线视频| 久久久久久久999| 99久热在线精品996热是什么| 狠狠色综合网| 欧美有码在线视频| 中文字幕第99页| 国产一区二区三区在线观看免费视频| 91视频免费在线观看| 丰满肉嫩西川结衣av| 2023国产精品视频| 亚洲资源在线网| 日本不卡影院| 欧美性精品220| 99re精彩视频| 中文字幕一区二区三区中文字幕 | 91国产视频在线| 五月婷婷激情视频| 国产在线精品不卡| 精品欧美日韩| 日本中文字幕在线视频| 亚洲精品欧美激情| 久久美女福利视频| www.久久久久爱免| 日韩精品在线免费观看视频| 精品伦精品一区二区三区视频密桃| 欧美1区2区3区| 日韩**中文字幕毛片| 99久久久国产精品无码免费 | 亚洲熟女少妇一区二区| 激情另类综合| 国产欧美亚洲精品| 午夜av免费在线观看| 国产精品久久久久一区 | 性xxxxfreexxxxx欧美丶| 国产欧美日韩一级| 国产欧美va欧美va香蕉在线| 国产黄a三级三级看三级| 久久亚洲影视婷婷| 男人日女人的bb| 成人在线免费电影网站| 日韩极品精品视频免费观看| 污污的视频在线免费观看| 国产午夜久久| 国产66精品久久久久999小说| av在线收看| 狠狠色香婷婷久久亚洲精品| 手机在线观看日韩av| 成人av动漫在线观看| 97视频网站入口| 亚洲毛片欧洲毛片国产一品色| 国产精品伦理在线| 免费日韩视频在线观看| 红杏aⅴ成人免费视频| 久久精品国产精品| 丰满熟女人妻一区二区三| 不卡区在线中文字幕| 国风产精品一区二区| 欧美一级做a| 亚洲最新视频在线| 日本a级c片免费看三区| 成人一区在线看| 男人的天堂成人| 欧美午夜三级| 亚洲乱码国产乱码精品精天堂| 国产无遮挡又黄又爽又色| 国产乱码精品一区二区三| 中文网丁香综合网| 成人综合网站| 色伦专区97中文字幕| 日本视频www色| 国产三级一区二区| 免费激情视频在线观看| 精品一区免费| 国产成+人+综合+亚洲欧美丁香花| 欧美一区二区三区激情| 亚洲国产视频一区二区| 丰满少妇xbxb毛片日本| 国产精品jizz在线观看美国| 99在线首页视频| www.久久综合| 亚洲丝袜另类动漫二区| 看看黄色一级片| 99免费精品| 91牛牛免费视频| av网站在线看| 精品免费视频.| 久久久久99精品| 丁香六月综合激情| 乱妇乱女熟妇熟女网站| 伊人久久大香线蕉av不卡| 日本一欧美一欧美一亚洲视频| 蜜桃视频在线播放| 欧美综合欧美视频| 国精产品一区一区| 韩国三级中文字幕hd久久精品| 国产成人免费高清视频| 99ri日韩精品视频| 欧美有码在线观看| 天堂地址在线www| 日韩一级黄色片| 日本少妇吞精囗交| 日韩电影在线观看一区| 99国精产品一二二线| 黑人另类精品××××性爽| 日韩精品在线观看网站| 乱子伦一区二区三区| 亚洲欧美在线视频观看| 波多野结衣办公室双飞 | 婷婷六月天在线| 亚洲91视频| 久久精品日韩精品| 国产精品高潮久久| 欧美日韩成人在线播放| 午夜视频在线播放| 欧美日韩国产综合一区二区三区| 欧美黄色aaa| 久久久久久影视| 亚洲激情在线看| 中文欧美日韩| 中文字幕在线观看一区二区三区| 大香伊人久久精品一区二区| 国产精品jvid在线观看蜜臀| 3d玉蒲团在线观看| 亚洲精品一区在线观看香蕉| 91亚洲精品国偷拍自产在线观看| 亚洲一区二区视频在线观看| 自拍偷拍视频亚洲| 国产成人精品亚洲午夜麻豆| av免费在线播放网站| 欧美黄在线观看| 日韩精品伦理第一区| 亚洲日本va午夜在线电影| 秋霞成人午夜鲁丝一区二区三区| 久久综合网导航| 一本色道久久综合狠狠躁篇怎么玩| 性欧美一区二区三区| 欧美色视频一区| 日韩乱码一区二区| 亚洲欧美日韩国产一区二区三区| 亚洲最大成人网站| 粉嫩蜜臀av国产精品网站| 午夜两性免费视频| 久久精品人人做人人爽电影蜜月| 激情视频小说图片| 日韩夫妻性生活xx| 乱一区二区三区在线播放| 亚洲精品国产九九九| 国产日韩欧美另类| 影视一区二区三区| 欧美一级大片在线免费观看| 国产天堂在线播放视频| 久久精品视频在线| 91大神在线网站| 国产香蕉97碰碰久久人人| 五月婷婷综合久久| 精品va天堂亚洲国产| 99久久久国产精品无码网爆| 91精品福利视频| 久久精品国产亚洲AV无码男同| 亚洲欧美日韩系列| 尤物在线免费视频| 国产精品美女视频| 日韩一级片在线免费观看| 久久久久久免费网| 日本一区二区三区网站| 99久久免费视频.com| 欧美熟妇精品一区二区蜜桃视频 | xxxx日本免费| 久久这里都是精品| 国产精品久久不卡| 91论坛在线播放| 动漫精品一区二区三区| 91在线免费视频观看| 国产熟女高潮一区二区三区 | а√天堂资源官网在线资源| 欧美国产日韩免费| gogo高清在线播放免费| 午夜精品久久久99热福利| av中文字幕电影在线看| 97在线免费观看视频| 免费成人在线电影| 欧美专区国产专区| 日韩电影免费观| 国产精品视频白浆免费视频| 2020国产精品小视频| 国产日韩在线播放| 激情视频亚洲| av一本久道久久波多野结衣| 好吊妞国产欧美日韩免费观看网站| 国产精品一区二区三区精品| 欧美性生活一级片| 欧美日韩无遮挡| 日韩国产一区二区三区| jizz国产在线| 日本免费新一区视频| 国产a级片免费观看| 免费亚洲一区| 久久久久久三级| 麻豆成人久久精品二区三区小说| 欧美成年人视频在线观看| 精品亚洲成a人在线观看| 女人扒开双腿让男人捅 | 日本视频久久久| 欧美日韩在线精品一区二区三区激情综合 | 老湿机69福利| 亚洲3atv精品一区二区三区| 欧美黑人一区二区| 欧美日韩三级一区二区| 国产色片在线观看| 成人激情视频网站| 日韩av不卡在线| 欧美性理论片在线观看片免费| 国产精品电影久久久久电影网| 亚洲ww精品| 狠狠色综合一区二区| 超碰成人久久| 日本a级片在线播放| 亚洲女人av| 人妻换人妻仑乱| 91小视频免费观看| 国产老头老太做爰视频| 天天影视色香欲综合网老头| 制服丝袜在线一区| 欧美一二三四在线| 国产区视频在线| 欧美黄色片视频| 亚洲高清黄色| 91久久精品国产91久久性色tv| 亚洲电影一级片| 久久观看最新视频| 亚洲一区二区三区高清| 伊人五月天婷婷| 久久久久久久久久久久久女国产乱 | 久久久精品影院| 欧美成人h版| 国产伦精品一区| 99热在线成人| 97视频在线免费播放| 国产成人在线影院| 青青青视频在线播放| 婷婷综合五月天| 国产免费黄色录像| 伊人久久久久久久久久| 老牛影视精品| 成人午夜电影免费在线观看| 久久理论电影| av无码精品一区二区三区| 成人黄色综合网站| 午夜精品一区二区三级视频| 色综合久久综合网97色综合| 亚洲精品无amm毛片| yw.139尤物在线精品视频| 亚洲美女炮图| 国产在线精品一区二区三区》| 在线中文字幕第一区| 中文字幕22页| 国产精品女人毛片| 欧美日韩在线视频播放| 日韩精品在线视频| 久草免费在线视频| 国产精品一区而去| 国产精品vip| 日本黄色一级网站| 亚洲女与黑人做爰| 一级片视频免费| 亚洲精品永久免费精品| 黄色在线网站噜噜噜| 国产66精品久久久久999小说| 欧美一区二区三区久久精品茉莉花| 欧美女同在线观看| 中文字幕亚洲电影| 亚洲一区二区三区高清视频| 色偷偷偷亚洲综合网另类| 九九九伊在线综合永久| 日本一区视频在线播放| 视频在线观看一区二区三区| a级大片在线观看| 日韩欧美亚洲综合| 久久久久久青草| 国产精品99蜜臀久久不卡二区| 中文字幕av一区二区三区人| 大肉大捧一进一出好爽视频| 久久天堂av综合合色蜜桃网 | 欧美日韩大陆在线| 欧美人xxx| 亚洲最大成人在线| 国产一区日韩欧美| 538国产视频| 色诱亚洲精品久久久久久| 成人动漫在线免费观看| 国产精品精品视频一区二区三区| 日本一本不卡| 日韩av福利在线观看| 亚洲成a人在线观看| 三级在线播放| 国产精品美女网站| 欧美 日韩 国产 一区| jjzz黄色片| 色综合色狠狠综合色| av资源种子在线观看| 成人免费在线网址| 亚洲视频免费| 国产免费看av| 欧美日韩国产三级| 国内在线视频| 欧洲精品亚洲精品| 精品在线免费观看| 九九精品在线观看视频| 亚洲精品第一国产综合精品| 久久久成人av毛片免费观看| 波多野结衣三级在线| www.日本不卡| 一级久久久久久久| 午夜免费久久久久| 欧美亚洲国产激情| 少妇丰满尤物大尺度写真| 欧美日韩一区二区精品| 麻豆传媒视频在线| 国产精品一区二区三区在线| 久热re这里精品视频在线6| 黑人狂躁日本娇小| 日韩精品高清视频| 日韩一区二区三免费高清在线观看| 青草网在线观看| 国产免费观看久久| 日本精品999| 国产精品视频xxx| 国产精品色网| 精品国产视频在线观看| 日韩高清人体午夜| 成人精品在线| 亚洲高清在线免费观看| 亚洲一区二区三区影院| 91大神xh98hx在线播放| 久久久精品有限公司|