Windows

復(fù)制配置文件
[root@root mysql]# cp /usr/share/mysql/my-huge.cnf /etc/my.cnf
cp:是否覆蓋"/etc/my.cnf"? y
[client]
port = 3306 #客戶端端口號
socket = /data/3306/mysql.sock #socket文件是linux/unix系統(tǒng)特有的,用戶在該環(huán)境下的客戶端連接可以不通過tcp/ip網(wǎng)絡(luò),而直接使用socket文件連接。
[mysql]
no-auto-rehash #僅僅允許使用鍵值的update和deletes
[mysqld] #mysqld組包括了mysqld服務(wù)啟動的參數(shù),它涉及的方面很多,其中包括mysql的目錄和文件,通信、網(wǎng)絡(luò)、信息安全、內(nèi)存管理、優(yōu)化、查詢緩存區(qū),MySQL日志設(shè)置等。
user = mysql #MySQL運行用戶(建議使用mysql用戶)
port = 3306 #MySQL服務(wù)運行時的端口號(建議更改默認端口,默認容易遭受攻擊)
socket = /data/3306/mysql.sock #socket文件是在Linux/Unix環(huán)境下特有的,用戶在Linux/Unix環(huán)境下客戶端連接可以不通過TCP/IP網(wǎng)絡(luò)而直接使用
basedir = /application/mysql #mysql程序所存放的路徑,一般用于存放mysql啟動文件、配置文件、日志等
datadir = /data/3306/data #mysql數(shù)據(jù)存放文件(極其重要)
open_files_limit= 1024 #mysql能打開文件的最大個數(shù),(如果出現(xiàn)too mant open files之類的就表示需要調(diào)整該值了)
back_log = 600 #back_log參數(shù)是指在mysql暫時停止響應(yīng)新的請求之前,短時間內(nèi)的多少個請求可以被存放在堆棧中,如果系統(tǒng)在短時間內(nèi)有很多連接的話,則需要調(diào)整該參數(shù)的值,該參數(shù)的值指定到來的TCP/IP連接的監(jiān)聽隊列的大小,不同的操作系統(tǒng)在這個隊列上的大小有各自的限制,如果試圖將back_log設(shè)置的高于操作系統(tǒng)的限制將是無效的,其默認值為50,對于Linux系統(tǒng)而言,推薦設(shè)為小于512的整數(shù)。
max_connections = 800 #指定mysql允許的最大連接進程數(shù)如果在訪問博客時經(jīng)常出現(xiàn) too many connections的錯誤 提示的話,則需要增大該參數(shù)的值。
max_connect_errors = 3000 #設(shè)置每個主機的連接請求異常中斷的最大次數(shù),當超過該次數(shù)時,MySQL服務(wù)器將禁止host的連接請求,直到MySQL服務(wù)器重啟或通過flush hosts命令來清空host的相關(guān)信息.
table_open_cache = 614 #用來指定表高速緩存的大小,當Mysql訪問一個表時,如果在mysql緩存區(qū)還有空間,那么這個表就被打開并放入表緩沖區(qū),這樣做的好處就是可以更快速的訪問表中的內(nèi)容,一般來說,可以查看數(shù)據(jù)庫運行峰值時間的狀態(tài)值Open_tables和Open_tables,用以判斷是否需要增加table_open_cache的值,即如果Open_tables接近table_open_cache的時候,并且Opened_tables這個值在逐步增加,那就要考慮增加這個值的大小了。
external-locking = FALSE #mysql選項可以避免外部鎖定。True為開啟。
max_allowed_packet =8M #服務(wù)器一次能處理最大的查詢包的值,也是服務(wù)器程序能夠處理的最大查詢。
sort_buffer_size = 1M #設(shè)置查詢排序時所能使用的緩存區(qū)的大小,系統(tǒng)默認為2M。
注意:該參數(shù)對應(yīng)的分配內(nèi)存是每個連接獨占的,如果有100個連接的話,那么實際分配的總排序緩存區(qū)大小為100x6=600M,所以,對于內(nèi)存在4GB左右的服務(wù)器來說,推薦將其設(shè)置為6MB~8MB。
join_buffer_size = 1M #聯(lián)合查詢操作所能使用的緩存區(qū)大小,和sort_buffer_size一樣,該參數(shù)對應(yīng)的分配內(nèi)存也是每個連接獨享的。
thread_cache_size = 100 #設(shè)置Thread Cache池中可以緩存的連接線程最大數(shù)量,可設(shè)置為0~16384,默認為0,這個值表示可以重新利用保存在緩存中線程的數(shù)量,當斷開連接時如果緩存中還有空間,那么客戶端的線程將被放到緩存中,如果線程被重新請求,那么請求將從緩存中讀取,如果緩存中是空的或者新的請求,那么這個這個線程將被重新創(chuàng)建,如果有很多線程,增加這個值可以改善系統(tǒng)性能,通過比較Connection和Thread_created狀態(tài)的數(shù)量,可以看到這個變量的作用,我們可以根據(jù)物理內(nèi)存設(shè)置規(guī)則如下:1GB內(nèi)存我們我們配置8,2GB內(nèi)存我們配置為16,3GB內(nèi)存我們配置為32,4GB或4GB以上我們給此值64或更大的值。
thread_concurrency = 2 #該參數(shù)取值為服務(wù)器邏輯CPU數(shù)量x2。
query_cache_size = 2M #指定mysql查詢緩沖區(qū)的大小,可以通過在mysql控制臺觀察,如果qcache_lowmem_prunes的值非常大,則表明經(jīng)常出現(xiàn)緩沖不夠的情況,如果qcache_hits的值非常大,則表明查詢緩沖區(qū)使用的非常頻繁,另外如果改值較小反而會影響效率,那么則可以考慮不用查詢緩沖,對于acache_free_blocks,如果該值非常大,則表明緩沖區(qū)碎片很多。
query_cache_limit = 1M #只有小于此設(shè)置值的結(jié)果才會被緩存。
query_cache_min_res_unit = 2k #設(shè)置查詢緩存分配內(nèi)存的最小單位,要適當設(shè)置此參數(shù),可以做到為減少內(nèi)存快的申請和分配次數(shù),但是設(shè)置過大可能導(dǎo)致內(nèi)存碎片數(shù)值上升,默認值為4K,建議設(shè)置W為1K~16K。
default_table_type = InnoDB #默認表的類型為InnoDB。
thread_stack = 192K #設(shè)置mysql每個線程的堆棧大小,默認值足夠大,可滿足普通操作,可設(shè)置范圍為128K~4GB,默認為192K.
transaction_isolation = READ-COMMITTED #數(shù)據(jù)庫隔離級別(READ UNCOMMITTED(讀取未提交內(nèi)容)READ COMMITTED(讀取提交內(nèi)容)REPEATABLE READ (可重讀)SERIALIZABLE(可串行化))
tmp_table_size = 2M #設(shè)置內(nèi)存臨時表最大值,如果超過該值,則會將臨時表寫入磁盤,其范圍1KB~4GB。
max_heap_table_size = 2M #獨立的內(nèi)存表所允許的最大容量
long_query_time = 1 #慢查詢的執(zhí)行用時上限,默認為10s,推薦1s~2s.
log_long_format #沒有使用索引的查詢也會被記錄(推薦,根據(jù)業(yè)務(wù)來調(diào)整)
log-error = /data/3306/error.log #默認錯誤日志存放路徑及名稱(出現(xiàn)錯誤要看錯誤日志)
log-slow-queries = /data/3306/slow.log #慢查詢?nèi)罩疚募窂剑ㄈ绻_啟慢查詢,建議打開此日志)
pid-file = /data/3306/mysql.pid #mysql_pid文件記錄的是當期mysqld進程的pid,pid即ProcessID
log-bin = /data/3306/mysql-bin #logbin是數(shù)據(jù)庫的操作日志,例如:update、delete、create等都會存儲到binlog日志,通過logbin可以實現(xiàn)增量恢復(fù)。
relay-log = /data/3306/relay-bin #relay-log日志記錄的是從服務(wù)器I/O線程將主服務(wù)器的二進制日志讀取過來記錄到從服務(wù)器本地文件,然后SQL線程會讀取relay-log日志的內(nèi)容并應(yīng)用到從服務(wù)器。
relay-log-info-file = /data/3306/relay-log.info #從服務(wù)器用于記錄中繼日志相關(guān)信息的文件,默認名為數(shù)據(jù)目錄中的relay-log.info。
binlog_cache_size = 1M #在一個事務(wù)中binlog為了記錄SQL狀態(tài)所持有的Cache大小,如果經(jīng)常使用大的,多聲明的事務(wù),可以增加此值來獲取更大的性能,所有從事務(wù)來的狀態(tài)都被緩沖在binlog緩沖中,然后再提交一次性寫入到binlog中,如果此事務(wù)比此值大,會使用磁盤上的臨時文件來替代,此緩沖在每個鏈接的事務(wù)第一次更新狀態(tài)時被創(chuàng)建。
max_binlog_cache_size = 1M #二進制日志文件的最大長度(默認設(shè)置1GB),一個二進制文件信息超過了這個最大長度之前,MySQL服務(wù)器會自動提供一個新的二進制文件接上。
expire_logs_days = 7 #超過7天的binlog.mysql程序自動刪除(如果數(shù)據(jù)重要,建議不要開啟該選項)
key_buffer_size = 16M #指定用于索引的緩沖區(qū)大小,增加它可以得到更好的索引處理性能,對于內(nèi)存在4GB左右的服務(wù)器來說,該參數(shù)可設(shè)置為256MB或384MB。
注意:如果該參數(shù)值設(shè)定的過大的話反而使服務(wù)器的整體效率降低。
read_buffer_size = 1M #讀查詢操作所能使用的緩沖區(qū)大小,和sort_buffer_size一樣,該參數(shù)對應(yīng)的分配內(nèi)存也是每個連接獨享。
read_rnd_buffer_size = 1M #設(shè)置進行隨機讀的時候所使用的緩沖區(qū),此參數(shù)和read_buffer_size所設(shè)置的Buffer相反,一個是順序讀的時候使用,一個是隨機讀的時候使用,但是兩者都是針對與線程的設(shè)置,每個線程都可以產(chǎn)生兩種Buffer中的任何一個,默認值256KB,最大值為4GB。
bulk_insert_buffer_size = 1M #如果經(jīng)常性的需要使用批量插入放入特殊語句來插入數(shù)據(jù),可以適當調(diào)整參數(shù)至16MB~32MB,建議8MB。
lower_case_table_names = 1 #實現(xiàn)mysql不區(qū)分大小(開發(fā)需求,建議開啟)
skip-name-resolve #禁止mysql對外部連接進行DNS解析,使用這一選項可以消除mysql進行DNS解析的時候。但是需要注意的是,如果開啟該選項,則所有遠程主機連接授權(quán)都要使用IP地址方式了,否則mysql將無法正常處理連接請求。
slave-skip-errors = 1032,1062 #從庫可以跳過的錯誤數(shù)字值
replicate-ignore-db=mysql #在做主從的情況下,設(shè)置不需要同步的庫。
server-id = 6 #表示本機的序列號為1,如果做主從或者多實例時,server-id一定不能相同
innodb_additional_mem_pool_size = 4M #用來設(shè)置InnoDB存儲的數(shù)據(jù)目錄信息和其他內(nèi)部數(shù)據(jù)結(jié)構(gòu)的內(nèi)存池大小,應(yīng)用程序里的表越多,需要在這里分配的內(nèi)存越多,對于一個相對穩(wěn)定的應(yīng)用,這個參數(shù)的大小也是相對穩(wěn)定的,也沒有必要預(yù)留非常大的值,如果InnoDB用光了這個池內(nèi)的內(nèi)存,InnoDB就開始從操作系統(tǒng)分配內(nèi)存,并且往mysql錯誤日志寫警告信息,默認為1MB,當發(fā)現(xiàn)錯誤日志中已經(jīng)有相關(guān)的警告信息時,就應(yīng)該適當?shù)脑黾釉搮?shù)的大小。
innodb_buffer_pool_size = 32M #InnoDB使用一個緩沖池來保存索引和原始數(shù)據(jù),設(shè)置越大,在存取表里面數(shù)據(jù)時所需要的磁盤I/O 越少,一般設(shè)置為物理內(nèi)存的%25左右,注意:不要將InnoDB的Buffer pool值配置為物理內(nèi)存的50%~80%,應(yīng)該根據(jù)具體生產(chǎn)環(huán)境而定。
innodb_data_file_path = ibdata1:128M:autoextend #設(shè)置配置一個可擴展大小的尺寸為128MB的單獨文件,名為ibdata1,沒有給出文件的位置,所有默認的是在mysql的數(shù)據(jù)目錄內(nèi)。
innodb_file_io_threads = 4 #InnoDB中的文件I/O線程,通常設(shè)置為4,如果是Windows可以設(shè)置更大的值以提高磁盤I/O.
innodb_thread_concurrency = 8 #服務(wù)器有幾個CPU就設(shè)置為幾,建議用默認設(shè)置,一般設(shè)為8。
innodb_flush_log_at_trx_commit = 2 #設(shè)置為0就等于Innodb_log_buffer_size隊列滿后再統(tǒng)一存儲,默認為1,也是最安全的設(shè)置。
innodb_log_buffer_size = 2M #默認為1MB,通常設(shè)置為8~16MB就足夠了。
innodb_log_file_size = 4M #確定日志文件的大小,更大的設(shè)置可以提高性能,但也會增加恢復(fù)數(shù)據(jù)庫的時間。
innodb_log_files_in_group = 3 #為提高性能,mysql可以以循環(huán)方式將日志文件寫入到多個文件。推薦設(shè)置為3.
innodb_max_dirty_pages_pct = 90 #InnoDB主線程刷新緩存池中的數(shù)據(jù)。
innodb_lock_wait_timeout = 120 #InnoDB事務(wù)被回滾之前可以等待一個鎖定的超時秒數(shù),InnoDB在它自己的鎖定表中自動檢測事務(wù)死鎖并且回滾事務(wù)。InnoDB用lock tables語句注意到鎖定設(shè)置,默認值為50秒。
innodb_file_per_table = 0 #InnoDB為獨立表空間模式,每個數(shù)據(jù)庫的每個表都會生成一個數(shù)據(jù)空間。0為關(guān)閉,1為開啟。
獨立表優(yōu)點:
1、每個表都有自己獨立的表空間。
2、每個表的數(shù)據(jù)和索引都會存在自己的表空間中。
3、可以實現(xiàn)單表在不同的數(shù)據(jù)庫中移動。
4、空間可以回收(除drop table操作處,表空不能自己回收)
[mysqldump]
quick
max_allowed_packet = 2M #設(shè)定在網(wǎng)絡(luò)傳輸中一次消息傳輸量的最大值,系統(tǒng)默認為1MB,最大值為1GB,必須設(shè)置為1024的倍數(shù),單位為字節(jié)。
[mysqld_safe]
log-error=/data/3306/oldboy_3306.err #mysql錯誤日志存放路徑及名稱
pid-file=/data/3306/mysqld.pid #mysql_pid文件記錄的是當期的mysqld進程的Pid,pid即ProcessID。