Kilka miesięcy temu odkryłem mongodbę, a po przeczytaniu tego post, pomyślałem, że mongodb jest naprawdę szybszy od mysql, więc postanowiłem zbudować własną ławkę, problemem jest to, że nie mam tego samego wyniku, co autor powyższego posta, szczególnie w przypadku kwarantanny bazy danych: mongodb wydaje się wolniejszy niż tablice MyISAM. Można mieć wygląd mojego kodu Pythona, może coś jest nie tak w tym:MongoDB nie jest szybszy od MySQL?
from datetime import datetime
import random
import MySQLdb
import pymongo
mysql_db=MySQLdb.connect(user="me",passwd="mypasswd",db="test_kv")
c=mysql_db.cursor()
connection = pymongo.Connection()
mongo_db = connection.test
kvtab = mongo_db.kvtab
nb=1000000
thelist=[]
for i in xrange(nb):
thelist.append((str(random.random()),str(random.random())))
t1=datetime.now()
for k,v in thelist:
c.execute("INSERT INTO key_val_tab (k,v) VALUES ('" + k + "','" + v + "')")
dt=datetime.now() - t1
print 'MySQL insert elapse :',dt
t1=datetime.now()
for i in xrange(nb):
c.execute("select * FROM key_val_tab WHERE k='" + random.choice(thelist)[0] + "'")
result=c.fetchone()
dt=datetime.now() - t1
print 'MySQL select elapse :',dt
t1=datetime.now()
for k,v in thelist:
kvtab.insert({"key":k,"value":v})
dt=datetime.now() - t1
print 'Mongodb insert elapse :',dt
kvtab.ensure_index('key')
t1=datetime.now()
for i in xrange(nb):
result=kvtab.find_one({"key":random.choice(thelist)[0]})
dt=datetime.now() - t1
print 'Mongodb select elapse :',dt
Uwagi:
- zarówno MySQL i MongoDB są na locahost.
- zarówno MySQL i MongoDB posiada 'klucz' kolumna indeksowane
MySQL:
CREATE TABLE IF NOT EXISTS `key_val_tab` (
`k` varchar(24) NOT NULL,
`v` varchar(24) NOT NULL,
KEY `kindex` (`k`)
) ENGINE=MyISAM DEFAULT CHARSET=latin1;
wersjach:
- MySQL: 5.1.41
- MongoDB: 1,8 .3
- python: 2.6.5
- pymongo: 2.0.1
- Linux: Ubuntu 2.6.32 32-bitowego z PAE
- Wyposażenie: Pulpit rdzeń i7 2,93 GHz
Wyniki (na 1 milion/wybiera wkładki):
MySQL insert elapse : 0:02:52.143803
MySQL select elapse : 0:04:43.675914
Mongodb insert elapse : 0:00:49.038416 -> mongodb much faster for insert
Mongodb select elapse : 0:05:10.409025 -> ...but slower for quering (thought was the opposite)
Po pierwsze, MongoDB lubi architekturę 64-bitową. Nie postawiłbym zbyt wiele w benchmarku prowadzonym przez kogoś, kto nie jest bardzo doświadczony w testowaniu jednego z systemów. – ceejayoz
dlatego poprosiłem o pomoc! – Eric
@ceejayoz Jeśli musisz być bardzo doświadczony, aby przyspieszyć, będzie on powolny dla większości użytkowników. Powiedziałbym, że testy porównawcze wykonane przez niedoświadczonych użytkowników mogą być równie użyteczne ... –