Amoeba for MySQL

2014年2月4日 | 標籤:
 

來源:http://docs.hexnova.com/amoeba/php

Amoeba for MySQL致力於MySQL的分佈式數據庫前端代理層,它主要在應用層訪問MySQL的時候充當query 路由功能,專一 分佈式數據庫 proxy 開發。座落與Client、DB Server(s)之間。對客戶端透明。具備負載均衡、高可用性、Query過濾、讀寫分離、可路由相關的query到目標數據庫、可併發請求多臺數據庫合併結果。 在Amoeba上面你可以完成多數據源的高可用、負載均衡、數據切片的功能。目前在不少企業的生產線上面使用。html

那麼Amoeba for mysql 對客戶端程序來講是什麼呢? 咱們就當它是mysql吧,它是一個虛擬的mysql,對外提供mysql協議。客戶端鏈接amoeba就象鏈接mysql同樣。在amoeba內部須要配置相關的認證屬性。具體請參閱後面的章節。前端

Amoeba for Mysql 與MySQL Proxy比較

在MySQL proxy 6.0版本 上面若是想要讀寫分離而且 讀集羣、寫集羣 機器比較多狀況下,用mysql proxy 須要至關大的工做量,目前mysql proxy沒有現成的 lua腳本。mysql proxy根本沒有配置文件, lua腳本就是它的所有,固然lua是至關方便的。那麼一樣這種東西須要編寫大量的腳本才能完成一 個複雜的配置。而Amoeba for Mysql只須要進行相關的配置就能夠知足需求。mysql

Amoeba不能作什麼?

  • 目前還不支持事務
  • 暫時不支持存儲過程(近期會支持)
  • 不適合從amoeba導數據的場景或者對大數據量查詢的query並不合適(好比一次請求返回10w以上甚至更多數據的場合)
  • 暫時不支持分庫分表,amoeba目前只作到分數據庫實例,每一個被切分的節點須要保持庫表結構一致

 

 
2014年1月7日 | 標籤:
 

一、MySQL的複製原理以及流程ios

(1)、先問基本原理流程,3個線程以及之間的關聯;面試

(2)、再問一致性延時性,數據恢復;sql

(3)、再問各類工做遇到的複製bug的解決方法。數據庫

 

二、MySQL中myisam與innodb的區別,至少5點緩存

(1)、問5點不一樣;安全

(2)、問各類不一樣mysql版本的2者的改進;

(3)、2者的索引的實現方式。

 

三、問MySQL中varchar與char的區別以及varchar(50)中的30表明的涵義

(1)、varchar與char的區別;

(2)、varchar(50)中50的涵義;

(3)、int(20)中20的涵義;

(4)、爲何MySQL這樣設計。

[備註] 本人也面試了近12個2年MySQL DBA經驗的朋友,沒有一個能回答出第(2)、(3)題

 

四、問了innodb的事務與日誌的實現方式

(1)、有多少種日誌;

(2)、日誌的存放形式;

(3)、事務是如何經過日誌來實現的,說得越深刻越好。

 

五、問了MySQL binlog的幾種日誌錄入格式以及區別

(1)、各類日誌格式的涵義;

(2)、適用場景;

(3)、結合第一個問題,每一種日誌格式在複製中的優劣。

 

六、問了下MySQL數據庫cpu飆升到500%的話他怎麼處理?

(1)、沒有經驗的,能夠不問;

(2)、有經驗的,問他們的處理思路。

 

七、sql優化

(1)、explain出來的各類item的意義;

(2)、profile的意義以及使用場景;

(3)、explain中的索引問題。

 

八、備份計劃,mysqldump以及xtranbackup的實現原理

(1)、備份計劃;

(2)、備份恢復時間;

(3)、備份恢復失敗如何處理。

 

九、500臺db,在最快時間以內重啓

 

十、在當前的工做中,你碰到到的最大的MySQL DB問題是?

 

十一、innodb的讀寫參數優化

(1)、讀取參數,global buffer pool以及 local buffer;

(2)、寫入參數;

(3)、與IO相關的參數;

(4)、緩存參數以及緩存的適用場景。

 

十二、請簡潔地描述下MySQL中InnoDB支持的四種事務隔離級別名稱,以及逐級之間的區別?

 

1三、表中有大字段X(例如:text類型),且字段X不會常常更新,以讀爲爲主,請問

(1)、您是選擇拆成子表,仍是繼續放一塊兒;

(2)、寫出您這樣選擇的理由。

 

1四、MySQL中InnoDB引擎的行鎖是經過加在什麼上完成(或稱實現)的?爲何是這樣子的?

 

 
2014年1月5日 | 標籤:
 

網上有很多mysql 性能優化方案,不過,mysql的優化同sql server相比,更爲麻煩與複雜,一樣的設置,在不一樣的環境下 ,因爲內存,訪問量,讀寫頻率,數據差別等等狀況,可能會出現不一樣的結果,所以簡單地根據某個給出方案來配置mysql是行不通的,最好能使用status信息對mysql進行具體的優化,網上找了一篇文章,分頁分得亂七八糟的,只能轉到博客。

mysql> show global status;

能夠列出MySQL服務器運行各類狀態值,另外,查詢MySQL服務器配置信息語句:

mysql> show variables;

1、慢查詢

mysql> show variables like ‘%slow%‘;
+------------------+-------+
| Variable_name     | Value |
+------------------+-------+
| log_slow_queries | ON     |
| slow_launch_time | 2      |
+------------------+-------+

mysql> show global status like ‘%slow%‘;
+———————+——-+
| Variable_name        | Value |
+———————+——-+
| Slow_launch_threads | 0      |
| Slow_queries         | 4148 |
+———————+——-+

配置中打開了記錄慢查詢,執行時間超過2秒的即爲慢查詢,系統顯示有4148個慢查詢,你能夠分析慢查詢日誌,找出有問題的SQL語句,慢查詢時間不宜設置過長,不然意義不大,最好在5秒之內,若是你須要微秒級別的慢查詢,能夠考慮給MySQL打補丁:http://www.percona.com/docs/wiki/release:start,記得找對應的版本。

打開慢查詢日誌可能會對系統性能有一點點影響,若是你的MySQL是主-從結構,能夠考慮打開其中一臺從服務器的慢查詢日誌,這樣既能夠監控慢查詢,對系統性能影響又小。

2、鏈接數

常常會碰見」MySQL: ERROR 1040: Too many connections」的狀況,一種是訪問量確實很高,MySQL服務器抗不住,這個時候就要考慮增長從服務器分散讀壓力,另一種狀況是MySQL配置文件中max_connections值太小:

mysql> show variables like ‘max_connections‘;
+—————–+——-+
| Variable_name    | Value |
+—————–+——-+
| max_connections | 256   |
+—————–+——-+

這臺MySQL服務器最大鏈接數是256,而後查詢一下服務器響應的最大鏈接數:

mysql> show global status like ‘Max_used_connections‘;

MySQL服務器過去的最大鏈接數是245,沒有達到服務器鏈接數上限256,應該沒有出現1040錯誤,比較理想的設置是

Max_used_connections / max_connections * 100% ≈ 85%

最大鏈接數占上限鏈接數的85%左右,若是發現比例在10%如下,MySQL服務器鏈接數上限設置的太高了。

3、Key_buffer_size

key_buffer_size是對MyISAM表性能影響最大的一個參數,下面一臺以MyISAM爲主要存儲引擎服務器的配置:

mysql> show variables like ‘key_buffer_size‘;+—————–+————+
| Variable_name    | Value       |
+—————–+————+
| key_buffer_size | 536870912 |
+—————–+————+

分配了512MB內存給key_buffer_size,咱們再看一下key_buffer_size的使用狀況:

mysql> show global status like ‘key_read%‘;
+————————+————-+
| Variable_name           | Value        |
+————————+————-+
| Key_read_requests       | 27813678764 |
| Key_reads               | 6798830      |
+————————+————-+

一共有27813678764個索引讀取請求,有6798830個請求在內存中沒有找到直接從硬盤讀取索引,計算索引未命中緩存的機率:

key_cache_miss_rate = Key_reads / Key_read_requests * 100%

好比上面的數據,key_cache_miss_rate爲0.0244%,4000個索引讀取請求才有一個直接讀硬盤,已經很BT了,key_cache_miss_rate在0.1%如下都很好(每1000個請求有一個直接讀硬盤),若是key_cache_miss_rate在0.01%如下的話,key_buffer_size分配的過多,能夠適當減小。

MySQL服務器還提供了key_blocks_*參數:

mysql> show global status like ‘key_blocks_u%‘;
+————————+————-+
| Variable_name           | Value        |
+————————+————-+
| Key_blocks_unused       | 0            |
| Key_blocks_used         | 413543       |
+————————+————-+

Key_blocks_unused表示未使用的緩存簇(blocks)數,Key_blocks_used表示曾經用到的最大的blocks數,好比這臺服務器,全部的緩存都用到了,要麼增長key_buffer_size,要麼就是過渡索引了,把緩存佔滿了。比較理想的設置:

Key_blocks_used / (Key_blocks_unused + Key_blocks_used) * 100% ≈ 80%

4、臨時表

mysql> show global status like ‘created_tmp%‘;
+————————-+———+
| Variable_name            | Value    |
+————————-+———+
| Created_tmp_disk_tables | 21197    |
| Created_tmp_files        | 58       |
| Created_tmp_tables       | 1771587 |
+————————-+———+

每次建立臨時表,Created_tmp_tables增長,若是是在磁盤上建立臨時表,Created_tmp_disk_tables也增長,Created_tmp_files表示MySQL服務建立的臨時文件文件數,比較理想的配置是:

Created_tmp_disk_tables / Created_tmp_tables * 100% <= 25%好比上面的服務器Created_tmp_disk_tables / Created_tmp_tables * 100% = 1.20%,應該至關好了。咱們再看一下MySQL服務器對臨時表的配置:

mysql> show variables where Variable_name in (‘tmp_table_size‘, ‘max_heap_table_size‘);
+———————+———–+
| Variable_name        | Value      |
+———————+———–+
| max_heap_table_size | 268435456 |
| tmp_table_size       | 536870912 |
+———————+———–+

只有256MB如下的臨時表才能所有放內存,超過的就會用到硬盤臨時表。

5、Open Table狀況

mysql> show global status like ‘open%tables%‘;
+—————+——-+
| Variable_name | Value |
+—————+——-+
| Open_tables    | 919    |
| Opened_tables | 1951  |
+—————+——-+

Open_tables表示打開表的數量,Opened_tables表示打開過的表數量,若是Opened_tables數量過大,說明配置中table_cache(5.1.3以後這個值叫作table_open_cache)值可能過小,咱們查詢一下服務器table_cache值:

mysql> show variables like ‘table_cache‘;
+—————+——-+
| Variable_name | Value |
+—————+——-+
| table_cache    | 2048  |
+—————+——-+

比較合適的值爲:

Open_tables / Opened_tables * 100% >= 85%

Open_tables / table_cache * 100% <= 95%

6、進程使用狀況

mysql> show global status like ‘Thread%‘;
+——————-+——-+
| Variable_name      | Value |
+——————-+——-+
| Threads_cached     | 46     |
| Threads_connected | 2      |
| Threads_created    | 570    |
| Threads_running    | 1      |
+——————-+——-+

若是咱們在MySQL服務器配置文件中設置了thread_cache_size,當客戶端斷開以後,服務器處理此客戶的線程將會緩存起來以響應下一個客戶而不是銷燬(前提是緩存數未達上限)。Threads_created表示建立過的線程數,若是發現Threads_created值過大的話,代表MySQL服務器一直在建立線程,這也是比較耗資源,能夠適當增長配置文件中thread_cache_size值,查詢服務器thread_cache_size配置:

mysql> show variables like ‘thread_cache_size‘;
+——————-+——-+
| Variable_name      | Value |
+——————-+——-+
| thread_cache_size | 64     |
+——————-+——-+

示例中的服務器仍是挺健康的。

7、查詢緩存(query cache)

mysql> show global status like ‘qcache%‘;
+————————-+———–+
| Variable_name            | Value      |
+————————-+———–+
| Qcache_free_blocks       | 22756      |
| Qcache_free_memory       | 76764704  |
| Qcache_hits              | 213028692 |
| Qcache_inserts           | 208894227 |
| Qcache_lowmem_prunes     | 4010916    |
| Qcache_not_cached        | 13385031  |
| Qcache_queries_in_cache | 43560      |
| Qcache_total_blocks      | 111212     |
+————————-+———–+

MySQL查詢緩存變量解釋:

Qcache_free_blocks:緩存中相鄰內存塊的個數。數目大說明可能有碎片。FLUSH QUERY CACHE會對緩存中的碎片進行整理,從而獲得一個空閒塊。

Qcache_free_memory:緩存中的空閒內存。

Qcache_hits:每次查詢在緩存中命中時就增大

Qcache_inserts:每次插入一個查詢時就增大。命中次數除以插入次數就是不中比率。

Qcache_lowmem_prunes:緩存出現內存不足而且必需要進行清理以便爲更多查詢提供空間的次數。這個數字最好長時間來看;若是這個數字在不斷增加,就表示可能碎片很是嚴重,或者內存不多。(上面的 free_blocks和free_memory能夠告訴您屬於哪一種狀況)

Qcache_not_cached:不適合進行緩存的查詢的數量,一般是因爲這些查詢不是 SELECT 語句或者用了now()之類的函數。

Qcache_queries_in_cache:當前緩存的查詢(和響應)的數量。

Qcache_total_blocks:緩存中塊的數量。

咱們再查詢一下服務器關於query_cache的配置:

mysql> show variables like ‘query_cache%‘;
+——————————+———–+
| Variable_name                 | Value      |
+——————————+———–+
| query_cache_limit             | 2097152    |
| query_cache_min_res_unit      | 4096       |
| query_cache_size              | 203423744 |
| query_cache_type              | ON         |
| query_cache_wlock_invalidate | OFF        |
+——————————+———–+

各字段的解釋:

query_cache_limit:超過此大小的查詢將不緩存

query_cache_min_res_unit:緩存塊的最小大小

query_cache_size:查詢緩存大小

query_cache_type:緩存類型,決定緩存什麼樣的查詢,示例中表示不緩存 select sql_no_cache 查詢

query_cache_wlock_invalidate:當有其餘客戶端正在對MyISAM表進行寫操做時,若是查詢在query cache中,是否返回cache結果仍是等寫操做完成再讀表獲取結果。

query_cache_min_res_unit的配置是一柄」雙刃劍」,默認是4KB,設置值大對大數據查詢有好處,但若是你的查詢都是小數據查詢,就容易形成內存碎片和浪費。

查詢緩存碎片率 = Qcache_free_blocks / Qcache_total_blocks * 100%

若是查詢緩存碎片率超過20%,能夠用FLUSH QUERY CACHE整理緩存碎片,或者試試減少query_cache_min_res_unit,若是你的查詢都是小數據量的話。

查詢緩存利用率 = (query_cache_size – Qcache_free_memory) / query_cache_size * 100%

查詢緩存利用率在25%如下的話說明query_cache_size設置的過大,可適當減少;查詢緩存利用率在80%以上並且Qcache_lowmem_prunes > 50的話說明query_cache_size可能有點小,要不就是碎片太多。

查詢緩存命中率 = (Qcache_hits – Qcache_inserts) / Qcache_hits * 100%

示例服務器 查詢緩存碎片率 = 20.46%,查詢緩存利用率 = 62.26%,查詢緩存命中率 = 1.94%,命中率不好,可能寫操做比較頻繁吧,並且可能有些碎片。

8、排序使用狀況

mysql> show global status like ‘sort%‘;
+——————-+————+
| Variable_name      | Value       |
+——————-+————+
| Sort_merge_passes | 29          |
| Sort_range         | 37432840    |
| Sort_rows          | 9178691532 |
| Sort_scan          | 1860569     |
+——————-+————+

Sort_merge_passes 包括兩步。MySQL 首先會嘗試在內存中作排序,使用的內存大小由系統變量 Sort_buffer_size 決定,若是它的大小不夠把全部的記錄都讀到內存中,MySQL 就會把每次在內存中排序的結果存到臨時文件中,等 MySQL 找到全部記錄以後,再把臨時文件中的記錄作一次排序。這再次排序就會增長 Sort_merge_passes。實際上,MySQL 會用另外一個臨時文件來存再次排序的結果,因此一般會看到 Sort_merge_passes 增長的數值是建臨時文件數的兩倍。由於用到了臨時文件,因此速度可能會比較慢,增長 Sort_buffer_size 會減小 Sort_merge_passes 和 建立臨時文件的次數。但盲目的增長 Sort_buffer_size 並不必定能提升速度,見 How fast can you sort data with MySQL?(引自http://qroom.blogspot.com/2007/09/mysql-select-sort.html,貌似被牆)

另外,增長read_rnd_buffer_size(3.2.3是record_rnd_buffer_size)的值對排序的操做也有一點的好處,參見:http://www.mysqlperformanceblog.com/2007/07/24/what-exactly-is-read_rnd_buffer_size/

9、文件打開數(open_files)

mysql> show global status like ‘open_files‘;
+—————+——-+
| Variable_name | Value |
+—————+——-+
| Open_files     | 1410  |
+—————+——-+

mysql> show variables like ‘open_files_limit‘;
+——————+——-+
| Variable_name     | Value |
+——————+——-+
| open_files_limit | 4590  |
+——————+——-+

比較合適的設置:Open_files / open_files_limit * 100% <= 75%

10、表鎖狀況

mysql> show global status like ‘table_locks%‘;
+———————–+———–+
| Variable_name          | Value      |
+———————–+———–+
| Table_locks_immediate | 490206328 |
| Table_locks_waited     | 2084912    |
+———————–+———–+

Table_locks_immediate表示當即釋放表鎖數,Table_locks_waited表示須要等待的表鎖數,若是Table_locks_immediate / Table_locks_waited > 5000,最好採用InnoDB引擎,由於InnoDB是行鎖而MyISAM是表鎖,對於高併發寫入的應用InnoDB效果會好些。示例中的服務器Table_locks_immediate / Table_locks_waited = 235,MyISAM就足夠了。

11、表掃描狀況

mysql> show global status like ‘handler_read%‘;
+———————–+————-+
| Variable_name          | Value        |
+———————–+————-+
| Handler_read_first     | 5803750      |
| Handler_read_key       | 6049319850  |
| Handler_read_next      | 94440908210 |
| Handler_read_prev      | 34822001724 |
| Handler_read_rnd       | 405482605    |
| Handler_read_rnd_next | 18912877839 |
+———————–+————-+

各字段解釋參見http://hi.baidu.com/thinkinginlamp/blog/item/31690cd7c4bc5cdaa144df9c.html,調出服務器完成的查詢請求次數:

mysql> show global status like ‘com_select‘;
+—————+———–+
| Variable_name | Value      |
+—————+———–+
| Com_select     | 222693559 |
+—————+———–+

計算表掃描率:

表掃描率 = Handler_read_rnd_next / Com_select

若是表掃描率超過4000,說明進行了太多表掃描,頗有可能索引沒有建好,增長read_buffer_size值會有一些好處,但最好不要超過8MB。

後記:

文中提到一些數字都是參考值,瞭解基本原理就能夠,除了MySQL提供的各類status值外,操做系統的一些性能指標也很重要,好比經常使用的top,iostat等,尤爲是iostat,如今的系統瓶頸通常都在磁盤IO上,關於iostat的使用,能夠參考:http://www.php-oa.com/2009/02/03/iostat.html

 
2014年1月2日 | 標籤:
 

[mysqld]
port = 3306
serverid = 1
socket = /tmp/mysql.sock
skip-name-resolve
#禁止MySQL對外部鏈接進行DNS解析,使用這一選項能夠消除MySQL進行DNS解析的時間。但須要注意,若是開啓該選項,則全部遠程主機鏈接受權都要使用IP地址方式,不然MySQL將沒法正常處理鏈接請求!注:若是用winform鏈接mysql,加入此句速度會有很大的提高

skip-locking
# 避免MySQL的外部鎖定,減小出錯概率加強穩定性。

back_log = 384
指定MySQL可能的鏈接數量。當MySQL主線程在很短的時間內接收到很是多的鏈接請求,該參數生效,主線程花費很短的時間檢查鏈接而且啓動一個新線程。 back_log參數的值指出在MySQL暫時中止響應新請求以前的短期內多少個請求能夠被存在堆棧中。 若是系統在一個短期內有不少鏈接,則須要增大該參數的值,該參數值指定到來的TCP/IP鏈接的偵聽隊列的大小。不一樣的操做系統在這個隊列大小上有它本身的限制。 試圖設定back_log高於你的操做系統的限制將是無效的。默認值爲50。對於Linux系統推薦設置爲小於512的整數。

key_buffer_size = 32M
# key_buffer_size這對MyISAM表來講很是重要。若是隻是使用MyISAM表,能夠把它設置爲可用內存的 30-40%。合理的值取決於索引大小、數據量以及負載 — 記住,MyISAM表會使用操做系統的緩存來緩存數據,所以須要留出部份內存給它們,不少狀況下數據比索引大多了。儘管如此,須要老是檢查是否全部的 key_buffer 都被利用了 — .MYI 文件只有 1GB,而 key_buffer 卻設置爲 4GB 的狀況是很是少的。這麼作太浪費了。若是你不多使用MyISAM表,那麼也保留低於 16-32MB 的key_buffer_size 以適應給予磁盤的臨時表索引所需。

innodb_buffer_pool_size = 2.4G
#這對Innodb表來講很是重要。Innodb相比MyISAM表對緩衝更爲敏感。MyISAM能夠在默認的 key_buffer_size 設置下運行的能夠,然而Innodb在默認的innodb_buffer_pool_size 設置下卻跟蝸牛似的。因爲Innodb把數據和索引都緩存起來,無需留給操做系統太多的內存,所以若是隻須要用Innodb的話則能夠設置它高達 70-80% 的可用內存。– 若是你的數據量不大,而且不會暴增,那麼無需把innodb_buffer_pool_size 設置的太大了。

innodb_additional_pool_size = 20M
#這個選項對性能影響並不太多,至少在有差很少足夠內存可分配的操做系統上是這樣。不過若是你仍然想設置爲 20MB(或者更大),所以就須要看一下Innodb其餘須要分配的內存有多少。

innodb_log_file_size = 512M
#在高寫入負載尤爲是大數據集的狀況下很重要。這個值越大則性能相對越高,可是要注意到可能會增長恢復時間。我常常設置爲64-512MB,根據服務器大小而異。

innodb_log_buffer_size =16M
#默認的設置在中等強度寫入負載以及較短事務的狀況下,服務器性能還能夠。若是存在更新操做峯值或者負載較大,就應該考慮加大它的值了。若是它的值設置過高了,可能會浪費內存 — 它每秒都會刷新一次,所以無需設置超過1秒所需的內存空間。一般8-16MB就足夠了。越小的系統它的值越小。

innodb_flush_logs_at_trx_commit = 2
#是否爲Innodb比MyISAM慢1000倍而頭大?看來也許你忘了修改這個參數了。默認值是 1,這意味着每次提交的更新事務(或者每一個事務以外的語句)都會刷新到磁盤中,而這至關耗費資源,尤爲是沒有電池備用緩存時。不少應用程序,尤爲是從 MyISAM轉變過來的那些,把它的值設置爲 2 就能夠了,也就是不把日誌刷新到磁盤上,而只刷新到操做系統的緩存上。日誌仍然會每秒刷新到磁盤中去,所以一般不會丟失每秒1-2次更新的消耗。若是設置爲0就快不少了,不過也相對不安全了 — MySQL服務器崩潰時就會丟失一些事務。設置爲2指揮丟失刷新到操做系統緩存的那部分事務。

max_allowed_packet = 4M
thread_stack = 256K
table_cache = 128K
sort_buffer_size = 6M
#查詢排序時所能使用的緩衝區大小。注意:該參數對應的分配內存是每鏈接獨佔!若是有100個鏈接,那麼實際分配的總共排序緩衝區大小爲100 × 6 = 600MB。因此,對於內存在4GB左右的服務器推薦設置爲6-8M。

read_buffer_size = 4M
#讀查詢操做所能使用的緩衝區大小。和sort_buffer_size同樣,該參數對應的分配內存也是每鏈接獨享!

join_buffer_size = 8M
#聯合查詢操做所能使用的緩衝區大小,和sort_buffer_size同樣,該參數對應的分配內存也是每鏈接獨享!

myisam_sort_buffer_size = 64M
table_cache = 512
#打開一個表的開銷可能很大。例如MyISAM把MYI文件頭標誌該表正在使用中。你確定不但願這種操做太頻繁,因此一般要加大緩存數量,使得足以最大限度地緩存打開的表。它須要用到操做系統的資源以及內存,對當前的硬件配置來講固然不是什麼問題了。若是你有200多個表的話,那麼設置爲 1024 也許比較合適(每一個線程都須要打開表),若是鏈接數比較大那麼就加大它的值。我曾經見過設置爲100,000的狀況。

thread_cache_size = 64
#線程的建立和銷燬的開銷可能很大,由於每一個線程的鏈接/斷開都須要。我一般至少設置爲 16。若是應用程序中有大量的跳躍併發鏈接而且 Threads_Created 的值也比較大,那麼我就會加大它的值。它的目的是在一般的操做中無需建立新線程。

query_cache_size = 64M
#指定MySQL查詢緩衝區的大小。能夠經過在MySQL控制檯執行如下命令觀察:

# > SHOW VARIABLES LIKE ‘%query_cache%’;
# > SHOW STATUS LIKE ‘Qcache%’;
# 若是Qcache_lowmem_prunes的值很是大,則代表常常出現緩衝不夠的狀況;若是Qcache_hits的值很是大,則代表查詢緩衝使用很是頻繁,若是該值較小反而會影響效率,那麼能夠考慮不用查詢緩衝;Qcache_free_blocks,若是該值很是大,則代表緩衝區中碎片不少。

tmp_table_size = 256M
max_connections = 768
#指定MySQL容許的最大鏈接進程數。若是在訪問論壇時常常出現Too Many Connections的錯誤提 示,則須要增大該參數值。

max_connect_errors = 10000000
wait_timeout = 10
#指定一個請求的最大鏈接時間,對於4GB左右內存的服務器能夠設置爲5-10。

thread_concurrency = 8
#該參數取值爲服務器邏輯CPU數量×2,在本例中,服務器有2顆物理CPU,而每顆物理CPU又支持H.T超線程,因此實際取值爲4 × 2 = 8

skip-networking
#開啓該選項能夠完全關閉MySQL的TCP/IP鏈接方式,若是WEB服務器是以遠程鏈接的方式訪問MySQL數據庫服務器則不要開啓該選項!不然將沒法正常鏈接!

show status 命令
含義以下:
aborted_clients 客戶端非法中斷鏈接次數
aborted_connects 鏈接mysql失敗次數
com_xxx xxx命令執行次數,有不少條
connections 鏈接mysql的數量
Created_tmp_disk_tables 在磁盤上建立的臨時表
Created_tmp_tables 在內存裏建立的臨時表
Created_tmp_files 臨時文件數
Key_read_requests The number of requests to read a key block from the cache
Key_reads The number of physical reads of a key block from disk
Max_used_connections 同時使用的鏈接數
Open_tables 開放的表
Open_files 開放的文件
Opened_tables 打開的表
Questions 提交到server的查詢數
Sort_merge_passes 若是這個值很大,應該增長my.cnf中的sort_buffer值
Uptime 服務器已經工做的秒數

提高性能的建議:1.若是opened_tables太大,應該把my.cnf中的table_cache變大2.若是Key_reads太大,則應該把my.cnf中key_buffer_size變大.能夠用Key_reads/Key_read_requests計算出cache失敗率3.若是Handler_read_rnd太大,則你寫的SQL語句裏不少查詢都是要掃描整個表,而沒有發揮索引的鍵的做用4.若是Threads_created太大,就要增長my.cnf中thread_cache_size的值.能夠用Threads_created/Connections計算cache命中率5.若是Created_tmp_disk_tables太大,就要增長my.cnf中tmp_table_size的值,用基於內存的臨時表代替基於磁盤的

相關文章
相關標籤/搜索