我們讀一下 MySQL 的文檔,關(guān)于 table_open_cache 的建議值公式:建議值 = 最大并發(fā)數(shù) * join 語句涉及的表的最大個(gè)數(shù)。通過實(shí)驗(yàn)我們?nèi)菀桌斫猓簍able_cache 是針對(duì)于線程的,所以需要最大并發(fā)數(shù)個(gè)緩存。
讓客戶滿意是我們工作的目標(biāo),不斷超越客戶的期望值來自于我們對(duì)這個(gè)行業(yè)的熱愛。我們立志把好的技術(shù)通過有效、簡(jiǎn)單的方式提供給客戶,將通過不懈努力成為客戶在信息化領(lǐng)域值得信任、有價(jià)值的長(zhǎng)期合作伙伴,公司提供的服務(wù)項(xiàng)目有:域名注冊(cè)、虛擬主機(jī)、營(yíng)銷軟件、網(wǎng)站建設(shè)、玉田網(wǎng)站維護(hù)、網(wǎng)站推廣。
有3個(gè)配置參數(shù)是最重要的,即key_buffer_size,query_cache_size,table_cache。key_buffer_size只對(duì)MyISAM表起作用,key_buffer_size指定索引緩沖區(qū)的大小,它決定索引處理的速度,尤其是索引讀的速度。
MySQL 默認(rèn)使用的是 glibc 的 ptmalloc 作為內(nèi)存分配器。內(nèi)存分配器采用的是內(nèi)存池的管理方式,處在用戶程序?qū)雍蛢?nèi)核層之間,它響應(yīng)用戶的分配請(qǐng)求,向操作系統(tǒng)申請(qǐng)內(nèi)存,然后將其返回給用戶程序。
如果你跑的是MySQL 6或7,你不需要更改innodb_stats_on_metadata的默認(rèn)值,因?yàn)樗呀?jīng)設(shè)置正確了。
table_cache = 614K sort_buffer_size = 6M 查詢排序時(shí)所能使用的緩沖區(qū)大小。注意:該參數(shù)對(duì)應(yīng)的分配內(nèi)存是每連接獨(dú)占,如果有100個(gè)連接,那么實(shí)際分配的總共排序緩沖區(qū)大小為100 × 6 = 600MB。
MySQL優(yōu)化 通過在網(wǎng)絡(luò)上查找資料和自己的嘗試,我認(rèn)為以下系統(tǒng)參數(shù)是比較關(guān)鍵的: (1)、back_log: 要求 MySQL 能有的連接數(shù)量。
案例一:大學(xué)有段時(shí)間學(xué)習(xí)爬蟲,爬取了知乎300w用戶答題數(shù)據(jù),存儲(chǔ)到mysql數(shù)據(jù)中。那時(shí)不了解索引,一條簡(jiǎn)單的“根據(jù)用戶名搜索全部回答的sql“需要執(zhí)行半分鐘左右,完全滿足不了正常的使用。
選取最適用的字段屬性。MySQL可以很好的支持大數(shù)據(jù)量的存取,但是一般說來,數(shù)據(jù)庫中的表越小,在它上面執(zhí)行的查詢也就會(huì)越快。因此,在創(chuàng)建表的時(shí)候,為了獲得更好的性能,我們可以將表中字段的寬度設(shè)得盡可能小。
添加主鍵ID盡量避免使用select * form table創(chuàng)建索引 對(duì)于查詢占主要的應(yīng)用來說,索引顯得尤為重要。很多時(shí)候性能問題很簡(jiǎn)單的就是因?yàn)槲覀兺颂砑铀饕斐傻?,或者說沒有添加更為有效的索引導(dǎo)致。
1、mysql的最大連接數(shù)可以通過設(shè)置max_connections的值來更新,具體操作如下。執(zhí)行如下命令登錄mysql。mysql -uroot -p說明:-uroot指明登錄用戶為root,-p需要密碼驗(yàn)證。登錄后執(zhí)行如下sql語句,設(shè)置max_connections的值。
2、mysql配置 如果你的系統(tǒng)出現(xiàn)“too many connections”的錯(cuò)誤, 你可以嘗試修改mysql的max_connections屬性。
3、第二種:修改配置文件。這 種方式說來很簡(jiǎn)單,只要修改MySQL配置文件my.ini 或 my點(diǎn)吸煙 f的參數(shù)max_connections,將其改為max_connections=1000,然后重啟MySQL即可。但是有一點(diǎn)最難的就是my.ini這個(gè)文件在哪找。
4、使用索引 索引是提高數(shù)據(jù)庫性能的常用方法,它可以令數(shù)據(jù)庫服務(wù)器以比沒有索引快得多的速度檢索特定的行,尤其是在查詢語句當(dāng)中包含有MAX(),MIN()和ORDERBY這些命令的時(shí)候,性能提高更為明顯。
5、為了設(shè)置合理的MySQL參數(shù),需要根據(jù)實(shí)際情況和使用場(chǎng)景來進(jìn)行調(diào)整。通常而言,你應(yīng)該關(guān)注以下幾個(gè)方面:連接數(shù)量: 在MySQL中有一個(gè)max_connections參數(shù),用于限制MySQL服務(wù)器能夠同時(shí)支持的客戶端連接數(shù)。
6、max_connections 這是Web服務(wù)器允許的最大連接數(shù),記住每個(gè)連接都要使用會(huì)話內(nèi)存(關(guān)于會(huì)話內(nèi)存,文章后面有涉及)。
1、調(diào)整緩存:MySQL有多個(gè)緩存機(jī)制,包括查詢緩存、表緩存和連接池等。調(diào)整這些緩存可以提高M(jìn)ySQL的性能。例如,增加查詢緩存的大小可以提高查詢速度。 調(diào)整服務(wù)器參數(shù):可以通過調(diào)整MySQL服務(wù)器參數(shù)來優(yōu)化性能。
2、選取最適用的字段屬性。MySQL可以很好的支持大數(shù)據(jù)量的存取,但是一般說來,數(shù)據(jù)庫中的表越小,在它上面執(zhí)行的查詢也就會(huì)越快。因此,在創(chuàng)建表的時(shí)候,為了獲得更好的性能,我們可以將表中字段的寬度設(shè)得盡可能小。
3、關(guān)于 MySQL 調(diào)優(yōu)有 3 種方法可以加快 MySQL 服務(wù)器的運(yùn)行速度,效率從低到高依次為:替換有問題的硬件。 對(duì) MySQL 進(jìn)程的設(shè)置進(jìn)行調(diào)優(yōu)。 對(duì)查詢進(jìn)行優(yōu)化。
4、選取最適用的字段屬性 MySQL可以很好的支持大數(shù)據(jù)量的存取,但是一般說來,數(shù)據(jù)庫中的表越小,在它上面執(zhí)行的查詢也就會(huì)越快。因此,在創(chuàng)建表的時(shí)候,為了獲得更好的性能,我們可以將表中字段的寬度設(shè)得盡可能小。
5、這樣,我們又可以提高數(shù)據(jù)庫的性能。使用連接(JOIN)來代替子查詢(Sub-Queries)MySQL 從1開始支持SQL的子查詢。這個(gè)技術(shù)可以使用SELECT語句來創(chuàng)建一個(gè)單列的查詢結(jié)果,然后把這個(gè)結(jié)果作為過濾條件用在另一個(gè)查詢中。
MySQL優(yōu)化 通過在網(wǎng)絡(luò)上查找資料和自己的嘗試,我認(rèn)為以下系統(tǒng)參數(shù)是比較關(guān)鍵的: (1)、back_log: 要求 MySQL 能有的連接數(shù)量。
從外在條件來說,優(yōu)化mysql涉及優(yōu)化硬件、優(yōu)化磁盤、優(yōu)化操作系統(tǒng)、選擇應(yīng)用編程接口等。優(yōu)化硬件 如果你需要龐大的數(shù)據(jù)庫表(2G),你應(yīng)該考慮使用64位的硬件結(jié)構(gòu),像Alpha、Sparc或即將推出的IA64。
索引的優(yōu)點(diǎn) 合適的索引,可以大大減小mysql服務(wù)器掃描的數(shù)據(jù)量,避免內(nèi)存排序和臨時(shí)表,提高應(yīng)用程序的查詢性能。
1、第二種方法是對(duì) MySQL 服務(wù)器(也稱為 mysqld)進(jìn)行調(diào)優(yōu)。對(duì)這個(gè)進(jìn)程進(jìn)行調(diào)優(yōu)意味著適當(dāng)?shù)胤峙鋬?nèi)存,并讓 mysqld 了解將會(huì)承受何種類型的負(fù)載。加快磁盤運(yùn)行速度不如減少所需的磁盤訪問次數(shù)。
2、第一個(gè)是標(biāo)準(zhǔn)配置,第二個(gè)是自定義配置。配置解讀:是否將mysql安裝為windows的服務(wù),我們要勾選服務(wù)名稱:不需要修改,默認(rèn)就可以是否自動(dòng)啟動(dòng)mysql,可以根據(jù)自己的需要選擇,我選擇的是手動(dòng),所以不勾選。
3、盡管你可以調(diào)整非常多的MySQL服務(wù)器變量,但是在通常情況下只有少數(shù)的變量是真正重要的。在你設(shè)置完這些變量以后,其他變量的改動(dòng)通常只能帶來相對(duì)有限的性能改善。key_buffer_size --- 非常重要,如果你使用MyISAM表。
4、選取最適用的字段屬性。MySQL可以很好的支持大數(shù)據(jù)量的存取,但是一般說來,數(shù)據(jù)庫中的表越小,在它上面執(zhí)行的查詢也就會(huì)越快。因此,在創(chuàng)建表的時(shí)候,為了獲得更好的性能,我們可以將表中字段的寬度設(shè)得盡可能小。
5、(2)、interactive_timeout: 服務(wù)器在關(guān)閉它前在一個(gè)交互連接上等待行動(dòng)的秒數(shù)。一個(gè)交互的客戶被定義為對(duì) mysql_real_connect()使用 CLIENT_INTERACTIVE 選項(xiàng)的客戶。 默認(rèn)數(shù)值是28800,我把它改為7200。