欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

MySQL中my.ini文件的基礎(chǔ)配置和優(yōu)化配置方式

 更新時(shí)間:2025年01月13日 10:45:47   作者:沐 修  
文章討論了數(shù)據(jù)庫(kù)異步同步的優(yōu)化思路,包括三個(gè)主要方面:冪等性、時(shí)序和延遲,作者還分享了MySQL配置文件的優(yōu)化經(jīng)驗(yàn),并鼓勵(lì)讀者提供支持

MySQL my.ini文件的配置和優(yōu)化配置

優(yōu)化思路

數(shù)據(jù)庫(kù)異步同步 三點(diǎn):幕等 時(shí)序 延遲

按照我的理解又分為以下幾個(gè)方面的層級(jí)

  • 傳輸階段:用戶連接至應(yīng)用服務(wù)器,應(yīng)用服務(wù)器訪問(wèn)數(shù)據(jù)庫(kù)服務(wù)器;
  • 硬件層:物理機(jī)器設(shè)備,硬盤的轉(zhuǎn)速,CPU的主頻,內(nèi)存的大小,網(wǎng)卡速率; 
  • 硬件層之上:read卡,bios,雙網(wǎng)卡綁定;
  • 操作系統(tǒng)的優(yōu)化:ulimit,tcp握手包的調(diào)試,selinux等;
  • 數(shù)據(jù)庫(kù)配置文件的調(diào)試:my.ini 主配置文件;
  • 數(shù)據(jù)庫(kù)表結(jié)構(gòu)的調(diào)試;
  • SQL語(yǔ)句的優(yōu)化;

MySQL配置文件優(yōu)化

[client]

port   = 3306  #客戶端端口號(hào)為3306

socket  =/data/3306/mysql.sock #

default-character-set = utf8  #客戶端字符集,(控制character_set_client、character_set_connection、character_set_results)

 

[mysql]

no-auto-rehash  
#僅僅允許使用鍵值的updates和deletes

 

[mysqld]  
#組包括了mysqld服務(wù)啟動(dòng)的參數(shù),它涉及的方面很多,其中有MySQL的目錄和文件,通信、網(wǎng)絡(luò)、
# 信息安全、內(nèi)存管理、優(yōu)化、查詢緩存區(qū),還有MySQL日志設(shè)置等。

user    = mysql  
#mysql_safe腳本使用 MySQL運(yùn)行用戶(編譯時(shí)--user=mysql指定),推薦使用mysql用戶。

port    = 3306  
# MySQL服務(wù)運(yùn)行時(shí)的端口號(hào)。建議更改默認(rèn)端口,默認(rèn)容易遭受攻擊。

socket  =/data/3306/mysql.sock  #socket文件是在Linux/Unix環(huán)境下特有的,用戶在Linux/Unix環(huán)境下客戶端連接可以不通過(guò)TCP/IP網(wǎng)絡(luò)而直接使用unix socket連接MySQL。

basedir = /application/mysql  
# mysql程序所存放路徑,常用于存放mysql啟動(dòng)、配置文件、日志等

datadir = /data/3306/data  
# MySQL數(shù)據(jù)存放文件(極其重要)

character-set-server = utf8  
# 數(shù)據(jù)庫(kù)和數(shù)據(jù)庫(kù)表的默認(rèn)字符集。(推薦utf8,以免導(dǎo)致亂碼)

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

pid-file=/data/3306/mysql_xuliangwei.pid  
# MySQL_pid文件記錄的是當(dāng)前mysqld進(jìn)程的pid,pid亦即ProcessID。

skip-locking  
# 避免MySQL的外部鎖定,減少出錯(cuò)幾率,增強(qiáng)穩(wěn)定性。

skip-name-resolv  
# 禁止 MySQL對(duì)外部連接進(jìn)行DNS解析,使用這一選項(xiàng)可以消除 MySQL進(jìn)行 DNS 解析的時(shí)候。
# 但是需要注意的是,如果開(kāi)啟該選項(xiàng),則所有遠(yuǎn)程主機(jī)連接授權(quán)都要使用 IP地址方式了,
# 否則 MySQL將無(wú)法正常處理連接請(qǐng)求!

skip-networking  
# 開(kāi)啟該選項(xiàng)可以徹底關(guān)閉 MySQL的 TCP/IP連接方式,
# 如果 Web服務(wù)器是以遠(yuǎn)程連接的方式訪問(wèn) MySQL數(shù)據(jù)庫(kù)服務(wù)器的,
# 則不要開(kāi)啟該選項(xiàng),否則無(wú)法正常連接!

open_files_limit    = 1024  
# MySQLd能打開(kāi)文件的最大個(gè)數(shù),如果出現(xiàn) too mant openfiles之類的就需要調(diào)整該值了。

back_log = 384  
# back_log參數(shù)是值指出在MySQL暫時(shí)停止響應(yīng)新請(qǐng)求之前,短時(shí)間內(nèi)的多少個(gè)請(qǐng)求可以被存在堆棧中。
# 如果系統(tǒng)在短時(shí)間內(nèi)有很多連接,則需要增加該參數(shù)的值,
# 該參數(shù)值指定到來(lái)的 TCP/IP連接的監(jiān)聽(tīng)隊(duì)列的大小。
# 不同的操作系統(tǒng)在這個(gè)隊(duì)列的大小上有自己的限制。
# 如果試圖將 back_log設(shè)置得高于操作系統(tǒng)的限制將是無(wú)效的,其默認(rèn)值為50.對(duì)于 Linux系統(tǒng)而言,
# 推薦設(shè)置為小于512的整數(shù)。

max_connections = 800 
# 指定 MySQL允許的最大連接進(jìn)程數(shù)。
# 如果在訪問(wèn)博客時(shí)經(jīng)常出現(xiàn) Too Many Connections的錯(cuò)誤提示,則需要增大該參數(shù)值。

max_connect_errors = 6000  
# 設(shè)置每個(gè)主機(jī)的連接請(qǐng)求異常中斷的最大次數(shù),當(dāng)超過(guò)該次數(shù),
# MySQL 服務(wù)器將禁止 host的連接請(qǐng)求,
# 直到 MySQL 服務(wù)器重啟或通過(guò) flush hosts命令清空此host的相關(guān)信息。

wait_timeout = 120  
# 指定一個(gè)請(qǐng)求的最大連接時(shí)間,對(duì)于4GB左右內(nèi)存的服務(wù)器來(lái)說(shuō),可以將其設(shè)置為5~10。

table_cache = 614K  
# table_cache指示表高速緩沖區(qū)的大小。當(dāng)MySQL訪問(wèn)一個(gè)表時(shí),如果在 MySQL緩沖區(qū)還有空間,
# 那么這個(gè)表就被打開(kāi)并放入表緩沖區(qū),這樣做的好處是可以更快速地訪問(wèn)表中的內(nèi)容。一般來(lái)說(shuō),
# 可以查看數(shù)據(jù)庫(kù)運(yùn)行峰值時(shí)間的狀態(tài)值 Open_tables和Open_tables,用以判斷是否需要增加
# table_cache的值,即如果 Open_tables接近 table_cache的時(shí)候,
# 并且 Opened_tables這個(gè)值在逐步增加,那就要考慮增加這個(gè)值的大小了。

external-locking = FALSE  
# MySQL選項(xiàng)可以避免外部鎖定。True為開(kāi)啟。

max_allowed_packet =16M  #服務(wù)器一次能處理最大的查詢包的值,也是服務(wù)器程序能夠處理的最大查詢

sort_buffer_size = 1M  #設(shè)置查詢排序時(shí)所能使用的緩沖區(qū)大小,系統(tǒng)默認(rèn)大小為2MB。

注意:該參數(shù)對(duì)應(yīng)的分配內(nèi)存是每個(gè)連接獨(dú)占的,如果有100個(gè)連接,那么實(shí)際分配的總排序緩沖區(qū)大小為100 x6=600MB。所以,對(duì)于內(nèi)存在4GB左右的服務(wù)器來(lái)說(shuō),推薦將其設(shè)置為6MB~8MB

join_buffer_size = 8M 
# 聯(lián)合查詢操作所能使用的緩沖區(qū)大小,和 sort_buffer_size一樣,
# 該參數(shù)對(duì)應(yīng)的分配內(nèi)存也是每個(gè)連接獨(dú)享。

thread_cache_size = 64 #設(shè)置Thread Cache池中可以緩存的連接線程最大數(shù)量,可設(shè)置為0~16384,默認(rèn)為0.這個(gè)值表示可以重新利用保存在緩存中線程的數(shù)量,當(dāng)斷開(kāi)連接時(shí)如果緩存中還有空間,那么客戶端的線程將被放到緩存中;如果線程重新被請(qǐng)求,那么請(qǐng)求將從緩存中讀取,如果緩存中是空的或者是新的請(qǐng)求,那么這個(gè)線程將被重新創(chuàng)建,如果有很多線程,增加這個(gè)值可以改善系統(tǒng)性能。通過(guò)比較Connections和Threads_created狀態(tài)的變量,可以看到這個(gè)變量的作用。我們可以根據(jù)物理內(nèi)存設(shè)置規(guī)則如下:1GB內(nèi)存我們配置為8,2GB內(nèi)存我們配置為16,3GB我們配置為32,4GB或4GB以上我們給此值為64或更大的值。

thread_concurrency = 8  #該參數(shù)取值為服務(wù)器邏輯CPU數(shù)量x 2,在本例中,服務(wù)器有兩個(gè)物理CPU,而每個(gè)物理CPU又支持H.T超線程,所以實(shí)際取值為4 x 2 = 8。這也是雙四核主流服務(wù)器的配置。

query_cache_size = 64M #指定MySQL查詢緩沖區(qū)的大小??梢酝ㄟ^(guò)在MySQL控制臺(tái)觀察,如果Qcache_lowmem_prunes的值非常大,則表明經(jīng)常出現(xiàn)緩沖不夠的情況;如果Qcache_hits的值非常大,則表明查詢緩沖使用得非常頻繁。另外如果改值較小反而會(huì)影響效率,那么可以考慮不用查詢緩沖。對(duì)于Qcache_free_blocks,如果該值非常大,則表明緩沖區(qū)中碎片很多。

query_cache_limit = 2M  #只有小于此設(shè)置值的結(jié)果才會(huì)被緩存

query_cache_min_res_unit = 2k  #設(shè)置查詢緩存分配內(nèi)存的最小單位,要適當(dāng)?shù)谠O(shè)置此參數(shù),可以做到為減少內(nèi)存快的申請(qǐng)和分配次數(shù),但是設(shè)置過(guò)大可能導(dǎo)致內(nèi)存碎片數(shù)值上升。默認(rèn)值為4K,建議設(shè)置為1K~16K。

default_table_type = InnoDB  #默認(rèn)表的類型為InnoDB

thread_stack = 256K  #設(shè)置MySQL每個(gè)線程的堆棧大小,默認(rèn)值足夠大,可滿足普通操作。可設(shè)置范圍為128KB至4GB,默認(rèn)為192KB

#transaction_isolation = Level #數(shù)據(jù)庫(kù)隔離級(jí)別 (READ UNCOMMITTED(讀取未提交內(nèi)容) READ COMMITTED(讀取提交內(nèi)容) REPEATABLE READ(可重讀) SERIALIZABLE(可串行化))

tmp_table_size = 64M  #設(shè)置內(nèi)存臨時(shí)表最大值。如果超過(guò)該值,則會(huì)將臨時(shí)表寫入磁盤,其范圍1KB到4GB。

max_heap_table_size = 64M  #獨(dú)立的內(nèi)存表所允許的最大容量。

table_cache = 614 #給經(jīng)常訪問(wèn)的表分配的內(nèi)存,物理內(nèi)存越大,設(shè)置就越大。調(diào)大這個(gè)值,一般情況下可以降低磁盤IO,但相應(yīng)的會(huì)占用更多的內(nèi)存,這里設(shè)置為614。

table_open_cache = 512  #設(shè)置表高速緩存的數(shù)目。每個(gè)連接進(jìn)來(lái),都會(huì)至少打開(kāi)一個(gè)表緩存。因此,table_cache 的大小應(yīng)與 max_connections 的設(shè)置有關(guān)。例如,對(duì)于200 個(gè)并行運(yùn)行的連接,應(yīng)該讓表的緩存至少有 200 × N ,這里 N 是應(yīng)用可以執(zhí)行的查詢的一個(gè)聯(lián)接中表的最大數(shù)量。此外,還需要為臨時(shí)表和文件保留一些額外的文件描述符。

long_query_time = 1  #慢查詢的執(zhí)行用時(shí)上限,默認(rèn)設(shè)置是10s,推薦(1s~2s)

log_long_format  #沒(méi)有使用索引的查詢也會(huì)被記錄。(推薦,根據(jù)業(yè)務(wù)來(lái)調(diào)整)

log-slow-queries = /data/3306/slow.log  #慢查詢?nèi)罩疚募窂?如果開(kāi)啟慢查詢,建議打開(kāi)此日志)

log-bin = /data/3306/mysql-bin #logbin數(shù)據(jù)庫(kù)的操作日志,例如update、delete、create等都會(huì)存儲(chǔ)到binlog日志,通過(guò)logbin可以實(shí)現(xiàn)增量恢復(fù)

relay-log = /data/3306/relay-bin #relay-log日志記錄的是從服務(wù)器I/O線程將主服務(wù)器的二進(jìn)制日志讀取過(guò)來(lái)記錄到從服務(wù)器本地文件,然后SQL線程會(huì)讀取relay-log日志的內(nèi)容并應(yīng)用到從服務(wù)器

relay-log-info-file = /data/3306/relay-log.info  #從服務(wù)器用于記錄中繼日志相關(guān)信息的文件,默認(rèn)名為數(shù)據(jù)目錄中的relay-log.info。

binlog_cache_size = 4M  #在一個(gè)事務(wù)中binlog為了記錄sql狀態(tài)所持有的cache大小,如果你經(jīng)常使用大的,多聲明的事務(wù),可以增加此值來(lái)獲取更大的性能,所有從事務(wù)來(lái)的狀態(tài)都被緩沖在binlog緩沖中,然后再提交后一次性寫入到binlog中,如果事務(wù)比此值大,會(huì)使用磁盤上的臨時(shí)文件來(lái)替代,此緩沖在每個(gè)鏈接的事務(wù)第一次更新?tīng)顟B(tài)時(shí)被創(chuàng)建。

max_binlog_cache_size = 8M  #最大的二進(jìn)制Cache日志緩沖尺寸。

max_binlog_size = 1G  #二進(jìn)制日志文件的最大長(zhǎng)度(默認(rèn)設(shè)置1GB)一個(gè)二進(jìn)制文件信息超過(guò)了這個(gè)最大長(zhǎng)度之前,MySQL服務(wù)器會(huì)自動(dòng)提供一個(gè)新的二進(jìn)制日志文件接續(xù)上。

expire_logs_days = 7  #超過(guò)7天的binlog,mysql程序自動(dòng)刪除(如果數(shù)據(jù)重要,建議不要開(kāi)啟該選項(xiàng))

key_buffer_size = 256M  #指定用于索引的緩沖區(qū)大小,增加它可得到更好的索引處理性能。對(duì)于內(nèi)存在4GB左右的服務(wù)器來(lái)說(shuō),該參數(shù)可設(shè)置為256MB或384MB。

注意:如果該參數(shù)值設(shè)置得過(guò)大反而會(huì)使服務(wù)器的整體效率降低!

read_buffer_size = 4M  #讀查詢操作所能使用的緩沖區(qū)大小。和sort_buffer_size一樣,該參數(shù)對(duì)應(yīng)的分配內(nèi)存也是每個(gè)連接獨(dú)享。

read_rnd_buffer_size = 16M #設(shè)置進(jìn)行隨機(jī)讀的時(shí)候所使用的緩沖區(qū)。此參數(shù)和read_buffer_size所設(shè)置的Buffer相反,一個(gè)是順序讀的時(shí)候使用,一個(gè)是隨機(jī)讀的時(shí)候使用。但是兩者都是針對(duì)與線程的設(shè)置,每個(gè)線程都可以產(chǎn)生兩種Buffer中的任何一個(gè)。默認(rèn)值256KB,最大值4GB。

bulk_insert_buffer_size = 8M  #如果經(jīng)常性的需要使用批量插入的特殊語(yǔ)句來(lái)插入數(shù)據(jù),可以適當(dāng)調(diào)整參數(shù)至16MB~32MB,建議8MB。

#myisam_sort_buffer_size = 8M #設(shè)置在REPAIR Table或用Create index創(chuàng)建索引或 Alter table的過(guò)程中排序索引所分配的緩沖區(qū)大小,可設(shè)置范圍4Bytes至4GB,默認(rèn)為8MB

lower_case_table_names = 1  #實(shí)現(xiàn)MySQL不區(qū)分大小。(發(fā)開(kāi)需求-建議開(kāi)啟)

slave-skip-errors = 1032,1062 #從庫(kù)可以跳過(guò)的錯(cuò)誤數(shù)字值(mysql錯(cuò)誤以數(shù)字代碼反饋,全的mysql錯(cuò)誤代碼大全,以后會(huì)發(fā)布至博客)。

replicate-ignore-db=mysql  #在做主從的情況下,設(shè)置不需要同步的庫(kù)。

server-id = 1  #表示本機(jī)的序列號(hào)為1,如果做主從,或者多實(shí)例,serverid一定不能相同。

myisam_sort_buffer_size = 128M  #當(dāng)需要對(duì)于執(zhí)行REPAIR, OPTIMIZE, ALTER 語(yǔ)句重建索引時(shí),MySQL會(huì)分配這個(gè)緩存,以及LOAD DATA INFILE會(huì)加載到一個(gè)新表,它會(huì)根據(jù)最大的配置認(rèn)真的分配的每個(gè)線程。 

myisam_max_sort_file_size = 10G #當(dāng)重新建索引(REPAIR,ALTER,TABLE,或者LOAD,DATA,TNFILE)時(shí),MySQL被允許使用臨時(shí)文件的最大值。

myisam_repair_threads = 1 #如果一個(gè)表?yè)碛谐^(guò)一個(gè)索引, MyISAM 可以通過(guò)并行排序使用超過(guò)一個(gè)線程去修復(fù)他們.

myisam_recover #自動(dòng)檢查和修復(fù)沒(méi)有適當(dāng)關(guān)閉的 MyISAM 表.

innodb_additional_mem_pool_size = 4M #用來(lái)設(shè)置InnoDB存儲(chǔ)的數(shù)據(jù)目錄信息和其他內(nèi)部數(shù)據(jù)結(jié)構(gòu)的內(nèi)存池大小。應(yīng)用程序里的表越多,你需要在這里面分配越多的內(nèi)存。對(duì)于一個(gè)相對(duì)穩(wěn)定的應(yīng)用,這個(gè)參數(shù)的大小也是相對(duì)穩(wěn)定的,也沒(méi)有必要預(yù)留非常大的值。如果InnoDB用廣了這個(gè)池內(nèi)的內(nèi)存,InnoDB開(kāi)始從操作系統(tǒng)分配內(nèi)存,并且往MySQL錯(cuò)誤日志寫警告信息。默認(rèn)為1MB,當(dāng)發(fā)現(xiàn)錯(cuò)誤日志中已經(jīng)有相關(guān)的警告信息時(shí),就應(yīng)該適當(dāng)?shù)脑黾釉搮?shù)的大小。

innodb_buffer_pool_size = 64M #InnoDB使用一個(gè)緩沖池來(lái)保存索引和原始數(shù)據(jù),設(shè)置越大,在存取表里面數(shù)據(jù)時(shí)所需要的磁盤I/O越少。強(qiáng)烈建議不要武斷地將InnoDB的Buffer Pool值配置為物理內(nèi)存的50%~80%,應(yīng)根據(jù)具體環(huán)境而定。

innodb_data_file_path = ibdata1:128M:autoextend  #設(shè)置配置一個(gè)可擴(kuò)展大小的尺寸為128MB的單獨(dú)文件,名為ibdata1.沒(méi)有給出文件的位置,所以默認(rèn)的是在MySQL的數(shù)據(jù)目錄內(nèi)。

innodb_file_io_threads = 4  #InnoDB中的文件I/O線程。通常設(shè)置為4,如果是windows可以設(shè)置更大的值以提高磁盤I/O

innodb_thread_concurrency = 8 #你的服務(wù)器有幾個(gè)CPU就設(shè)置為幾,建議用默認(rèn)設(shè)置,一般設(shè)為8。

innodb_flush_log_at_trx_commit = 1 #設(shè)置為0就等于innodb_log_buffer_size隊(duì)列滿后在統(tǒng)一存儲(chǔ),默認(rèn)為1,也是最安全的設(shè)置。

innodb_log_buffer_size = 2M  #默認(rèn)為1MB,通常設(shè)置為8~16MB就足夠了。

innodb_log_file_size = 32M  #確定日志文件的大小,更大的設(shè)置可以提高性能,但也會(huì)增加恢復(fù)數(shù)據(jù)庫(kù)的時(shí)間。

innodb_log_files_in_group = 3 #為提高性能,MySQL可以以循環(huán)方式將日志文件寫到多個(gè)文件。推薦設(shè)置為3。

innodb_max_dirty_pages_pct = 90 #InnoDB主線程刷新緩存池中的數(shù)據(jù)。

innodb_lock_wait_timeout = 120 #InnoDB事務(wù)被回滾之前可以等待一個(gè)鎖定的超時(shí)秒數(shù)。InnoDB在它自己的鎖定表中自動(dòng)檢測(cè)事務(wù)死鎖并且回滾事務(wù)。InnoDB用locak tables 語(yǔ)句注意到鎖定設(shè)置。默認(rèn)值是50秒。

innodb_file_per_table = 0  #InnoDB為獨(dú)立表空間模式,每個(gè)數(shù)據(jù)庫(kù)的每個(gè)表都會(huì)生成一個(gè)數(shù)據(jù)空間。0關(guān)閉,1開(kāi)啟。

[mysqldump]

quick

max_allowed_packet = 2M  #設(shè)定在網(wǎng)絡(luò)傳輸中一次消息傳輸量的最大值。系統(tǒng)默認(rèn)值為1MB,最大值是1GB,必須設(shè)置為1024的倍數(shù)。單位為字節(jié)。

總結(jié)

以上為個(gè)人經(jīng)驗(yàn),希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。

相關(guān)文章

最新評(píng)論