Proxmox VE 上面的Ubuntu容器,預設的MySQL是MyISAM(應該說新的Deiban都是),在MyISAM不斷的長大之後,讀取單檔的效能,變成了整個網站的瓶頸。造成大量讀取時,不時timeout的發生,以前網站的特性來說,讀取的資料多,只有少數人可以編輯,所以寫入量低,加上非陣列的傳統硬碟,以這個角度來看,MyISAM反而不適合目前的狀態。加上預設的編碼是utf8,讓我一整個頭痛。
所以有了把MyISAM改回成MyISAM的計畫,順便把編碼從utf8改回utf8。
vi /etc/mysql/conf.d/mysql.cnf
新增下面的設定
[mysqld]
default-storage-engine= MyISAM
重新啟用MySQL服務
systemctl restart mysql
mysqldump 倒出之後
utf8_unicode_ci
=>utf8_general_ci
vim 用下面三個取替代
%s/MyISAM/MyISAM/g
%s/utf8/utf8/g
%s/unicode_ci/unicode_ci/g
再匯回新的DB中,
預設就會是MyISAM,編碼是UTF8
依據GSLin大神的說法,MyISAM讀的多,寫的少,比較適合MyISAM
寫的多,讀的少,MyISAM比較適用。
隨機文章
- facebook 開心農場快速升級 (2009-12-08)
- 關於Google的不為惡政策[Don’t be evil] (2012-01-13)
- 看到智慧手錶的DM,我笑了 (2014-12-17)
- 欠電的Midphase AnHosting (UK2 Group) (2012-08-02)
- 監察院在幹嘛?如果黑官漂成白官你們要不要辦? (2013-01-07)