MYSQL 5.6.34設定檔詳解

來源:互聯網
上載者:User

標籤:linux   mysql   用戶端   設定檔   資訊安全   

[client]

port = 3306     #用戶端連接埠號碼                                            

socket = /data/3306/mysql.sock  #socket檔案是linux/unix系統特有的,使用者在該環境下的用戶端串連可以不通過tcp/ip網路,而直接使用socket檔案串連。

[mysql]

no-auto-rehash    #僅僅允許使用索引值的update和deletes

[mysqld]          #mysqld組包括了mysqld服務啟動的參數,它涉及的方面很多,其中包括mysql的目錄和檔案,通訊、網路、資訊安全、記憶體管理、最佳化、查詢快取區,MySQL日誌設定等。

user    = mysql   #MySQL運行使用者(建議使用mysql使用者)

port    = 3306    #MySQL服務運行時的連接埠號碼(建議更改預設連接埠,預設容易遭受攻擊)

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

basedir = /application/mysql    #mysql程式所存放的路徑,一般用於存放mysql開機檔案、設定檔、日誌等

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

open_files_limit= 1024     #mysql能開啟檔案的最大個數,(如果出現too mant open files之類的就表示需要調整該值了)

back_log = 600     #back_log參數是指在mysql暫時停止回應新的請求之前,短時間內的多少個請求可以被存放在堆棧中,如果系統在短時間內有很多串連的話,則需要調整該參數的值,該參數的值指定到來的TCP/IP串連的監聽隊列的大小,不同的作業系統在這個隊列上的大小有各自的限制,如果試圖將back_log設定的高於作業系統的限制將是無效的,其預設值為50,對於Linux系統而言,推薦設為小於512的整數。

max_connections = 800    #指定mysql允許的最大串連進程數如果在訪問部落格時經常出現 too many connections的錯誤 提示的話,則需要增大該參數的值。

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

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

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

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

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

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

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

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

thread_concurrency = 2   #該參數取值為伺服器邏輯CPU數量x2。

query_cache_size = 2M    #指定mysql查詢緩衝區的大小,可以通過在mysql控制台觀察,如果qcache_lowmem_prunes的值非常大,則表明經常出現緩衝不夠的情況,如果qcache_hits的值非常大,則表明查詢緩衝區使用的非常頻繁,另外如果改值較小反而會影響效率,那麼則可以考慮不用查詢緩衝,對於acache_free_blocks,如果該值非常大,則表明緩衝區片段很多。

query_cache_limit = 1M   #只有小於此設定值的結果才會被緩衝。

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

default_table_type = InnoDB  #預設表的類型為InnoDB。

thread_stack = 192K      #設定mysql每個線程的堆棧大小,預設值足夠大,可滿足普通操作,可設定範圍為128K~4GB,預設為192K.

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

tmp_table_size = 2M    #設定記憶體暫存資料表最大值,如果超過該值,則會將暫存資料表寫入磁碟,其範圍1KB~4GB。

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

long_query_time = 1       #慢查詢的執行用時上限,預設為10s,推薦1s~2s.

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

log-error = /data/3306/error.log   #預設錯誤記錄檔存放路徑及名稱(出現錯誤要看錯誤記錄檔)

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

pid-file = /data/3306/mysql.pid   #mysql_pid檔案記錄的是當期mysqld進程的pid,pid即ProcessID

log-bin = /data/3306/mysql-bin   #logbin是資料庫的動作記錄,例如:update、delete、create等都會儲存到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 = 1M    #在一個事務中binlog為了記錄SQL狀態所持有的Cache大小,如果經常使用大的,多聲明的事務,可以增加此值來擷取更大的效能,所有從事務來的狀態都被緩衝在binlog緩衝中,然後再提交一次性寫入到binlog中,如果此事務比此值大,會使用磁碟上的臨時檔案來替代,此緩衝在每個連結的事務第一次更新狀態時被建立。

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

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

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

注意:如果該參數值設定的過大的話反而使伺服器的整體效率降低。

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

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

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


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

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

slave-skip-errors = 1032,1062   #從庫可以跳過的錯誤數字值

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

server-id = 6     #表示原生序號為1,如果做主從或者多執行個體時,server-id一定不能相同

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

innodb_buffer_pool_size = 32M   #InnoDB使用一個緩衝池來儲存索引和未經處理資料,設定越大,在存取表裡面資料時所需要的磁碟I/O 越少,一般設定為實體記憶體的%25左右,注意:不要將InnoDB的Buffer 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 = 2     #設定為0就等於Innodb_log_buffer_size隊列滿後再統一儲存,預設為1,也是最安全的設定。

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

innodb_log_file_size = 4M    #確定記錄檔的大小,更大的設定可以提高效能,但也會增加恢複資料庫的時間。

innodb_log_files_in_group = 3     #為提高效能,mysql可以以迴圈方式將記錄檔寫入到多個檔案。推薦設定為3.

innodb_max_dirty_pages_pct = 90    #InnoDB主線程重新整理緩衝池中的資料。

innodb_lock_wait_timeout = 120    #InnoDB事務被復原之前可以等待一個鎖定的逾時秒數,InnoDB在它自己的鎖定表中自動檢測事務死結並且復原事務。InnoDB用lock tables語句注意到鎖定設定,預設值為50秒。

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

獨立表優點:

1、每個表都有自己獨立的資料表空間。

2、每個表的資料和索引都會存在自己的資料表空間中。

3、可以實現單表在不同的資料庫中移動。

4、空間可以回收(除drop table操作處,表空不能自己回收)

[mysqldump]

quick

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

[mysqld_safe]

log-error=/data/3306/oldboy_3306.err    #mysql錯誤記錄檔存放路徑及名稱

pid-file=/data/3306/mysqld.pid   #mysql_pid檔案記錄的是當期的mysqld進程的Pid,pid即ProcessID。


本文出自 “12206254” 部落格,請務必保留此出處http://12216254.blog.51cto.com/12206254/1908401

MYSQL 5.6.34設定檔詳解

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.