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

攜程酒店慢查詢治理之路

數據庫 MySQL
隨著攜程酒店業務的不斷擴張,再加上大量的SQLServer轉MySQL項目的推進,慢查詢的數量正在飛速增長,每日的報警量也居高不下,因此慢查詢的治理優化已經是刻不容緩,此文主要針對MySQL。

?作者簡介 | xuqi,攜程資深數據庫工程師,關注MySQL、分布式數據庫的優化、運維;

              潘達鳴,攜程資深數據庫工程師,關注數據庫性能優化、高可用性領域;

              康男,攜程數據庫專家,關注數據庫性能調優領域。

一、背景

慢查詢指的是數據庫中查詢時間超過了指定的閾值的SQL,這類SQL通常伴隨著執行時間長、服務器資源占用高、業務響應慢等負面影響。隨著攜程酒店業務的不斷擴張,再加上大量的SQLServer轉MySQL項目的推進,慢查詢的數量正在飛速增長,每日的報警量也居高不下,因此慢查詢的治理優化已經是刻不容緩,此文主要針對MySQL。

二、慢查詢治理實踐

2.1 SQL上線流程優化

圖片


之前的流程發布比較快捷,但是隨著質量差的SQL發布\遷移得越來越多,告警和回退數量也隨之變多,綜合下來,數據庫風險方面不容樂觀,該流程需要優化。

圖片

和舊流程相比,新增了一個SQLReview的環節,將潛在的慢查詢提前篩選出來優化,確保上線的SQL質量,在此流程保障下,所有上線到生產的SQL性能都能在DBA評估后的可控范圍內,在研發提交審核后,會收到審批的事件單。

圖片

攜程目前是存在自動化review審核的平臺,但是由于酒店業務場景比較復雜,研發對于SQL的理解水平層次不齊,平臺給出的建議并不能做到面面俱到,因此還沒有被廣泛使用于流程中,僅作為一個參考。

2.2 理解查詢語句

要優化慢查詢,首先要知道慢查詢是如何產生的,執行計劃是怎么樣的,最后考慮如何去優化查詢。

SQL流程及查詢優化器

一條sql的執行主要分成如圖幾個步驟:

  • SQL語法的緩存查詢(QC)
  • 語法解析(SQL的編寫、關鍵字的語法之類)
  • 生成執行計劃
  • 執行查詢
  • 輸出結果

圖片

通常慢查詢都發生在“執行查詢”這步,讀懂查詢計劃,可以有效地幫助我們分析SQL性能差的原因。

執行計劃

在SQL前面加上EXPLAIN,就可以查看執行計劃,計劃以“表”的形式展示:

圖片

具體字段含義可以參考MySQL官方的解釋,這里不多贅述。

圖片

2.3 優化慢查詢

通過執行計劃就可以定位到問題點,通常可以分為這幾種常見的原因。

圖片

(1) 索引層面

圖片

索引缺失

這個查詢由于缺少name字段索引,產生了全表掃描:


select * from hotel where name=’xc’;

圖片

補上索引之后,提示使用到了索引。

圖片

索引失效

圖片

如圖所示,索引失效的大致原因可以分為八類,這些場景通過查看執行計劃都會發現產生type=ALL或者type=index的全表掃描。

Like、or、非操作符、函數

explain select * from hotel where name like '%酒店%';
explain select * from hotel where name like '%酒店%'or Bookable='T';
explain select * from hotel where name <>'酒店';
explain select * from hotel where substring(name,1,2)='酒店';

圖片

參數類型不匹配

create table t1 (
col1 varchar(3) primary key
)engine=innodb default charset=utf8mb4;

圖片

t1表的col1為varchar類型,但是參數傳入的是數值類型,結果產生了隱形轉換,索引失效導致type=index的全表掃描。

聯合索引

Where條件不符合“最左匹配原則”,則索引會失效。

alter table hotel add index idx_hotelid_name_isdel(hotelid,name,status);

以下條件均可以命中聯合索引:

explain select * from hotel where hotelid=10000 and name='ctrip' and status='T';
explain select * from hotel where hotelid=10000 and name='ctrip';
explain select * from hotel where hotelid=10000;

圖片

但是以下條件無法使用到聯合索引:

explain select * from hotel where name='ctrip' and status='T';
explain select * from hotel where name='ctrip';
explain select * from hotel where status='T';

圖片

數據分布和數據量

索引字段的數據分布不均勻,表數據量過小的情況下,MYSQL查詢優化器可能認為返回的數據量本身就很多,通過索引掃描并不能減少多少開銷,此時選擇全表掃描的權重會提高很多。

查詢不帶where條件

不帶where條件直接查詢\修改全表是很危險的操作,表數據量夠大的話,盡量拆分成多批次操作。

圖片

優化中遇到的案例:

某天發現有一臺DB服務器IO異常,服務器鏈接開始堆積,引發了大量應用報錯

圖片

圖片

監控顯示此時repl延遲已經有25分鐘,集群幾乎處于無高可用狀態,非常的危險。

圖片

登陸服務器排查后發現有一條全表刪除的SQL在通過JOB系統跑,該表的數據量很大:

-tarpresqls "delete from XXXXXX"

最后緊急Kill這條SQL后恢復正常,直接在生產刪除全表是很危險的操作。

強制使用索引

MySQL中存在force index()、ignore index()方式來強制使用/忽略特定的索引。

這種方式可能會導致執行計劃選擇不到最優的索引,從而導致計劃走偏。

圖片

性能差索引的Index Merge

Index merge方法可以對同一個表使用多個索引分別進行條件掃描,檢索多個范圍掃描并將結果合并為一個。

圖片

但是,當遇到如圖2個索引字段分布都很差的情況時(status與bookable的區分度都很低),2個索引的結果集存在大量數據需要merge,性能就會變得很糟糕。

(2) SQL頻率

圖片

  • 業務代碼while、for循環的結束條件不正確,導致模塊內產生死循環
  • 業務邏輯本身存在高并發場景,例如秒殺、短期促銷活動、直播帶貨等
  • 通過定時JOB循環拉取全量數據,但是循環的并發節奏控制不到位
  • 緩存被擊穿、業務代碼發布后緩存失效等原因,導致大量請求直接打到了db

(3) 寫法不規范

圖片

分頁寫法

最常見的分頁寫法就是使用limit,在分頁查詢時,我們會在 LIMIT 后面傳兩個參數,一個是偏移量(offset),一個是獲取的條數(limit)。當偏移量很小時,查詢速度很快,但是隨著 offset 變大時,查詢速度會越來越慢。

MySQL Limit 語法格式:

SELECT * FROM table LIMIT [offset,] rows | rows OFFSET offset

例如下列分頁查詢:

圖片

當limit只有0,10時,執行還是很快,但是隨著offset增加,可以看到深度分頁的情況下,分頁越深,掃描的行數就越多,性能也就越來越差了。

explain select * from testlimittable order by id limit 1000, 10;
explain select * from testlimittable order by id limit 10000, 10;
explain select * from testlimittable order by id limit 20000, 10;
explain select * from testlimittable order by id limit 30000, 10;
explain select * from testlimittable order by id limit 40000, 10;
explain select * from testlimittable order by id limit 50000, 10;
explain select * from testlimittable order by id limit 60000, 10;

圖片

*:警惕通過分頁寫法來實現循環分批的邏輯,limit深分頁實現不了將大量數據拆分成若干小份的效果

分批可以采用分段拉取減少掃描的行數,如果分段拉取不連續的話可以傳入上一次拉取最大的值作為下一次的起始值:

圖片

最大最小值寫法

由于where條件的字段數據分布問題,會導致max和min的查詢非常慢:

explain select max(id) from hotel where hotelid=10000 and status='T';

圖片

由于hotelid=10000的數據分布比較多,可以看到掃描數很高:

1、添加聯合索引

alter table hotel add index idx_hotelid_status(hotelid,status);

圖片

在索引覆蓋下,extra提示Select tables optimized away,這意味著在查詢執行期間不需要讀取表,可以通過索引直接返回結果。

2、改寫為order by的方式

explain select id from hotel where hotelid=10000 and status='T' order by id desc limit 1;

圖片

掃描數很少,雖然是type=index的索引掃描,但是由于MYSQL對limit的優化,實際上并不會全表掃描。

排序聚合寫法

通常SQL在使用Group by及Order by后,會產生臨時表和文件排序操作。若查詢條件的數據量非常大,temporary和filesort都會產生額外的巨大開銷。

圖片

a.  使用索引來滿足排序聚合

alter table hotel add index idx_name_hotelid(name,hotelid);

圖片

此時MYSQL可以通過訪問索引來避免執行filesort 及temporary操作

b.  取消隱形排序?

在某些情況下,Group by會默認實現隱形排序,通過添加ORDER BY NULL可以取消這種隱形排序。

*注意從MySQL 8.0開始,不會再有這種情況了,因此不需要ORDER BY NULL寫法了

(4)資源

圖片

鎖資源等待

在讀寫很熱的表上,通常會發生鎖資源爭奪,從而導致慢查詢的情況。

  • 謹慎使用for update查詢
  • 增刪改盡量保證使用到索引
  • 降低并發,避免對同一條數據進行反復的修改

網絡波動

往客戶端發送數據時發生網絡波動導致的慢查詢

硬件配置

CPU利用率高,磁盤IO經常滿載,導致慢查詢

總結

慢查詢治理是一個長期且漫長的過程,不應等SQL超時報錯后才開始考慮優化,從一開始就要建立完善的日常化流程體系,才能有效的控制慢查詢的增長。

但是經過長期優化后發現,僅僅從數據庫層面優化,并不能實現慢查詢完全“清零”,還有很多的痛點來自于業務邏輯和應用層面本身。這也需要研發工程師著重優化業務邏輯、應用策略,并加強數據庫培訓,在編寫SQL時切勿過于隨意,貪圖省事,否則事后再優化會變得相當困難。

責任編輯:未麗燕 來源: 攜程技術
相關推薦

2023-01-13 14:35:00

攜程實踐

2022-07-08 09:38:27

攜程酒店Flutter技術跨平臺整合

2024-09-10 16:09:58

2015-05-28 14:05:02

2022-10-27 09:42:22

數據庫SQL

2023-03-14 14:01:00

內存優化

2017-07-06 19:57:11

AndroidMVP攜程酒店

2024-03-22 15:09:32

2022-04-14 17:53:50

攜程AWS上云

2024-04-18 09:41:53

2023-09-15 09:34:54

2022-08-06 08:27:41

Trace系統機票前臺微服務架構

2022-06-03 08:58:24

APP攜程流暢度

2018-07-20 09:42:23

Elasticsear實戰訂單

2022-06-10 08:43:20

攜程小程序Size治理Size檢查

2024-02-23 12:24:00

引擎數據

2023-03-03 09:42:27

日志數據

2025-08-05 09:28:08

2014-12-25 17:51:07

2024-09-25 15:37:46

點贊
收藏

51CTO技術棧公眾號

国产精品视频播放| 欧美精品久久一区二区三区| 精品一区二区国产| 天天综合久久综合| 中文字幕一区二区三区在线视频| 亚洲第一福利在线观看| 国产福利一区视频| a天堂中文在线官网在线| 成年人国产精品| 国产精品视频yy9099| 日本少妇吞精囗交| 久久国产影院| 国产丝袜一区二区三区免费视频| 午夜xxxxx| 婷婷六月国产精品久久不卡| 亚洲一区中文日韩| 亚洲一区二区三区乱码| 天天综合网天天综合| 欧美96一区二区免费视频| 久久男人的天堂| 成人一级黄色大片| 国内精品久久久久久99蜜桃| 亚洲成人黄色在线| 欧美日韩一区二区在线 | 日韩av电影天堂| 欧美激情久久久| 国产精品1区2区3区4区| 亚洲第一福利社区| 精品久久久久久久久久久久包黑料| 国产免费999| 日本不良网站在线观看| 一区二区成人在线观看| 中文字幕av日韩精品| 韩国精品视频| 99在线精品免费| 999精品视频一区二区三区| 一区二区久久精品66国产精品 | 日韩激情免费| 亚洲欧美另类在线观看| 制服丝袜第二页| 极品国产人妖chinesets亚洲人妖| 91精品中文字幕一区二区三区| 超碰影院在线观看| 欧美大片1688| 色婷婷av一区二区三区之一色屋| 黄色动漫网站入口| 黄色大片在线| 午夜精品福利一区二区蜜股av| 欧美日韩激情四射| 久久www人成免费看片中文| 一区二区欧美精品| 国产一区一区三区| 91福利国产在线观看菠萝蜜| 亚洲欧美激情在线| 欧美人与动牲交xxxxbbbb| 巨大荫蒂视频欧美大片| 综合网在线视频| a级网站在线观看| 亚洲wwwww| 亚洲成av人片一区二区三区| 亚洲一区二区三区av无码| 国产网红女主播精品视频| 亚洲成人资源网| 免费在线激情视频| 免费高清视频在线一区| 欧美日韩视频在线一区二区| 欧美激情国内自拍| 日本高清久久| 亚洲二区中文字幕| 成人免费毛片糖心| 欧美另类69xxxxx| 日韩中文字幕在线免费观看| 日本老熟俱乐部h0930| 亚洲小说欧美另类社区| 欧美亚洲在线播放| 正在播放木下凛凛xv99| 国产一区二区三区国产| 国产精品久久久久av福利动漫| 凸凹人妻人人澡人人添| 国产夜色精品一区二区av| 色噜噜狠狠一区二区三区| 快射av在线播放一区| 亚洲成人www| 日本在线观看免费视频| 亚洲免费一区三区| 精品视频久久久久久久| 国产一区第一页| 伊人精品视频| 国产精品久久久久久网站| 成人激情四射网| 国产网红主播福利一区二区| dy888午夜| 日韩电影免费观| 日韩视频永久免费| 亚洲av成人无码久久精品| 欧美ab在线视频| 91福利视频在线观看| 伊人免费在线观看| 不卡高清视频专区| 一区二区三区四区视频在线| 不卡专区在线| 7777精品伊人久久久大香线蕉经典版下载 | 极品美女扒开粉嫩小泬| 日韩黄色三级| 亚洲精品天天看| 欧美三根一起进三p| 日韩精品久久理论片| 国产精品手机在线| 黄色网址在线免费播放| 一本大道av一区二区在线播放| 亚洲制服在线观看| 红桃成人av在线播放| 欧美极品欧美精品欧美视频| 91精品人妻一区二区三区果冻| 9l国产精品久久久久麻豆| 亚洲精品偷拍视频| 草莓视频成人appios| 日韩国产欧美精品一区二区三区| 91视频青青草| 日本中文一区二区三区| 乱色588欧美| 91福利在线免费| 日韩三级视频在线看| 国产视频精品免费| 日本欧美加勒比视频| 欧美精品久久久| 麻豆mv在线观看| 亚洲成人亚洲激情| 欧美日韩在线国产| 精品一区二区精品| 亚洲看片网站| 国产精品亚洲d| 一区二区亚洲欧洲国产日韩| 国产精品免费精品一区| 91丨porny丨最新| 热99这里只有精品| 国产精品1luya在线播放| 欧美超级乱淫片喷水| 国产又粗又猛又黄| 国产精品毛片a∨一区二区三区| 久久人妻精品白浆国产 | 亚洲欧美在线一区| 日日夜夜综合网| 97久久精品人人做人人爽| 国产毛片视频网站| 日本久久成人网| 日本成人激情视频| 国产中文在线观看| 色国产综合视频| 天天操天天干天天操天天干| 日韩有码一区二区三区| 亚洲国产精品一区二区第一页| 日韩毛片在线| 色综久久综合桃花网| 亚洲天堂视频网| 亚洲色图欧美在线| 日本成人在线免费| 亚洲永久网站| 日韩亚洲一区在线播放| 免费视频观看成人| 久久av.com| 欧美综合视频在线| 疯狂蹂躏欧美一区二区精品| b站大片免费直播| 麻豆精品国产传媒mv男同| 五月天男人天堂| 第四色中文综合网| 8050国产精品久久久久久| 蜜桃视频在线免费| 欧美日韩国产高清一区二区三区 | 亚洲国产精品yw在线观看| 欧美三级午夜理伦| 国产欧美va欧美不卡在线| 女人高潮一级片| 欧美午夜免费影院| 久久资源av| 亚洲人成777| 91精品国产色综合| 日本中文字幕电影在线免费观看| 日韩一区二区不卡| 欧美超碰在线观看| 一区二区视频在线| wwwwww日本| 国产精品一区三区| 日本久久久精品视频| 香蕉综合视频| 免费成人av网站| 免费精品一区| 国产精品1234| 调教一区二区| 一区二区三区在线播放欧美| 蜜桃视频污在线观看| 91福利视频久久久久| 久久中文字幕在线观看| 日本一二三不卡| 尤物网站在线观看| 九色综合狠狠综合久久| 欧美国产亚洲一区| 欧美~级网站不卡| 日韩免费三级| 加勒比色老久久爱综合网| 国产精品一区久久| 亚洲福利影院| 久久久久久国产免费 | 久久久久久久久久av| 午夜激情视频在线观看| 日韩av在线播放资源| av片免费播放| 欧美久久久久久久久| 国产嫩bbwbbw高潮| 亚洲18色成人| 青青草手机在线观看| 欧美国产精品一区二区| 可以直接看的无码av| 粉嫩欧美一区二区三区高清影视| 欧美性受xxxxxx黑人xyx性爽| 香蕉国产精品偷在线观看不卡| 日韩激情视频一区二区| 欧美一区二区三区久久精品| 亚洲最大免费| 国内成人自拍| 日本一区二区三不卡| 全球av集中精品导航福利| 91麻豆精品秘密入口| 亚洲精品大片| 国产在线观看精品| 素人一区二区三区| 国产精品久久久久久久久借妻| 一个人看的www视频在线免费观看 一个人www视频在线免费观看 | 色菇凉天天综合网| 欧美在线观看不卡| 亚洲mv在线观看| 国产在线一二区| 亚洲国产精品久久久久婷婷884| 国产精品99一区| 欧美日韩国产精品综合| 亚洲人成网站色在线观看| 一级在线观看视频| 国产亚洲精品超碰| 成都免费高清电影| 久久久精品国产免大香伊| 中文字幕在线播放一区| 99精品一区二区| 国产福利在线观看视频| 91丨九色丨蝌蚪丨老版| 欧美狂猛xxxxx乱大交3| 久久精品水蜜桃av综合天堂| 波多野结衣 在线| 久久久久久一二三区| 免费在线观看污| 国产色一区二区| 九九热免费在线| 综合色中文字幕| 国产女人被狂躁到高潮小说| 亚洲狠狠爱一区二区三区| 国产一级做a爱免费视频| 亚洲动漫第一页| 国产精品50页| 粉嫩老牛aⅴ一区二区三区| www.日韩一区| 欧美日本国产一区| 国产视频一区二区三区四区五区| 日韩三级视频在线观看| 午夜小视频在线播放| 一区二区三区在线播放欧美| 久操视频在线播放| 欧美国产日韩一区二区在线观看 | 国产探花一区| 中国成人在线视频| 国内精品美女在线观看| 免费毛片小视频| 久久97超碰国产精品超碰| 在线观看视频你懂得| 91亚洲精华国产精华精华液| 婷婷色一区二区三区| 亚洲人成网站影音先锋播放| 国产成人无码精品| 欧美色综合久久| 朝桐光av在线一区二区三区| 日韩hd视频在线观看| 天天综合视频在线观看| 国模精品视频一区二区三区| 日韩av超清在线观看| 91丨九色丨国产| 一区二区三区日本久久久| 亚洲一区二区三区在线观看视频 | 久久久久久久久网站| 亚洲伦理影院| 国产精品入口免费| 欧美色图国产精品| 日韩精品一区二区免费| 免费成人美女在线观看| 国产成人av免费观看| 国产日产亚洲精品系列| 久久精品一区二区三| 欧美三级日本三级少妇99| 黄色一级大片在线免费看国产| 一本大道久久加勒比香蕉| 黄色大片在线| 成人午夜一级二级三级| 亚洲成在人线免费观看| 天天想你在线观看完整版电影免费 | 久久综合电影一区| 中文字幕在线免费观看视频| 亚洲在线www| 日韩一区三区| 欧美女人性生活视频| 成人免费观看视频| 91杏吧porn蝌蚪| 精品视频全国免费看| 日韩大胆视频| 国内精品久久久久影院 日本资源| 青青久久精品| 日本在线观看一区| 亚洲专区一区| 三级男人添奶爽爽爽视频 | 福利网址在线观看| 精品国产99国产精品| а√天堂在线官网| 国产日本欧美在线观看| 欧美啪啪小视频| 亚洲精品菠萝久久久久久久| 波多野结衣啪啪| 日韩成人激情视频| 国产极品在线观看| 97超碰在线播放| 一区二区三区四区电影| 亚洲精品性视频| 中文字幕乱码一区二区免费| 免费黄色av片| 亚洲视频电影图片偷拍一区| 在线看片福利| 国产精品我不卡| 国产综合亚洲精品一区二| 四虎国产精品免费| 亚洲精品午夜久久久| 国产色综合视频| 久久综合久中文字幕青草| 91精品国产色综合久久不卡粉嫩| 亚洲欧洲精品一区二区| 青青草视频一区| 国产调教在线观看| 欧美三区免费完整视频在线观看| 亚洲免费视频一区二区三区| 成人免费淫片aa视频免费| 希岛爱理av一区二区三区| 婷婷中文字幕在线观看| 亚洲日本成人在线观看| 国产精品久久久久久久久久久久久久久久久久 | 亚洲视频一区在线观看| 97精品久久人人爽人人爽| 色七七影院综合| 日韩精品一级| av日韩在线看| 成人免费不卡视频| 欧美一区二区激情视频| 亚洲欧美变态国产另类| 欧美日韩国产网站| 综合视频在线观看| 国产精品一卡二卡| 国产精品suv一区二区| 日韩成人久久久| 国产激情欧美| 9191国产视频| 99国产精品一区| 青青国产在线视频| 亚洲日本中文字幕区| 精品无码国产一区二区三区av| 国产一区二区三区在线观看免费 | 麻豆高清免费国产一区| 日韩福利小视频| 亚洲第一区中文字幕| 日本免费一区二区三区四区| 99精品视频网站| 成人动漫av在线| 香蕉污视频在线观看| 久久视频国产精品免费视频在线 | 日韩极品精品视频免费观看| 97久久香蕉国产线看观看| 三年中文高清在线观看第6集| 懂色中文一区二区在线播放| 久久久免费高清视频| 色吧影院999| 国产精品网在线观看| 亚洲一区在线不卡| 亚洲一卡二卡三卡四卡五卡| 日本一二三区在线视频| 91香蕉嫩草影院入口| 亚洲日本久久| 成年人网站在线观看视频| 亚洲国产精品va在线看黑人动漫| 男女啪啪999亚洲精品| 日韩黄色片在线| 亚洲国产精品av| 色噜噜一区二区三区| 91精品久久久久久久久| 国产日韩一区| 欧美日韩在线视频免费| 中文在线资源观看视频网站免费不卡| 韩国女主播一区二区三区|