我們這是對mysql進(jìn)入優(yōu)化時做的一點,就是啟用mysql查詢語句緩存了,這樣可以避免需要進(jìn)行大量的數(shù)據(jù)庫操作時數(shù)據(jù)庫常常會成為產(chǎn)生瓶頸的問題。
開啟查詢語句緩存也是優(yōu)化MySQL的一個策略.
MySQL 是我們開發(fā)程序常用的數(shù)據(jù)庫,它具有在內(nèi)存中緩存常用查詢語句的能力,這樣一個給定的查詢語句再次被調(diào)用時,MySQL將立即從緩存中將其返回,然而,在大多數(shù)MySQL中,這一特性默認(rèn)是被禁用的,為了啟用它,向你的MySQL配置選項文件添加以下代碼,該配置文件的名稱為my.cnf,它用來聲明變量和你的MySQL服務(wù)器的行為.
啟用MySQL的查詢語句緩存,在這里,我們將查詢語句緩存設(shè)為64MB,代碼如下:
[mysqld]
query_cache_size=64M
當(dāng)前查詢語句緩存的大小,可以通過MySQL的SHOW VARIABLES命令來查看,代碼如下:
query_cache_size |555-55554
query_cache_type | ON
我們需要不斷地試驗查詢語句緩存大小的設(shè)置,緩存太小就意味著緩存了的查詢語句很快就會過期,緩存太大就意味著搜索一個緩存可能需要花費(fèi)相對較長時間,還有就是使用內(nèi)存進(jìn)行緩存比使用其它一些方式要好,就像有更多的web服務(wù)器處理,memcache或者操作系統(tǒng)的文件緩存一樣.
查詢緩存介紹,查詢緩存的工作原理,基本上可以概括為:
緩存SELECT操作或預(yù)處理查詢,注釋,5.1.17開始支持,的結(jié)果集和SQL語句;
新的SELECT語句或預(yù)處理查詢語句,先去查詢緩存,判斷是否存在可用的記錄集,判斷標(biāo)準(zhǔn),與緩存的SQL語句,是否完全一樣,區(qū)分大小寫.
查詢緩存對什么樣的查詢語句,無法緩存其記錄集,大致有以下幾類:
查詢語句中加了SQL_NO_CACHE參數(shù);
查詢語句中含有獲得值的函數(shù),包涵自定義函數(shù),如:CURDATE()、GET_LOCK()、RAND()、CONVERT_TZ等;
對系統(tǒng)數(shù)據(jù)庫的查詢:mysql、information_schema
查詢語句中使用SESSION級別變量或存儲過程中的局部變量;
查詢語句中使用了LOCK IN SHARE MODE、FOR UPDATE的語句
查詢語句中類似SELECT …INTO 導(dǎo)出數(shù)據(jù)的語句;
事務(wù)隔離級別為:Serializable情況下,所有查詢語句都不能緩存;
對臨時表的查詢操作;//Vevb.com
存在警告信息的查詢語句;
不涉及任何表或視圖的查詢語句;
某用戶只有列級別權(quán)限的查詢語句;
查詢緩存的優(yōu)缺點:不需要對SQL語句做任何解析和執(zhí)行,當(dāng)然語法解析必須通過在先,直接從Query Cache中獲得查詢結(jié)果;
查詢緩存的判斷規(guī)則,不夠智能,也即提高了查詢緩存的使用門檻,降低其效率,Query Cache的起用,會增加檢查和清理Query Cache中記錄集的開銷,而且存在SQL語句緩存的表,每一張表都只有一個對應(yīng)的全局鎖.
新聞熱點
疑難解答
圖片精選