MySQL服務器最大鏈接數怎麼設置才合理[轉]

若是mysql 鏈接數據設置不合理可能會致使很小的流量mysql就提示MySQL: ERROR 1040: Too many connections錯誤了,那麼要如何纔算是合理設置mysql最大鏈接數呢,下面我來給你們介紹介紹。
 

MySQL服務器的鏈接數並非要達到最大的100%爲好,仍是要具體問題具體分析,下面就對MySQL服務器最大鏈接數的合理設置進行了詳盡的分析,供您參考。mysql

咱們常常會碰見「MySQL: ERROR 1040: Too many connections」的狀況,一般,mysql的最大鏈接數默認是100, 最大能夠達到16384。sql

一種是訪問量確實很高,MySQL服務器抗不住,這個時候就要考慮增長從服務器分散讀壓力,另一種狀況是MySQL配置文件中max_connections值太小:數據庫

mysql> show variables like 'max_connections';
+-----------------+-------+
| Variable_name | Value |
+-----------------+-------+
| max_connections | 256 |
+-----------------+-------+windows

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

mysql> show global status like 'Max_used_connections';session

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

Max_used_connections / max_connections * 100% ≈ 85%併發

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


 在Windows下經常使用的有兩種方式修改最大鏈接數。命令行

第一種:命令行修改。

    >mysql -uuser -ppassword(命令行登陸MySQL)

    mysql>show variables like 'max_connections';(查能夠看當前的最大鏈接數)

    msyql>set global max_connections=1000;(設置最大鏈接數爲1000,能夠再次查看是否設置成功)

    mysql>exit(推出)

    這種方式有個問題,就是設置的最大鏈接數只在mysql當前服務進程有效,一旦mysql重啓,又會恢復到初始狀態。由於mysql啓動後的初始化工做是從其配置文件中讀取數據的,而這種方式沒有對其配置文件作更改。

    第二種:修改配置文件。

   這 種方式說來很簡單,只要修改MySQL配置文件my.ini 或 my.cnf的參數max_connections,將其改成max_connections=1000,而後重啓MySQL便可。可是有一點最難的就是my.ini這個文件在哪找。一般有兩種可能,一個是在安裝目錄下(這是比較理想的狀況),另外一種是在數據文件的目錄下,安裝的時候若是沒有人爲改變目錄的話,通常就在C:/ProgramData/MySQL往下的目錄下。

 與鏈接數相關的幾個參數:

     在修改最大鏈接數的時候會有這樣一個疑問—這個值是否是越大越好,或者設置爲多大才合適?這個參數的大小要綜合不少因素來考慮,好比使用的平臺所支持的線程庫數量(windows只能支持到2048)、服務器的配置(特別是內存大小)、每一個鏈接佔用資源(內存和負載)的多少、系統須要的響應時間等。能夠在global或session範圍內修改這個參數。鏈接數的增長會帶來不少連鎖反應,須要在實際中避免由此引起的負面影響。

    首先看一下MySQL的狀態:

mysql> status;
--------------
mysql  Ver 14.14 Distrib 5.5.15, for Win32 (x86)

Connection id:          1
Current database:
Current user:           root@localhost
SSL:                    Not in use
Using delimiter:        ;
Server version:         5.5.15 MySQL Community Server (GPL)
Protocol version:       10
Connection:             localhost via TCP/IP
Server characterset:    utf8
Db     characterset:    utf8
Client characterset:    gbk
Conn.  characterset:    gbk
TCP port:               3306
Uptime:                 1 hour 3 min 27 sec

Threads: 12  Questions: 18  Slow queries: 10  Opens: 33  Flush tables: 5  Open tab
les: 34  Queries per second avg: 6.256
--------------

Open tables:34,即當前數據庫打開表的數量是34個,注意這個34並非實際的34個表,由於MySQL是多線程的系統,幾個不一樣的併發鏈接可能打開同一個表,這就須要爲不一樣的鏈接session分配獨立的內存空間來存儲這些信息以免衝突。所以鏈接數的增長會致使MySQL須要的文件描述符數目的增長。另外對於MyISAM表,還會創建一個共享的索引文件描述符。

    在MySQL數據庫層面,有幾個系統參數決定了可同時打開的表的數量和要使用的文件描述符,那就是table_open_cache、max_tmp_tables和open_files_limit。

mysql> show variables like 'table_open%';
+------------------+-------+
| Variable_name    | Value |
+------------------+-------+
| table_open_cache | 256   |
+------------------+-------+
1 row in set (0.00 sec)

table_open_cache:256,這就是說全部的MySQL線程一共能同時打開256個表,咱們能夠蒐集系統的打開表的數量的歷史記錄和這個參數來對比,決定是否要增長這個參數的大小。查看當前的打開表的數目(Open tables)可用上邊提到過的status命令,另外能夠直接查詢這個系統變量的值:

mysql> show status like 'open_tables';
+---------------+-------+
| Variable_name | Value |
+---------------+-------+
| Open_tables   | 3     |
+---------------+-------+
1 row in set (0.00 sec)

Open_tables就是當前打開表的數目,經過flush tables命令能夠關閉當前打開的表。 這個值若是過大,而且若是沒有常常的執行flush tables命令,能夠考慮增長table_open_cache參數的大小。
 
接下來看max_tmp_tables:
mysql> show variables like 'max_tmp%';
+----------------+-------+
| Variable_name  | Value |
+----------------+-------+
| max_tmp_tables | 32    |
+----------------+-------+
1 row in set (0.00 sec)
max_tmp_tables:32即單個客戶端鏈接能打開的臨時表數目。查看當前已打開的臨時表的信息:
mysql> show global status like '%tmp%table%';
+-------------------------+-------+
| Variable_name           | Value |
+-------------------------+-------+
| Created_tmp_disk_tables | 0     |
| Created_tmp_tables      | 11    |
+-------------------------+-------+
2 rows in set (0.00 sec)
根據這兩個值能夠判斷臨時表的建立位置,通常選取BLOB和TEXT列、Group by 和 Distinct語句的數據量超過512 bytes,或者union的時候select某列的數據超過512 bytes的時候,就直接在磁盤上建立臨時表了,另外內存中的臨時表變大的時候,也可能被MySQL自動轉移到磁盤上(由tmp_table_size和max_heap_table_size參數決定)。
 
增長table_open_cache或max_tmp_tables 參數的大小後,從操做系統的角度看,mysqld進程須要使用的文件描述符的個數就要相應的增長,這個是由open_files_limit參數控制的。
mysql> show variables like 'open_files%';
+------------------+-------+
| Variable_name    | Value |
+------------------+-------+
| open_files_limit | 2670  |
+------------------+-------+
1 row in set (0.00 sec)
可是這個參數是OS限制的,因此咱們設定的值並不必定老是生效。若是OS限制MySQL不能修改這個值,那麼置爲0。若是是專用的MySQL服務器上,這個值通常要設置的儘可能大,就是設爲沒有報Too many open files錯誤的最大值,這樣就能一勞永逸了。當操做系統沒法分配足夠的文件描述符的時候,mysqld進程會在錯誤日誌裏記錄警告信息。
相應的,有兩個狀態變量記錄了當前和歷史的文件打開信息:
mysql> show global status like '%open%file%';
+---------------+-------+
| Variable_name | Value |
+---------------+-------+
| Open_files    | 0     |
| Opened_files  | 76    |
+---------------+-------+
2 rows in set (0.00 sec)
MySQL爲每一個鏈接分配線程來處理,能夠經過threads_connected參數查看當前分配的線程數量:
mysql> show status like '%thread%';
+------------------------------------------+-------+
| Variable_name                            | Value |
+------------------------------------------+-------+
| Delayed_insert_threads                   | 0     |
| Performance_schema_thread_classes_lost   | 0     |
| Performance_schema_thread_instances_lost | 0     |
| Slow_launch_threads                      | 0     |
| Threads_cached                           | 0     |
| Threads_connected                        | 1     |
| Threads_created                          | 1     |
| Threads_running                          | 1     |
+------------------------------------------+-------+
8 rows in set (0.00 sec)
比較threads_connected參數和前面提到的max_connections參數,也能夠做爲目前的系統負載的參照,決定是否須要修改鏈接數。

查看每一個線程的詳細信息:mysql>show processlist;對影響系統運行的線程:kill connection|query threadid的命令殺死。

相關文章
相關標籤/搜索