欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

使用Python如何測試InnoDB與MyISAM的讀寫性能

 更新時間:2018年09月18日 09:19:30   作者:ChrisYZX  
網(wǎng)上有很多評論myisam和innodb讀寫性能對比,所以下面這篇文章主要給大家介紹了關(guān)于使用Python如何測試InnoDB與MyISAM讀寫性能的相關(guān)資料,文中通過圖文介紹的非常詳細(xì),需要的朋友可以參考下

前言

由于近期有個項(xiàng)目對系統(tǒng)性能要求很高,技術(shù)選型上由于種種原因已經(jīng)確定使用Mysql數(shù)據(jù)庫,接下來就是要確定到底使用哪種存儲引擎。我們的應(yīng)用是典型的寫多讀少,寫入內(nèi)容為也很短,對系統(tǒng)的穩(wěn)定性要求很高。所以存儲引擎肯定就定在廣泛使用的Innodb和MyISAM之中了。

至于兩者的比較網(wǎng)上也有很多,但是畢竟這個事情也不復(fù)雜,決定還是自己來做,去驗(yàn)證一下在我們的場景下誰更優(yōu)。

本文測試所用工具版本如下:

Tools Version
MySQL 5.7.18
Python 3.6
Pandas 0.23

① 創(chuàng)建數(shù)據(jù)表

首先我們需要把兩張使用了不同引擎的表創(chuàng)建出來,使用為了方便起見,我們直接使用Navicat創(chuàng)建了兩張 員工信息表,具體字段如下:

使用InnoDB引擎的表,設(shè)計(jì)表名為innodb,選項(xiàng)如下:

 

使用InnoDB引擎的表,設(shè)計(jì)表名為myisam,選項(xiàng)如下:

 

因?yàn)槭呛唵尾僮鳎瑒?chuàng)建的具體細(xì)節(jié)就不詳述了,至此,我們的數(shù)據(jù)庫就把使用 InnoDB 和 MyISAM 兩種引擎的表創(chuàng)建好了。

② 單線程寫入性能對比

1. InnoDB 引擎

執(zhí)行以下代碼,往使用了InnoDB引擎的表格插入1000條數(shù)據(jù)

import pandas as pd
from sqlalchemy import create_engine
import time

db = create_engine('mysql+pymysql://mysql:123456@127.0.0.1:3306/test')
start = time.time()

for i in range(1000):
 data = {'index': i,
   'name': 'name_' + str(i),
   'age': i,
   'salary': i,
   'level': i}
 df = pd.DataFrame(data, index=[0])
 df.to_sql('innodb', db, if_exists='append', index=False)

end = time.time()
print(end - start)

執(zhí)行3次上面的代碼,得到程序?qū)懭?000條數(shù)據(jù)的時間分別為:12.58s、14.10s、12.71s,平均寫入時間為 13.13s。

2. MyISAM 引擎

執(zhí)行以下代碼,往使用了MyISAM引擎的表格插入1000條數(shù)據(jù)

import pandas as pd
from sqlalchemy import create_engine
import time

db = create_engine('mysql+pymysql://mysql:123456@127.0.0.1:3306/test')
start = time.time()

for i in range(1000):
 data = {'index': i,
   'name': 'name_' + str(i),
   'age': i,
   'salary': i,
   'level': i}
 df = pd.DataFrame(data, index=[0])
 df.to_sql('myisam', db, if_exists='append', index=False)

end = time.time()
print(end - start)

執(zhí)行3次上面的代碼,得到程序?qū)懭?000條數(shù)據(jù)的時間分別為:6.64s、6.99s、7.29s,平均寫入時間為 6.97s。

兩種引擎的單線程寫入速度對比如下:

結(jié)論:單線程的情況下,MyISAM引擎的寫入速度比InnoDB引擎的寫入速度快88%

③ 多線程寫入性能對比

1. InnoDB 引擎

執(zhí)行以下代碼,往使用了InnoDB引擎的表格插入1000條數(shù)據(jù)

import pandas as pd
from sqlalchemy import create_engine
import time
from concurrent.futures import ThreadPoolExecutor

db = create_engine('mysql+pymysql://mysql:123456@127.0.0.1:3306/test')
start = time.time()

data_lst = [{'index': i,
    'name': 'name_' + str(i),
    'age': i,
    'salary': i,
    'level': i} for i in range(1000)]

def write(data):
 df = pd.DataFrame(data, index=[0])
 df.to_sql('innodb', db, if_exists='append', index=False)

def execute():
 with ThreadPoolExecutor(max_workers=5) as executor:
  executor.map(write, data_lst)

execute()

end = time.time()
print(end - start)

執(zhí)行3次上面的代碼,得到程序?qū)懭?000條數(shù)據(jù)的時間分別為:4.98s、4.84s、4.88s,平均寫入時間為 4.9s。

2. MyISAM 引擎

執(zhí)行以下代碼,往使用了MyISAM引擎的表格插入1000條數(shù)據(jù)

import pandas as pd
from sqlalchemy import create_engine
import time
from concurrent.futures import ThreadPoolExecutor

db = create_engine('mysql+pymysql://mysql:123456@127.0.0.1:3306/test')
start = time.time()

data_lst = [{'index': i,
    'name': 'name_' + str(i),
    'age': i,
    'salary': i,
    'level': i} for i in range(1000)]

def write(data):
 df = pd.DataFrame(data, index=[0])
 df.to_sql('myisam', db, if_exists='append', index=False)

def execute():
 with ThreadPoolExecutor(max_workers=5) as executor:
  executor.map(write, data_lst)

execute()

end = time.time()
print(end - start)

執(zhí)行3次上面的代碼,得到程序?qū)懭?000條數(shù)據(jù)的時間分別為:3.29s、3.62s、3.47s,平均寫入時間為 3.46s。

兩種引擎的多線程寫入速度對比如下:

結(jié)論:多線程的情況下,MyISAM引擎的寫入速度比InnoDB引擎的寫入速度快42%

④ 讀取性能對比

為了獲得數(shù)據(jù)量較大的表用于測試數(shù)據(jù)庫的讀取性能,我們循環(huán)執(zhí)行10遍上面多線程寫入數(shù)據(jù)的操作,得到兩張數(shù)據(jù)量為10000條數(shù)據(jù)的表格,然后讀取10遍該表格,獲取讀取時間

1. InnoDB 引擎

執(zhí)行以下代碼,讀取10遍使用了InnoDB引擎的表格

import pandas as pd
from sqlalchemy import create_engine
import time

db = create_engine('mysql+pymysql://mysql:123456@127.0.0.1:3306/test')
start = time.time()

for _ in range(10):
 df = pd.read_sql('innodb', db)

end = time.time()
print(end - start)

執(zhí)行3次上面的代碼,得到程序10次讀取10000條數(shù)據(jù)的時間分別為:28.94s、28.88s、28.48s,平均寫入時間為 28.77s。

2. MyISAM 引擎

執(zhí)行以下代碼,讀取10遍使用了MyISAM引擎的表格

import pandas as pd
from sqlalchemy import create_engine
import time

db = create_engine('mysql+pymysql://mysql:123456@127.0.0.1:3306/test')
start = time.time()

for _ in range(10):
 df = pd.read_sql('innodb', db)

end = time.time()
print(end - start)

執(zhí)行3次上面的代碼,得到程序10次讀取10000條數(shù)據(jù)的時間分別為:28.51s、29.12s、28.76s,平均寫入時間為 28.8s。

兩種引擎的讀取速度對比如下:

結(jié)論:MyISAM引擎和InnoDB引擎的讀取速度無明顯差異

⑤ 總結(jié)

1. 寫入速度,MyISAM比InnoDB快,單線程的情況下,兩者差異尤為明顯

2. 讀取速度,InnoDB和MyISAM無明顯差異

好了,以上就是這篇文章的全部內(nèi)容了,希望本文的內(nèi)容對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,如果有疑問大家可以留言交流,謝謝大家對腳本之家的支持。

相關(guān)文章

  • PyCharm軟件無法安裝lxml庫的問題及解決

    PyCharm軟件無法安裝lxml庫的問題及解決

    這篇文章主要介紹了PyCharm軟件無法安裝lxml庫的問題及解決,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2023-01-01
  • pytorch中的優(yōu)化器optimizer.param_groups用法

    pytorch中的優(yōu)化器optimizer.param_groups用法

    這篇文章主要介紹了pytorch中的優(yōu)化器optimizer.param_groups用法,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2021-05-05
  • python如何將圖片轉(zhuǎn)換為字符圖片

    python如何將圖片轉(zhuǎn)換為字符圖片

    這篇文章主要為大家詳細(xì)介紹了python將圖片轉(zhuǎn)換為字符圖片的方法,文中示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2018-03-03
  • Python 字節(jié)流,字符串,十六進(jìn)制相互轉(zhuǎn)換實(shí)例(binascii,bytes)

    Python 字節(jié)流,字符串,十六進(jìn)制相互轉(zhuǎn)換實(shí)例(binascii,bytes)

    這篇文章主要介紹了Python 字節(jié)流,字符串,十六進(jìn)制相互轉(zhuǎn)換實(shí)例(binascii,bytes),具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2020-05-05
  • Python實(shí)現(xiàn)DBSCAN聚類算法并樣例測試

    Python實(shí)現(xiàn)DBSCAN聚類算法并樣例測試

    聚類是一種機(jī)器學(xué)習(xí)技術(shù),它涉及到數(shù)據(jù)點(diǎn)的分組,聚類是一種無監(jiān)督學(xué)習(xí)的方法,是許多領(lǐng)域中常用的統(tǒng)計(jì)數(shù)據(jù)分析技術(shù)。本文給大家分享Python實(shí)現(xiàn)DBSCAN聚類算法并樣例測試,感興趣的朋友一起看看吧
    2021-06-06
  • 詳解Python 中的短路評估

    詳解Python 中的短路評估

    短路是指當(dāng)表達(dá)式的真值已經(jīng)確定時終止布爾運(yùn)算,Python 解釋器以從左到右的方式計(jì)算表達(dá)式,這篇文章主要介紹了Python 中的短路評估,需要的朋友可以參考下
    2023-06-06
  • 一文帶你掌握Python中的雙下劃線寫法

    一文帶你掌握Python中的雙下劃線寫法

    在?Python?中,雙下劃線--也被稱為“dunder”--是一種用于修飾類屬性名稱或類方法名稱的行為,下面小編就來和大家詳細(xì)講講如何在Python中使用雙下劃線吧
    2023-10-10
  • pytorch:model.train和model.eval用法及區(qū)別詳解

    pytorch:model.train和model.eval用法及區(qū)別詳解

    今天小編就為大家分享一篇pytorch:model.train和model.eval用法及區(qū)別詳解,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2020-02-02
  • 如何利用python之wxpy模塊玩轉(zhuǎn)微信

    如何利用python之wxpy模塊玩轉(zhuǎn)微信

    這篇文章主要介紹了利用python之wxpy模塊玩轉(zhuǎn)微信,本文通過實(shí)例代碼給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2020-08-08
  • 詳解Python?Requests庫中的重試策略

    詳解Python?Requests庫中的重試策略

    在Python中,requests庫是處理HTTP請求的標(biāo)準(zhǔn)工具之一,這篇文章主要為大家介紹了如何在requests中實(shí)現(xiàn)請求的自動重試,感興趣的小伙伴可以跟隨小編一起學(xué)習(xí)一下
    2023-11-11

最新評論