西西軟件園多重安全檢測(cè)下載網(wǎng)站、值得信賴的軟件下載站!
軟件
軟件
文章
搜索

首頁西西教程數(shù)據(jù)庫教程 → 使用PHP+mysq建立完美站點(diǎn)需要注意的幾個(gè)關(guān)鍵參數(shù)配置

使用PHP+mysq建立完美站點(diǎn)需要注意的幾個(gè)關(guān)鍵參數(shù)配置

相關(guān)軟件相關(guān)文章發(fā)表評(píng)論 來源:本站整理時(shí)間:2010/8/6 13:39:03字體大小:A-A+

作者:佚名點(diǎn)擊:461次評(píng)論:0次標(biāo)簽: PHP

  • 類型:服務(wù)器區(qū)大。21M語言:中文 評(píng)分:7.5
  • 標(biāo)簽:
立即下載

以下的文章主要是對(duì)MySQL性能影響關(guān)系緊密的五大配置參數(shù)的介紹,我前幾天在相關(guān)網(wǎng)站看見對(duì)MySQL性能影響關(guān)系緊密的五大配置參數(shù)的資料,覺得挺好,就拿出來供大家分享,望你能有所收獲。

  (一)連接

  連接通常來自Web服務(wù)器,下面列出了一些與連接有關(guān)的參數(shù),以及該如何設(shè)置它們。

  1、max_connections

  這是Web服務(wù)器允許的最大連接數(shù),記住每個(gè)連接都要使用會(huì)話內(nèi)存(關(guān)于會(huì)話內(nèi)存,文章后面有涉及)。

  2、max_packet_allowed

  最大數(shù)據(jù)包大小,通常等于你需要在一個(gè)大塊中返回的最大數(shù)據(jù)集的大小,如果你在使用遠(yuǎn)程mysqldump,那它的值需要更大。

  3、aborted_connects

  檢查系統(tǒng)狀態(tài)的計(jì)數(shù)器,確定其沒有增長,如果數(shù)量增長說明客戶端連接時(shí)遇到了錯(cuò)誤。

  4、thread_cache_size

  入站連接會(huì)在MySQL中創(chuàng)建一個(gè)新的線程,因?yàn)镸ySQL中打開和關(guān)閉連接都很廉價(jià),速度也快,它就沒有象其它數(shù)據(jù)庫,如Oracle那么多持續(xù)連接了,但線程預(yù)先創(chuàng)建并不會(huì)節(jié)約時(shí)間,這就是為什么要MySQL線程緩存的原因了。

  如果在增長請(qǐng)密切注意創(chuàng)建的線程,讓你的線程緩存更大,對(duì)于2550或100的thread_cache_size,內(nèi)存占用也不多。

  (二)查詢緩存

  (三)臨時(shí)表

  內(nèi)存速度是相當(dāng)快的,因此我們希望所有的排序操作都在內(nèi)存中進(jìn)行,我們可以通過調(diào)整查詢讓結(jié)果集更小以實(shí)現(xiàn)內(nèi)存排序,或?qū)⒆兞吭O(shè)置得更大。

  tmp_table_size

  max_heap_table_size

  無論何時(shí)在MySQL中創(chuàng)建臨時(shí)表,它都會(huì)使用這兩個(gè)變量的最小值作為臨界值,除了在磁盤上構(gòu)建臨時(shí)表外,還會(huì)創(chuàng)建許多會(huì)話,這些會(huì)話會(huì)搶占有 限制的資源,因此最好是調(diào)整查詢而不是將這些參數(shù)設(shè)置得更高,同時(shí),需要注意的是有BLOB或TEXT字段類型的表將直接寫入磁盤。 深入淺出MySQL雙向復(fù)制技術(shù)

  (四)會(huì)話內(nèi)存

  MySQL中每個(gè)會(huì)話都有其自己的內(nèi)存,這個(gè)內(nèi)存就是分配給SQL查詢的內(nèi)存,因此你想讓它變得盡可能大以滿足需要。但你不得不平衡同一時(shí)間數(shù) 據(jù)庫內(nèi)一致性會(huì)話的數(shù)量。這里顯得有點(diǎn)黑色藝術(shù)的是MySQL是按需分配緩存的,因此,你不能只添加它們并乘以會(huì)話的數(shù)量,這樣估算下來比MySQL典型 的使用要大得多。

  最佳做法是啟動(dòng)MySQL,連接所有會(huì)話,然后繼續(xù)關(guān)注頂級(jí)會(huì)話的VIRT列,mysqld行的數(shù)目通常保持相對(duì)穩(wěn)定,這就是實(shí)際的內(nèi)存 總用量,減去所有的靜態(tài)MySQL內(nèi)存區(qū)域,就得到了實(shí)際的所有會(huì)話內(nèi)存,然后除以會(huì)話的數(shù)量就得到平均值。

  1、read_buffer_size

  緩存連續(xù)掃描的塊,這個(gè)緩存是跨存儲(chǔ)引擎的,不只是MyISAM表。

  2、sort_buffer_size

  執(zhí)行排序緩存區(qū)的大小,最好將其設(shè)置為1M-2M,然后在會(huì)話中設(shè)置,為一個(gè)特定的查詢?cè)O(shè)置更高的值。

  3、join_buffer_size

  執(zhí)行聯(lián)合查詢分配的緩存區(qū)大小,將其設(shè)置為1M-2M大小,然后在每個(gè)會(huì)話中再單獨(dú)按需設(shè)置。

  4、read_rnd_buffer_size

  用于排序和order by操作,最好將其設(shè)置為1M,然后在會(huì)話中可以將其作為一個(gè)會(huì)話變量設(shè)置為更大的值。

  (五)慢速查詢?nèi)罩?/p>

  慢速查詢?nèi)罩臼荕ySQL很有用的一個(gè)特性。

  1、log_slow_queries

  MySQL參數(shù)中l(wèi)og_slow_queries參數(shù)在my.cnf文件中設(shè)置它,將其設(shè)置為on,默認(rèn)情況下,MySQL會(huì)將文件放到數(shù)據(jù)目錄,文件以“主機(jī)名-slow.log”的形式命名,但你在設(shè)置這個(gè)選項(xiàng)的時(shí)候也可以為其指定一個(gè)名字。

  2、long_query_time

  默認(rèn)值是10秒,你可以動(dòng)態(tài)設(shè)置它,值從1到將其設(shè)置為on,如果數(shù)據(jù)庫啟動(dòng)了,默認(rèn)情況下,日志將關(guān)閉。截至5.1.21和安裝了 Google補(bǔ)丁的版本,這個(gè)選項(xiàng)可以以微秒設(shè)置,這是一個(gè)了不起的功能,因?yàn)橐坏┠阆怂胁樵儠r(shí)間超過1秒的查詢,說明調(diào)整非常成功,這樣可以幫助 你在問題變大之前消除問題SQL。

  3、log_queries_not_using_indexes

  開啟這個(gè)選項(xiàng)是個(gè)不錯(cuò)的主意,它真實(shí)地記錄了返回所有行的查詢。

  小結(jié)

  我們介紹了MySQL參數(shù)的五大類設(shè)置,平時(shí)我們一般都很少碰它們,在進(jìn)行MySQL性能調(diào)優(yōu)和故障診斷時(shí)這些參數(shù)還是非常有用的。

  MySQL中的緩存查詢包括兩個(gè)解析查詢計(jì)劃,以及返回的數(shù)據(jù)集,如果基礎(chǔ)表數(shù)據(jù)或結(jié)構(gòu)有變化,將會(huì)使查詢緩存中的項(xiàng)目無效。

  1、query_cache_min_res_unit

  MySQL參數(shù)中query_cache_min_res_unit查詢緩存中的塊是以這個(gè)大小進(jìn)行分配的,使用下面的公式計(jì)算查詢緩存的平均大小,根據(jù)計(jì)算結(jié)果設(shè)置這個(gè)變量,MySQL就會(huì)更有效地使用查詢緩存,緩存更多的查詢,減少內(nèi)存的浪費(fèi)。

  2、query_cache_size

  這個(gè)參數(shù)設(shè)置查詢緩存的總大小。

  3、query_cache_limit

  這個(gè)參數(shù)告訴MySQL丟掉大于這個(gè)大小的查詢,一般大型查詢還是比較少見的,如運(yùn)行一個(gè)批處理執(zhí)行一個(gè)大型報(bào)表的統(tǒng)計(jì),因此那些大型結(jié)果集不應(yīng)該填滿查詢緩存。

  qcache hit ratio = qcache_hits / (qcache_hits + com_select)

  使用

  SQL> show status like ‘qcache%’; SQL> show status like ‘com_%’;

  找到這些變量。

  average query size = (query_cache_size – qcache_free_memory)/qcache_queries_in_cache

  使用

  SQL> show variables like ‘query%’; qcache_* status variables you can get with: SQL> show status like ‘qcache%’;

  獲取query_cache_size的值。

    相關(guān)評(píng)論

    閱讀本文后您有什么感想? 已有人給出評(píng)價(jià)!

    • 8 喜歡喜歡
    • 3 頂
    • 1 難過難過
    • 5 囧
    • 3 圍觀圍觀
    • 2 無聊無聊

    熱門評(píng)論

    最新評(píng)論

    發(fā)表評(píng)論 查看所有評(píng)論(0)

    昵稱:
    表情: 高興 可 汗 我不要 害羞 好 下下下 送花 屎 親親
    字?jǐn)?shù): 0/500 (您的評(píng)論需要經(jīng)過審核才能顯示)