国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 數據庫 > MySQL > 正文

MySQL數據庫優化技術之配置技巧總結

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

本文實例講述了MySQL數據庫優化技術的配置方法。分享給大家供大家參考,具體如下:

(一)減少數據庫訪問

對于可以靜態化的頁面,盡可能靜態化

對一個動態頁面中可以靜態的局部,采用靜態化

部分數據可以生成XML,或者文本文件形式保存

使用數據緩存技術,例如: MemCached

(二)優化的檢測方法

1.用戶體驗檢測

2.Mysql狀態檢測

在Mysql命令行里面使用show status命令,得到當前mysql狀態。

主要關注下列屬性:

key_read_requests (索引讀的請求數)(key_buffer_size設置影響)

key_reads(索引讀響應數)

Key_blocks_used

Qcache_*

Open_tables(通過table_cache的設置影響)

Opened_tables

table_locks

3. 第三方工具檢測

mysqlreport http://hackmysql.com/mysqlreport

mytop http://jeremy.zawodny.com/mysql/mytop/

系統及Mysql的Log

系統命令: top, sar

Mysql的Log: slow_query.log

(三)硬件方面的優化

硬件方面,最容易成為Mysql瓶頸的部分是磁盤,其次是CPU和內存

磁盤方面

使用更快的磁盤,會對Mysql有很好的幫助

使用更多的硬盤,通過Raid,可以提高單塊磁盤速度的問題

對于Raid方式,建議采用Raid 0+1 或者 Raid 1+0

CPU

毫無疑問,更高主頻的CPU和更多的CPU數量可以給Mysql更

高的性能

內存

更高的內存,往往可以讓Mysql中的更多的數據緩存在內存中,

但是,一個重要的因素是,需要有正確的Mysql的配置

網卡

使用千兆網卡及千兆網絡

(四)操作系統方面的優化

1.不使用交換區。如果內存不足,增加更多的內存或配置你的系統使用較少內存

2. 不要使用NFS磁盤

3.增加系統和MySQL服務器的打開文件數量

使用ulimit –n 65535

4.增加系統的進程和線程數量。

5.關閉不必要的應用,優化硬盤參數,使用hdparm測試

(五)應用級的優化

1.使用多服務器負載均衡(多臺讀和寫,用復制技術進行數據同步)

2.表的分區 (自定義分區,mysql5.1開始支持自帶分區功能)

3.使用數據緩存技術memcached

(六)Mysql配置的優化

1.key_buffer(=512):索引緩沖使用的內存數量

這對MyISAM表來說非常重要,設定在可用內存的25%-30%較好,通過檢查狀態值 Key_read_requests和 Key_reads,

可以知道key_buffer設置是否合理。比例key_reads / key_read_requests應該盡可能的低,至少是1:100,1:1000更好 ,否則說明 key_buffer 設置有點偏小

2.innodb_buffer_pool_size(= 512):索引緩沖使用的內存數量

3.table_cache (=1024):數據表緩存區的尺寸

每當 MySQL 訪問一個表時,如果在表緩沖區中還有空間,該表就被打開并放入其中,這樣可以更快地訪問表內容。

通過檢查運行峰值時間的 Open_tables 和 Opened_tables 狀態值,可以決定是否需要調整 table_cache 的值。

如果你發現 open_tables 的值等于 table_cache,并且發現 opened_tables 狀態值在不斷增長,那么你就需要增加 table_cache 參數值了,

也不能盲目地把 table_cache 參數設置成很大的值,如果設置得太高,可能會造成文件描述符不足,從而造成性能不穩定或者連接失敗。

4.sort_buffer_size (=256):指定排序用緩沖區的長度

該參數對應的分配內存是每連接獨占!如果有100個連接,那么實際分配的總共排序緩沖區大小為100 × 6 = 600MB。

所以,對于內存在4GB左右的服務器推薦設置為6-8M

5.join_buffer_size :關聯查詢用緩沖區的長度

4G內存以上,建議大于32M,該參數對應的分配內存也是每連接獨享!

6.max_connections (=1024):可以復用的線程數量

允許同時連接MySQL服務器的客戶數量 ,可以觀察和估計系統在峰值最大的并發連接數來設置

7.thread_cache(=*):可以復用的線程數量

一般設置為CPU數×2

8.innodb_buffer_pool_size(= 512):innodb表緩存池大小

這對Innodb表來說非常重要。Innodb相比MyISAM表對緩沖更為敏感。MyISAM可以在默認的 key_buffer_size 設置下運行的可以,

然而Innodb在默認的innodb_buffer_pool_size 設置下卻跟蝸牛似的。

由于Innodb把數據和索引都緩存起來,無需留給操作系統太多的內存,因此如果只需要用Innodb的話則可以設置它高達 70-80% 的可用內存。

一些應用于 key_buffer 的規則有 -- 如果你的數據量不大,并且不會暴增,那么無需把innodb_buffer_pool_size 設置的太大了.

9.innodb_flush_logs_at_trx_commit(=1) :事務提交后的日志刷新模式

是否為Innodb比MyISAM慢1000倍而頭大?看來也許你忘了修改這個參數了。默認值是 1,這意味著每次提交的更新事務(或者每個事務之外的語句)都會刷新到磁盤中,

而這相當耗費資源,尤其是沒有電池備用緩存時。很多應用程序,尤其是從 MyISAM轉變過來的那些,把它的值設置為 2 就可以了,也就是不把日志刷新到磁盤上,

而只刷新到操作系統的緩存上。日志仍然會每秒刷新到磁盤中去,因此通常不會丟失每秒1-2次更新的消耗。如果設置為0就快很多了,不過也相對不安全了,

MySQL服務器崩潰時就會丟失一些事務。設置為2指揮丟失刷新到操作系統緩存的那部分事務.

希望本文所述對大家MySQL數據庫計有所幫助。


注:相關教程知識閱讀請移步到MYSQL教程頻道。
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 龙州县| 漳浦县| 荔波县| 乌鲁木齐县| 分宜县| 土默特左旗| 芷江| 平凉市| 灌南县| 龙山县| 盐亭县| 威信县| 仪陇县| 万源市| 磐石市| 关岭| 新干县| 东兴市| 文水县| 仁寿县| 固安县| 桐乡市| 阳江市| 张家港市| 卫辉市| 鲁山县| 东台市| 饶河县| 东港市| 桐城市| 南宫市| 且末县| 盐亭县| 霸州市| 阳谷县| 津南区| 常熟市| 德庆县| 河池市| 抚州市| 嫩江县|