測試程序:
CMS程序:帝國cms dedecms phpcms
論壇程序:discuz phpwind xiuno
負載測試結果:
xiuno > discuz > phpwind > phpcms > ( 帝國cms ? dedecms)
從數據庫設計來看(個人觀點):
xiuno > (discuz 、 phpwind 、 phpcms) > (帝國cms 、 dedecms)
dedecms和帝國cms都是老牌的CMS了,從的數據庫設計來看,不知是數據庫設計者完全沒有理解mysql索引的真諦,還是留一手以對高負載需求的用戶收費改進?(希望不懂技術的朋友不要噴我,真正懂mysql索引的朋友可以自己看一下他們對索引的設計,雖然對于dedecms和帝國cms的作者來說,我只是一個晚輩,像您們這樣有10多年開發(fā)經驗的人,我比較尊敬,但我建議當前的dedecms和帝國cms數據庫設計者還是再研究一下mysql索引吧,可以不相信我,但可以花點時間看看discuz 、phpwind的數據庫設計吧,確實是比您們的好)。
如果有幸帝國cms作者能看到此文,希望您再重新設計帝國cms架構吧,畢竟這些年您一直在改進帝國cms的負載能力,光是通過分表技術提升,沒有真正用到索引來優(yōu)化,真的不行的,如果用對了索引,性能還會有更大的提升。
dedecms的創(chuàng)始人我算是和他認識,但現(xiàn)在dedecms卻不是他的,比較遺憾,現(xiàn)在的dedecms這幾年確實沒多大變化,一直在打補丁,這樣下去真是比較悲劇。
我的測試環(huán)境:
i3CPU 4G內存 1T硬盤 win7系統(tǒng) apache 2.2 + mysql 5.0(普通環(huán)境沒有優(yōu)化過)
測試方法:
導入100萬至1億 不等數據,進行簡單的訪問測試
我的導入方法:
根據各個程序的數據結構寫出導入程序,
1.先寫一個PHP程序,將數據寫入 e:/insert1.sql 這個文件,
2.然后再通過 LOAD DATA local INFILE 'e:/insert1.sql' INTO TABLE `數據表名` character set 編碼; 這種方式導入的,導入千W數據也就幾分鐘。
1、帝國cms
測試版本:EmpireCMS_7.0_SC_GBK (當前官方最新版)
先說說帝國cms,官方有一篇大數據測試貼(2千萬數據、17.3GB數據庫下帝國CMS超強生成速度 ),當年我看到這篇測試貼時,也覺得負載非常強大,但我測試后,令我失望了。
安裝默認測試數據(共33篇新聞測試數據),首頁改為動態(tài)首頁 第一次訪問0.670127010345459 第二次訪問0.07926607131958
我導入100W數據時,數據庫大小3.6G,首頁第一次訪問182秒,第二次訪問155秒,我不知道當時帝國cms作者測試時,是否有測試過動態(tài)訪問首頁的時間。包括從6.0版起,每次更新都有說提升性能,但為何會這樣?
帝國CMS官方的測試帖,就是誤導人,忽悠人。
問題1.測試數據并沒有提到動態(tài)訪問首頁或是生成首頁。也沒有提到動態(tài)訪問列表頁,和生成列表頁。
問題2.測試統(tǒng)計的時間,也只統(tǒng)計了連接數據庫之后的執(zhí)行時間,并沒有加上連接數據庫的時間,這樣很容易誤導很多人,拿這個時間和別人統(tǒng)計了連接數據庫的時間比。這樣就差別大了。
問題3.每篇新聞的內容很少也就幾行字。同時內容頁模板,也非常簡單,生成出來的文件也非常小,只有3K。正常的文章,都是上10K至幾十K。
問題4.同時因為phome_ecms_news表 id 為主鍵,讀取內容時,都是走的索引,所以動態(tài)訪問內容頁,編輯內容,生成內容頁很快,都是理所當然的。
問題5.測試時都是通過分表來測試的,在真實站長做網站,不可能一開始就把網站內容分表。所以這和真實做站情況完全不一樣。
像官方這種測試貼,真是誤導人,而且還掛了幾年。對于不懂技術的人,就是一種誤導,讓普通用戶盲目的崇拜。
2、dedecms
測試版本:DedeCMS V5.7 SP1_GBK正式版 (當前官方最新版)
織夢CMS在知度CMS中一直公認的負載性能最差的CMS,確實很差。
我導入100W數據時,數據庫大小只有330M,首頁訪問已經需要70幾秒-80幾秒才能訪問。