日韩无码专区无码一级三级片|91人人爱网站中日韩无码电影|厨房大战丰满熟妇|AV高清无码在线免费观看|另类AV日韩少妇熟女|中文日本大黄一级黄色片|色情在线视频免费|亚洲成人特黄a片|黄片wwwav色图欧美|欧亚乱色一区二区三区

RELATEED CONSULTING
相關(guān)咨詢
選擇下列產(chǎn)品馬上在線溝通
服務(wù)時間:8:30-17:00
你可能遇到了下面的問題
關(guān)閉右側(cè)工具欄

新聞中心

這里有您想知道的互聯(lián)網(wǎng)營銷解決方案
MySQL優(yōu)化的三個小秘訣

MySQL性能優(yōu)化就是通過合理安排資源,調(diào)整系統(tǒng)參數(shù)使MySQL運行更快、更節(jié)省資源,本篇文章為大家分享一下MySQL優(yōu)化的三個小秘訣。

網(wǎng)站建設(shè)哪家好,找成都創(chuàng)新互聯(lián)公司!專注于網(wǎng)頁設(shè)計、網(wǎng)站建設(shè)、微信開發(fā)、微信小程序定制開發(fā)、集團企業(yè)網(wǎng)站建設(shè)等服務(wù)項目。為回饋新老客戶創(chuàng)新互聯(lián)還提供了官渡免費建站歡迎大家使用!

警告

1.沒有兩個數(shù)據(jù)庫或者應(yīng)用程序是完全相同的。這里假設(shè)我們要調(diào)整的數(shù)據(jù)庫是為一個“典型”的 Web 網(wǎng)站服務(wù)的,優(yōu)先考慮的是快速查詢、良好的用戶體驗以及處理大量的流量。

2.在你對服務(wù)器進行優(yōu)化之前,請做好數(shù)據(jù)庫備份!

1、使用 InnoDB 存儲引擎

如果你還在使用 MyISAM 存儲引擎,那么是時候轉(zhuǎn)換到 InnoDB 了。有很多的理由都表明 InnoDB 比 MyISAM 更有優(yōu)勢,如果你關(guān)注性能,那么,我們來看一下它們是如何利用物理內(nèi)存的:

MyISAM:僅在內(nèi)存中保存索引。

InnoDB:在內(nèi)存中保存索引和數(shù)據(jù)。

結(jié)論:保存在內(nèi)存的內(nèi)容訪問速度要比磁盤上的更快。

下面是如何在你的表上去轉(zhuǎn)換存儲引擎的命令:

ALTER TABLE table_name ENGINE=InnoDB;

注意:你已經(jīng)創(chuàng)建了所有合適的索引,對嗎?為了更好的性能,創(chuàng)建索引永遠(yuǎn)是第一優(yōu)先考慮的事情。

2、讓 InnoDB 使用所有的內(nèi)存

你可以在 my.cnf 文件中編輯你的 MySQL 配置。使用 innodb_buffer_pool_size 參數(shù)去配置在你的服務(wù)器上允許 InnoDB 使用物理內(nèi)存數(shù)量。

對此(假設(shè)你的服務(wù)器僅僅運行 MySQL),公認(rèn)的“經(jīng)驗法則”是設(shè)置為你的服務(wù)器物理內(nèi)存的 80%。在保證操作系統(tǒng)不使用交換分區(qū)而正常運行所需要的足夠內(nèi)存之后 ,盡可能多地為 MySQL 分配物理內(nèi)存。

因此,如果你的服務(wù)器物理內(nèi)存是 32 GB,可以將那個參數(shù)設(shè)置為多達(dá) 25 GB。

innodb_buffer_pool_size = 25600M

注意:(1)如果你的服務(wù)器內(nèi)存較小并且小于 1 GB。為了適用本文的方法,你應(yīng)該去升級你的服務(wù)器。 (2) 如果你的服務(wù)器內(nèi)存特別大,比如,它有 200 GB,那么,根據(jù)一般常識,你也沒有必要為操作系統(tǒng)保留多達(dá) 40 GB 的內(nèi)存。

3、讓 InnoDB 多任務(wù)運行

如果服務(wù)器上的參數(shù) innodb_buffer_pool_size 的配置是大于 1 GB,將根據(jù)參數(shù) innodb_buffer_pool_instances 的設(shè)置, 將 InnoDB 的緩沖池劃分為多個。

擁有多于一個的緩沖池的好處有:

在多線程同時訪問緩沖池時可能會遇到瓶頸。你可以通過啟用多緩沖池來最小化這種爭用情況:

對于緩沖池數(shù)量的官方建議是:

為了實現(xiàn)最佳的效果,要綜合考慮 innodb_buffer_pool_instances 和 innodb_buffer_pool_size 的設(shè)置,以確保每個實例至少有不小于 1 GB 的緩沖池。

因此,在我們的示例中,將參數(shù) innodb_buffer_pool_size 設(shè)置為 25 GB 的擁有 32 GB 物理內(nèi)存的服務(wù)器上。一個合適的設(shè)置為 25600M / 24 = 1.06 GB

innodb_buffer_pool_instances = 24

注意

在修改了 my.cnf 文件后需要重啟 MySQL 才能生效:

sudo service mysql restart

還有更多更科學(xué)的方法來優(yōu)化這些參數(shù),但是這幾點可以作為一個通用準(zhǔn)則來應(yīng)用,將使你的 MySQL 服務(wù)器性能更好。


文章標(biāo)題:MySQL優(yōu)化的三個小秘訣
分享URL:http://www.5511xx.com/article/dheddod.html