一、存儲引擎
mysql中有多種存儲引擎,一般常見的有三種:
| MyIsam | InnoDB | Memory | |
| 用途 | 快讀 | 完整的事務支持 | 內存數據 |
| 鎖 | 全表鎖定 | 多種隔離級別的行鎖 | 全表鎖定 |
| 持久性 | 基於表恢復 | 基於日志的恢復 | 無磁盤I/O,無可持久性 |
| 事務特性 | 不支持 | 支持 | 不支持 |
| 支持索引類型 | B-tree/FullText/R-tree | Hash/B-tree | Hash/B-tree |
通常的觀點是MyISAM 注重性能,InnoDB注重事務,所以一邊使用MyISAM類的表做非事務型的業務。
這種觀點是由於早期InnoDB引擎還不成熟,而事實上並不是這樣的。mysql在高並發下的性能瓶頸很明顯,主要原因就是鎖定機制導致的堵塞。而InnoDB在鎖定機制上采用了行級鎖,不同於MyISAM的表級鎖,行級鎖在鎖定上帶來的消耗大於表級鎖,但是在系統並發訪問較高時,InnoDB整體的性能高於MyISAM。同時InnoDB的索引不僅緩存索引本身,也緩存數據,說以InnoDB需要更大的內存,在現在來說內存很廉價。而且在MYSQL8.0 中 MyISAM已經不存在了。
二、mysql服務器調整優化
關閉不必要的二進制日志和慢查詢日志,僅在內存足夠或開發調試時打開。使用下來語句查看是否打開:
show variables like '%slow%';
使用下列語句查看慢查詢條數:
show global status like '%slow%';
慢查詢會消耗過度消耗CPU,可以間歇性打開慢查詢日志來定位新能瓶頸。
適度使用query cache
增加mysql允許的最大連接數。查看mysql最大連接數:
show variables like 'max_connections';
對於InnoDB存儲引擎,需要安裝服務器內存來設置innodb_buffer_pool_size一般是操作系統內存的70%-80%最佳。
定期的執行optimize table tableName 進行碎片整理 ,或者在大量刪除后進行。
對數據庫進行分區,分表操作。
使用Nosql輔助,如:Memcached,redis。
mysql最大連接數修改方法:
方法一:進入MYSQL安裝目錄 打開MYSQL配置文件 my.ini 或 my.cnf查找 max_connections=100 修改為 max_connections=(數字) 服務里重起MYSQL即可
方法二:set GLOBAL max_connections=200
mysql修改innodb_buffer_pool_size
進入MYSQL安裝目錄 打開MYSQL配置文件 my.ini 或 my.cnf 查找 innodb_buffer_pool_size 這一項設置 修改為 例如: innodb_buffer_pool_size = 6G
增加mysql配置中的buffer和cache的數值
產考文章:
http://www.jb51.net/article/48082.htm
http://blog.csdn.net/cenfei78325747/article/details/7861454
