1. 程式人生 > >my.ini檔案引數中文註釋

my.ini檔案引數中文註釋

優化思路:資料庫非同步同步 三點:幕等 時序 延遲

按照我的理解又分為以下幾個方面的層級

    傳輸階段:使用者連線至應用伺服器,應用伺服器訪問資料庫伺服器;

     硬體層:物理機器裝置,硬碟的轉速,CPU的主頻,記憶體的大小,網絡卡速率;

      硬體層之上:read卡,bios,雙網絡卡繫結;

      作業系統的優化:ulimit,tcp握手包的除錯,selinux等;

      資料庫配置檔案的除錯:my.ini 主配置檔案;

      資料庫表結構的除錯;

      SQL語句的優化;

以下整理搬運學弟的,讓自己在優化及調整的時候更方便,選擇用到的,滿足需求就好。

MySQL配置檔案優化

[client]

port   = 3306  #客戶端埠號為3306

socket  =/data/3306/mysql.sock #

default-character-set = utf8  #客戶端字符集,(控制character_set_clientcharacter_set_connectioncharacter_set_results)

[mysql]

no-auto-rehash  #僅僅允許使用鍵值的updatesdeletes

[mysqld]  #組包括了mysqld服務啟動的引數,它涉及的方面很多,其中有MySQL的目錄和檔案,通訊、網路、資訊保安,記憶體管理、優化、查詢快取區,還有

MySQL日誌設定等。

user    = mysql  #mysql_safe指令碼使用MySQL執行使用者(編譯時--user=mysql指定),推薦使用mysql使用者。

port    = 3306  #MySQL服務執行時的埠號。建議更改預設埠,預設容易遭受攻擊。

socket  =/data/3306/mysql.sock  #socket檔案是在Linux/Unix環境下特有的,使用者在Linux/Unix環境下客戶端連線可以不通過TCP/IP網路而直接使用unix socket連線MySQL

basedir = /application/mysql  #mysql程式所存放路徑,常用於存放

mysql啟動、配置檔案、日誌等

datadir = /data/3306/data  #MySQL資料存放檔案(極其重要)

character-set-server = utf8  #資料庫和資料庫表的預設字符集。(推薦utf8,以免導致亂碼)

log-error=/data/3306/mysql_xuliangwei.err  #mysql錯誤日誌存放路徑及名稱(啟動出現錯誤一定要看錯誤日誌,百分之百都能通過錯誤日誌排插解決。)

pid-file=/data/3306/mysql_xuliangwei.pid  #MySQL_pid檔案記錄的是當前mysqld程序的pidpid亦即ProcessID

skip-locking  #避免MySQL的外部鎖定,減少出錯機率,增強穩定性。

skip-name-resolv  #禁止MySQL對外部連線進行DNS解析,使用這一選項可以消除MySQL進行DNS解析的時候。但是需要注意的是,如果開啟該選項,則所有遠端主機連線授權都要使用IP地址方式了,否則MySQL將無法正常處理連線請求!

skip-networking  #開啟該選項可以徹底關閉MySQLTCP/IP連線方式,如果Web伺服器是以遠端連線的方式訪問MySQL資料庫伺服器的,則不要開啟該選項,否則無法正常連線!

open_files_limit    = 1024  #MySQLd能開啟檔案的最大個數,如果出現too mant openfiles之類的就需要調整該值了。

back_log = 384  #back_log引數是值指出在MySQL暫時停止響應新請求之前,短時間內的多少個請求可以被存在堆疊中。如果系統在短時間內有很多連線,則需要增加該引數的值,該引數值指定到來的TCP/IP連線的監聽佇列的大小。不同的作業系統在這個佇列的大小上有自己的限制。如果試圖將back_log設定得高於作業系統的限制將是無效的,其預設值為50.對於Linux系統而言,推薦設定為小於512的整數。

max_connections = 800 #指定MySQL允許的最大連線程序數。如果在訪問部落格時經常出現 Too Many Connections的錯誤提示,則需要增大該引數值。

max_connect_errors = 6000  #設定每個主機的連線請求異常中斷的最大次數,當超過該次數,MySQL伺服器將禁止host的連線請求,直到MySQL伺服器重啟或通過flush hosts命令清空此host的相關資訊。

wait_timeout = 120  #指定一個請求的最大連線時間,對於4GB左右記憶體的伺服器來說,可以將其設定為5~10

table_cache = 614K  #table_cache指示表高速緩衝區的大小。當MySQL訪問一個表時,如果在MySQL緩衝區還有空間,那麼這個表就被開啟並放入表緩衝區,這樣做的好處是可以更快速地訪問表中的內容。一般來說,可以檢視資料庫執行峰值時間的狀態值Open_tablesOpen_tables,用以判斷是否需要增加table_cache的值,即如果Open_tables接近table_cache的時候,並且Opened_tables這個值在逐步增加,那就要考慮增加這個值的大小了。

external-locking = FALSE  #MySQL選項可以避免外部鎖定。True為開啟。

max_allowed_packet =16M  #伺服器一次能處理最大的查詢包的值,也是伺服器程式能夠處理的最大查詢

sort_buffer_size = 1M  #設定查詢排序時所能使用的緩衝區大小,系統預設大小為2MB

注意:該引數對應的分配記憶體是每個連線獨佔的,如果有100個連線,那麼實際分配的總排序緩衝區大小為100 x6=600MB。所以,對於記憶體在4GB左右的伺服器來說,推薦將其設定為6MB~8MB

join_buffer_size = 8M #聯合查詢操作所能使用的緩衝區大小,和sort_buffer_size一樣,該引數對應的分配記憶體也是每個連線獨享。

thread_cache_size = 64 #設定Thread Cache池中可以快取的連線執行緒最大數量,可設定為0~16384,預設為0.這個值表示可以重新利用儲存在快取中執行緒的數量,當斷開連線時如果快取中還有空間,那麼客戶端的執行緒將被放到快取中;如果執行緒重新被請求,那麼請求將從快取中讀取,如果快取中是空的或者是新的請求,那麼這個執行緒將被重新建立,如果有很多執行緒,增加這個值可以改善系統性能。通過比較ConnectionsThreads_created狀態的變數,可以看到這個變數的作用。我們可以根據實體記憶體設定規則如下:1GB記憶體我們配置為8,2GB記憶體我們配置為16,3GB我們配置為32,4GB4GB以上我們給此值為64或更大的值。

thread_concurrency = 8  #該引數取值為伺服器邏輯CPU數量x 2,在本例中,伺服器有兩個物理CPU,而每個物理CPU又支援H.T超執行緒,所以實際取值為4 x 2 = 8。這也是雙四核主流伺服器的配置。

query_cache_size = 64M #指定MySQL查詢緩衝區的大小。可以通過在MySQL控制檯觀察,如果Qcache_lowmem_prunes的值非常大,則表明經常出現緩衝不夠的情況;如果Qcache_hits的值非常大,則表明查詢緩衝使用得非常頻繁。另外如果改值較小反而會影響效率,那麼可以考慮不用查詢緩衝。對於Qcache_free_blocks,如果該值非常大,則表明緩衝區中碎片很多。

query_cache_limit = 2M  #只有小於此設定值的結果才會被快取

query_cache_min_res_unit = 2k  #設定查詢快取分配記憶體的最小單位,要適當第設定此引數,可以做到為減少記憶體快的申請和分配次數,但是設定過大可能導致記憶體碎片數值上升。預設值為4K建議設定為1K~16K

default_table_type = InnoDB  #預設表的型別為InnoDB

thread_stack = 256K  #設定MySQL每個執行緒的堆疊大小,預設值足夠大,可滿足普通操作。可設定範圍為128KB4GB,預設為192KB

#transaction_isolation = Level #資料庫隔離級別 (READ UNCOMMITTED(讀取未提交內容) READ COMMITTED(讀取提交內容) REPEATABLE READ(可重讀) SERIALIZABLE(可序列化))

tmp_table_size = 64M  #設定記憶體臨時表最大值。如果超過該值,則會將臨時表寫入磁碟,其範圍1KB4GB

max_heap_table_size = 64M  #獨立的記憶體表所允許的最大容量。

table_cache = 614 #給經常訪問的表分配的記憶體,實體記憶體越大,設定就越大。調大這個值,一般情況下可以降低磁碟IO,但相應的會佔用更多的記憶體,這裡設定為614

table_open_cache = 512  #設定表快取記憶體的數目。每個連線進來,都會至少開啟一個表快取。因此,table_cache 的大小應與 max_connections 的設定有關。例如,對於200 個並行執行的連線,應該讓表的快取至少有 200 × N ,這裡 N 是應用可以執行的查詢的一個聯接中表的最大數量。此外,還需要為臨時表和檔案保留一些額外的檔案描述符。

long_query_time = 1  #慢查詢的執行用時上限,預設設定是10s,推薦(1s~2s)

log_long_format  #沒有使用索引的查詢也會被記錄。(推薦,根據業務來調整)

log-slow-queries = /data/3306/slow.log  #慢查詢日誌檔案路徑(如果開啟慢查詢,建議開啟此日誌)

log-bin = /data/3306/mysql-bin #logbin資料庫的操作日誌,例如updatedeletecreate等都會儲存到binlog日誌,通過logbin可以實現增量恢復

relay-log = /data/3306/relay-bin #relay-log日誌記錄的是從伺服器I/O執行緒將主伺服器的二進位制日誌讀取過來記錄到從伺服器本地檔案,然後SQL執行緒會讀取relay-log日誌的內容並應用到從伺服器

relay-log-info-file = /data/3306/relay-log.info  #從伺服器用於記錄中繼日誌相關資訊的檔案,預設名為資料目錄中的relay-log.info

binlog_cache_size = 4M  #在一個事務中binlog為了記錄sql狀態所持有的cache大小,如果你經常使用大的,多宣告的事務,可以增加此值來獲取更大的效能,所有從事務來的狀態都被緩衝在binlog緩衝中,然後再提交後一次性寫入到binlog中,如果事務比此值大,會使用磁碟上的臨時檔案來替代,此緩衝在每個連結的事務第一次更新狀態時被建立。

max_binlog_cache_size = 8M  #最大的二進位制Cache日誌緩衝尺寸。

max_binlog_size = 1G  #二進位制日誌檔案的最大長度(預設設定1GB)一個二進位制檔案資訊超過了這個最大長度之前,MySQL伺服器會自動提供一個新的二進位制日誌檔案接續上。

expire_logs_days = 7  #超過7天的binlog,mysql程式自動刪除(如果資料重要,建議不要開啟該選項)

key_buffer_size = 256M  #指定用於索引的緩衝區大小,增加它可得到更好的索引處理效能。對於記憶體在4GB左右的伺服器來說,該引數可設定為256MB384MB

注意:如果該引數值設定得過大反而會使伺服器的整體效率降低!

read_buffer_size = 4M  #讀查詢操作所能使用的緩衝區大小。和sort_buffer_size一樣,該引數對應的分配記憶體也是每個連線獨享。

read_rnd_buffer_size = 16M #設定進行隨機讀的時候所使用的緩衝區。此引數和read_buffer_size所設定的Buffer相反,一個是順序讀的時候使用,一個是隨機讀的時候使用。但是兩者都是針對與執行緒的設定,每個執行緒都可以產生兩種Buffer中的任何一個。預設值256KB,最大值4GB

bulk_insert_buffer_size = 8M  #如果經常性的需要使用批量插入的特殊語句來插入資料,可以適當調整引數至16MB~32MB,建議8MB

#myisam_sort_buffer_size = 8M #設定在REPAIR Table或用Create index建立索引或 Alter table的過程中排序索引所分配的緩衝區大小,可設定範圍4Bytes4GB,預設為8MB

lower_case_table_names = 1  #實現MySQL不區分大小。(發開需求-建議開啟)

slave-skip-errors = 1032,1062 #從庫可以跳過的錯誤數字值(mysql錯誤以數字程式碼反饋,全的mysql錯誤程式碼大全,以後會發布至部落格)

replicate-ignore-db=mysql  #在做主從的情況下,設定不需要同步的庫。

server-id = 1  #表示本機的序列號為1,如果做主從,或者多例項,serverid一定不能相同。

myisam_sort_buffer_size = 128M  #當需要對於執行REPAIR, OPTIMIZE, ALTER 語句重建索引時,MySQL會分配這個快取,以及LOAD DATA INFILE會載入到一個新表,它會根據最大的配置認真的分配的每個執行緒。 

myisam_max_sort_file_size = 10G #當重新建索引(REPAIRALTERTABLE,或者LOADDATATNFILE)時,MySQL被允許使用臨時檔案的最大值。

myisam_repair_threads = 1 #如果一個表擁有超過一個索引, MyISAM 可以通過並行排序使用超過一個執行緒去修復他們.

myisam_recover #自動檢查和修復沒有適當關閉的 MyISAM .

innodb_additional_mem_pool_size = 4M #用來設定InnoDB儲存的資料目錄資訊和其他內部資料結構的記憶體池大小。應用程式裡的表越多,你需要在這裡面分配越多的記憶體。對於一個相對穩定的應用,這個引數的大小也是相對穩定的,也沒有必要預留非常大的值。如果InnoDB用廣了這個池內的記憶體,InnoDB開始從作業系統分配記憶體,並且往MySQL錯誤日誌寫警告資訊。預設為1MB,當發現錯誤日誌中已經有相關的警告資訊時,就應該適當的增加該引數的大小。

innodb_buffer_pool_size = 64M #InnoDB使用一個緩衝池來儲存索引和原始資料,設定越大,在存取表裡面數據時所需要的磁碟I/O越少。強烈建議不要武斷地將InnoDBBuffer Pool值配置為實體記憶體的50%~80%,應根據具體環境而定。

innodb_data_file_path = ibdata1:128M:autoextend  #設定配置一個可擴充套件大小的尺寸為128MB的單獨檔案,名為ibdata1.沒有給出檔案的位置,所以預設的是在MySQL的資料目錄內。

innodb_file_io_threads = 4  #InnoDB中的檔案I/O執行緒。通常設定為4,如果是windows可以設定更大的值以提高磁碟I/O

innodb_thread_concurrency = 8 #你的伺服器有幾個CPU就設定為幾,建議用預設設定,一般設為8

innodb_flush_log_at_trx_commit = 1 #設定為0就等於innodb_log_buffer_size佇列滿後在統一儲存,預設為1,也是最安全的設定。

innodb_log_buffer_size = 2M  #預設為1MB通常設定為8~16MB就足夠了。

innodb_log_file_size = 32M  #確定日誌檔案的大小,更大的設定可以提高效能,但也會增加恢復資料庫的時間。

innodb_log_files_in_group = 3 #為提高效能,MySQL可以以迴圈方式將日誌檔案寫到多個檔案。推薦設定為3

innodb_max_dirty_pages_pct = 90 #InnoDB主執行緒重新整理快取池中的資料。

innodb_lock_wait_timeout = 120 #InnoDB事務被回滾之前可以等待一個鎖定的超時秒數。InnoDB在它自己的鎖定表中自動檢測事務死鎖並且回滾事務。InnoDBlocak tables 語句注意到鎖定設定。預設值是50秒。

innodb_file_per_table = 0  #InnoDB為獨立表空間模式,每個資料庫的每個表都會生成一個數據空間。0關閉,1開啟。

[mysqldump]

quick

max_allowed_packet = 2M  #設定在網路傳輸中一次訊息傳輸量的最大值。系統預設值為1MB,最大值是1GB,必須設定為1024的倍數。單位為位元組。

轉摘自:http://hexudong.blog.51cto.com/7169867/1750109/