mysql read_buffer_size 設(shè)置多少合適
MySQL手冊里關(guān)于read_rnd_buffer_size的解釋如下:
“這個參數(shù)用在sort查詢之后 ,以保證獲取以順序的方式獲取到查詢的數(shù)據(jù)。如果你有很多order by 查詢語句,增長這值能夠提升性能?!?/p>
這個解釋足夠簡練,但沒有準(zhǔn)確的告訴我們這個參數(shù)工作在哪一層,SQL層還是引擎層?
老實(shí)說,這個參數(shù)和read_buffer_size很像,read_buffer_size僅僅用于MyISAM引擎,我下意識的也認(rèn)為read_rnd_buffer_size也僅僅用于MyISAM引擎。我今天早和Monty聊了聊,學(xué)到,它不是這樣的。read_rnd_buffer_size不僅僅用在MyISAM引擎,而是用在所有引擎。它用在查詢后,對讀取真正的數(shù)據(jù)進(jìn)行優(yōu)化。它是這樣工作的:
sort后,得到的是行數(shù)據(jù)指針,通過key-value的形式存在,對于MyISAM是數(shù)據(jù)的偏移量,對于innodb是主鍵或存儲重新查詢的全量數(shù)據(jù)(對于小片的數(shù)據(jù)是有益的)。
假設(shè)sort后的數(shù)據(jù)使用的是行指針,并且行中的字段能夠被轉(zhuǎn)換成固定的大?。ǔ薆LOB/TEXT字段外),MySQL能夠使用read_rnd_buffer_size優(yōu)化數(shù)據(jù)讀取。
因為sort后的數(shù)據(jù)是以key-value的形式存在的,使用這些行指針去讀取數(shù)據(jù),將是以指針數(shù)據(jù)物理的順序去讀取,很大程度上是隨機(jī)的方式讀取數(shù)據(jù)的。MySQL從sort_buffer中讀取這些行指針數(shù)據(jù),然后通過指針排序后存入read_rnd_buffer中,之后再通過指針讀取數(shù)據(jù)時,基本上都是順序讀取了。
read_rnd_buffer_size是很重要的參數(shù),尤其工作在如下場景:
* sort_buffer中存的是行指針而不是要查詢的數(shù)據(jù)。
* 查詢的字段中包含Blob/Text字段。
* sort后有大量的數(shù)據(jù)行(limit 10并不能幫助你,因為MySQL是通過指針獲取行數(shù)據(jù)的)
如果你取出很少字段的數(shù)據(jù)(小于max_length_for_sort_data),行數(shù)據(jù)將會全部存儲在sort buffer里,因此將不需要read_rnd_buffer_size這個參數(shù)。而如果你查詢的字段數(shù)據(jù)很長(這些字段很可能含有Text/Blob字段),比max_length_for_sort_data還長,read_rnd_buffer_size這個參數(shù)將派上用場。
下面是其他網(wǎng)友的補(bǔ)充
key_buffer_size + (read_buffer_size + sort_buffer_size)*max_connections = 458624 K
read_buffer_size:是MySQL讀入緩沖區(qū)大小。對表進(jìn)行順序掃描的請求將分配一個讀入緩沖區(qū),MySQL會為它分配一段內(nèi)存緩沖區(qū)。read_buffer_size變量控制這一緩沖區(qū)的大小。如果對表的順序掃描請求非常頻繁,并且你認(rèn)為頻繁掃描進(jìn)行得太慢,可以通過增加該變量值以及內(nèi)存緩沖區(qū)大小提高其性能。
如下是對于16g內(nèi)存的設(shè)置
read_buffer_size = 1M
個人機(jī)器是32G的,一般數(shù)據(jù)庫就用來存儲數(shù)據(jù),很少用mysql 所以我就設(shè)置為2M或3M
手機(jī)在線更新系統(tǒng)MySQL數(shù)據(jù)庫服務(wù)器參數(shù)優(yōu)化mycnf,16G內(nèi)存8核CPU
業(yè)務(wù)場景:后臺支持手機(jī)在線更新系統(tǒng),db服務(wù)器內(nèi)存16G,8核,dell的pc服務(wù)器。
qps: 200個左右
tps: 1個左右 一分鐘50幾個
sort_buffer_size = 32M 大了, 8M即可
read_buffer_size = 32M 大了,8M即可
read_rnd_buffer_size = 16M 大了,8M即可
table_open_cache = 512
小了,建議改成2048
max_allowed_packet = 5M
小了,建議改成16M
tmp_table_size=64M
小了,建議改成2G
innodb_buffer_pool_size = 3000M
小了,改成db服務(wù)器總內(nèi)存的60% 到80%
innodb_additional_mem_pool_size = 20M 小了,改成128M
join_buffer_size 這個參數(shù)為什么沒有看到,必須設(shè)置值,join_buffer_size = 8M 必須補(bǔ)上,這個是跟join table 關(guān)聯(lián)的,很重要。
- MySQL Innodb關(guān)鍵特性之插入緩沖(insert buffer)
- 詳解MySQL中的緩沖池(buffer pool)
- MySQL的查詢緩存和Buffer Pool
- mysql優(yōu)化的重要參數(shù) key_buffer_size table_cache
- 優(yōu)化mysql之key_buffer_size設(shè)置
- mysql Sort aborted: Out of sort memory, consider increasing server sort buffer size的解決方法
- 從MySQL的源碼剖析Innodb buffer的命中率計算
- php中mysql操作buffer用法詳解
- Mysql優(yōu)化調(diào)優(yōu)中兩個重要參數(shù)table_cache和key_buffer
- mysql Key_buffer_size參數(shù)的優(yōu)化設(shè)置
- mysqldump造成Buffer Pool污染的研究
- MySQL的join buffer原理
相關(guān)文章
MySQL數(shù)據(jù)庫給表添加索引的實(shí)現(xiàn)
在MySQL中,索引是用來加速數(shù)據(jù)庫查詢的一種特殊數(shù)據(jù)結(jié)構(gòu),當(dāng)我們需要查詢數(shù)據(jù)庫中某些數(shù)據(jù)的時候,如果數(shù)據(jù)庫中有索引,就可以避免全表掃描,從而提高查詢速度,本文就介紹了如何給表添加索引,感興趣的可以了解一下2023-08-08
MySQL通過DQL實(shí)現(xiàn)對數(shù)據(jù)庫數(shù)據(jù)的條件查詢
這篇文章給大家介紹了MySQL如何通過DQL進(jìn)行數(shù)據(jù)庫數(shù)據(jù)的條件查詢,文中通過代碼示例和圖文結(jié)合介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作有一定的幫助,需要的朋友可以參考下2024-01-01
如何使用mysql語句進(jìn)行多表聯(lián)查(以三個表為例)
這篇文章主要介紹了如何使用mysql語句進(jìn)行多表聯(lián)查(以三個表為例),具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教2023-08-08
如何修改MYSQL5.7.17數(shù)據(jù)庫存儲文件的路徑
在搭建華為云服務(wù)器的時候遇到點(diǎn)問題,查看了網(wǎng)上好多的帖子都沒能解決,不知道有沒有跟我遇到一樣問題的老鐵,我就把我的解決辦法分享給大家,希望能夠幫助各位老鐵2023-05-05
64位CentOs7源碼安裝mysql-5.6.35過程分享
本文給大家分享的是在64位CentOs7系統(tǒng)中使用源碼安裝mysql-5.6.35的詳細(xì)過程,非常的細(xì)致,有需要的小伙伴可以參考下2017-02-02
mysql搭建主從復(fù)制的實(shí)現(xiàn)步驟
在MySQL集群中,主庫更新會同步到從庫,但從庫更新不同步到主庫,主從復(fù)制能分?jǐn)倝毫?本文就來介紹一下mysql搭建主從復(fù)制的實(shí)現(xiàn)步驟,感興趣的可以了解一下2024-11-11

