亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 編程 > C++ > 正文

C++開發的Redis數據導入工具優化

2020-01-26 15:03:50
字體:
來源:轉載
供稿:網友

背景

使用C++開發了一個Redis數據導入工具
從oracle中將所有表數據導入到redis中;
不是單純的數據導入,每條oracle中的原有記錄,需要經過業務邏輯處理,
并添加索引(redis集合);
工具完成后,性能是個瓶頸;

優化效果

使用了2個樣本數據測試:
樣本數據a表8763 條記錄;
b表940279 條記錄;

優化前,a表耗時11.417s;
優化后,a表耗時1.883s;

用到的工具

gprof, pstrace,time

使用time工具查看每次執行的耗時,分別包含用戶時間和系統時間;
使用pstrace打印實時運行,查詢進程主要的系統調用,發現耗時點;
使用gprof統計程序的耗時匯總,集中精力優化最耗時的地方;

使用簡介:

1.對g++的所有編輯和連接選項都必須要加上-pg(第一天由于沒有在連接處加上-pg選項,導致無法出統計報告);
2.執行完程序后,本目錄會產生gmon.out文件;
3.gprof redistool gmou.out > report,生成可讀文件report,打開report集中優化最耗時的函數;

優化過程

優化前11.417s:

復制代碼 代碼如下:

time ./redistool im a a.csv
real    0m11.417s
user    0m6.035s
sys     0m4.782s (發現系統調用時間過長)

文件內存映射

系統調用時間過長,主要是文件讀寫,初步考慮是讀取文件時,調用api次數過于頻繁;
讀取樣本采用的是文件fgets一行行的讀取,采用文件內存映射mmap后,可直接使用指針操作整個文件內存快;

日志開關提前

改進了文件讀寫后,發現優化效果比較有限(提高了2s左右);fgets是C的文件讀取庫函數,相比系統read(),是帶了緩沖區了,應該不會太慢(網上有人測試,文件內存映射相比fgets()能快上一個數量級,感覺場景應該比較特殊);

之后通過pstrace工具發現log.dat打開次數過多;原來是調試日志的開關寫到了后面,導致 調試日志都是會打開日志文件open("log.dat");
將日志開關提前;改進后,3.53s

復制代碼 代碼如下:

time ./redistool im a a.csv
real    0m3.530s
user    0m2.890s
sys     0m0.212s

vector空間預先分配

后續通過gprof分析,某個函數的vector內存分配次數多,并有不少復制次數:
改進以下這行代碼:

vector <string> vSegment;
使用靜態vector變量,并預先分配內存:

復制代碼 代碼如下:

static vector <string> vSegment;
vSegment.clear();
static int nCount = 0;
if( 0 == nCount)
{
    vSegment.reserve(64);
}
++nCount;

優化后,提升至2.286s

復制代碼 代碼如下:

real    0m2.286s
user    0m1.601s
sys     0m0.222s

同樣,另外一個類中的成員vector也使用預先分配空間(在構造函數中):

m_vtPipecmd.reserve(256);
優化后,提升至2.166s;

復制代碼 代碼如下:

real    0m2.166s
user    0m1.396s
sys     0m0.204s

函數改寫 && 內聯

繼續執行程序,發現SqToolStrSplitByCh()函數消耗過大,改寫整個函數邏輯,并將改寫后的函數內聯:
優化后,提升至1.937s

復制代碼 代碼如下:

real    0m1.937s
user    0m1.301s
sys     0m0.186s

去除調試符和優化監測符號

最后,去掉debug和pg調試符號后,最終效果為1.883s;

復制代碼 代碼如下:

real    0m1.883s
user    0m1.239s
sys     0m0.191s

滿足生產要求

以上最后幾步看似毫秒級的提升,擴大到全表數據后,效果就很明顯了;
優化后,生產上a表為152w,導入耗時大約326s(~6分鐘);
b表數據420w,導入耗時大約1103s(~18分鐘)

以上所述就是本文的全部內容了,希望大家能夠喜歡。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
日韩精品在线看| 欧美亚洲日本网站| 久久国产一区二区三区| 亚洲欧美一区二区三区四区| 亚洲第一福利视频| 欧美一区二区视频97| 久久精品成人欧美大片古装| 久久久精品免费视频| 亚洲福利视频网| 国产精品国产三级国产专播精品人| 亚洲国产成人久久| 国产日韩av在线播放| 91精品国产777在线观看| 精品成人乱色一区二区| 国产成人精品视| 米奇精品一区二区三区在线观看| 亚洲www在线观看| 欧美日韩亚洲一区二区| 亚洲国产精品99久久| 国产不卡在线观看| 国产精品亚洲片夜色在线| 日韩av在线导航| 欧美性videos高清精品| 国产精品专区h在线观看| 欧美性猛交xxxx免费看| 欧美伊久线香蕉线新在线| 国产精品网址在线| 亚洲天堂免费视频| 精品久久久久久久久久久| 7m第一福利500精品视频| 日本精品免费一区二区三区| 久久综合国产精品台湾中文娱乐网| 中文字幕在线国产精品| 亚洲老板91色精品久久| 日韩av电影免费观看高清| 欧美第一黄色网| 亚洲白虎美女被爆操| 国产精品久久久久久久久免费看| 久久久久北条麻妃免费看| 国产欧美日韩精品在线观看| 精品夜色国产国偷在线| 92国产精品久久久久首页| 日韩在线精品视频| 亚洲国产日韩欧美综合久久| 米奇精品一区二区三区在线观看| 国模精品视频一区二区| 国产xxx69麻豆国语对白| 亚洲精品短视频| 国产一区二区三区四区福利| 国产ts人妖一区二区三区| 黄网站色欧美视频| 亚洲第一色中文字幕| 在线视频一区二区| 91精品免费久久久久久久久| 亚洲精品白浆高清久久久久久| 91国产高清在线| 91精品视频在线| 丝袜美腿精品国产二区| 国产精品九九久久久久久久| 5566日本婷婷色中文字幕97| 亚洲色图17p| 欧美一级高清免费| 国产情人节一区| 一区二区三区高清国产| 社区色欧美激情 | 欧美日韩国产一区二区| 欧美网站在线观看| 日本成人免费在线| 久久久精品一区| 欧美日韩国产黄| 日韩中文在线视频| 97热在线精品视频在线观看| 欧美一级淫片aaaaaaa视频| 美女扒开尿口让男人操亚洲视频网站| 91日韩在线播放| 亚洲精品国产精品自产a区红杏吧| 国产欧洲精品视频| 亚洲欧美日韩一区二区在线| 亚洲自拍中文字幕| 色av中文字幕一区| 国产精品亚洲视频在线观看| 欧美性极品少妇精品网站| 欧美一区二区影院| 国产精品激情自拍| 亚洲精品免费一区二区三区| 午夜精品久久久久久99热软件| 一区二区三区黄色| 亚洲国产日韩欧美在线图片| 亚洲精品v天堂中文字幕| 一区二区三区美女xx视频| 久久久久久久色| 亚洲国产91精品在线观看| 欧美激情一区二区三级高清视频| 国产亚洲成av人片在线观看桃| 日韩电影中文字幕在线观看| 日韩电影免费观看中文字幕| 精品亚洲一区二区三区在线播放| 成人亚洲综合色就1024| 日韩电影在线观看中文字幕| 国产欧美精品日韩精品| 欧洲精品毛片网站| 97在线日本国产| 7m第一福利500精品视频| 国产在线视频欧美| 欧美第一页在线| 久久久国产精品x99av| 国产亚洲精品久久久久久牛牛| 亚洲成色777777女色窝| 91免费看视频.| 欧美在线视频免费| 亚洲自拍小视频| 中文日韩电影网站| 亚洲国产婷婷香蕉久久久久久| 国产精品久久久久久久电影| 欧美成人小视频| 人九九综合九九宗合| 欧美激情网友自拍| 亚洲男人7777| 久久久精品欧美| 国产成人一区二区三区电影| 在线观看国产精品日韩av| 日韩欧美在线字幕| 中文字幕亚洲一区二区三区五十路| 国产在线日韩在线| 一个人看的www欧美| 亚洲欧美在线一区二区| 欧美中文在线观看国产| 午夜精品美女自拍福到在线| 成人激情视频小说免费下载| 久久久久国色av免费观看性色| 9.1国产丝袜在线观看| 一区二区三区回区在观看免费视频| 欧美极品少妇与黑人| 中文字幕日韩欧美| 日韩欧美高清在线视频| 91在线观看欧美日韩| 国产精品福利网| 黑人狂躁日本妞一区二区三区| 一个人www欧美| 欧美精品在线视频观看| 国产精品久久久久久久7电影| 亚洲aa中文字幕| 欧美精品性视频| 91老司机在线| 亚洲色图综合网| 国产精品久久久久久久一区探花| 成人欧美一区二区三区在线湿哒哒| 国产精品免费看久久久香蕉| 欧美性猛交丰臀xxxxx网站| 日韩中文字幕在线视频| 综合136福利视频在线| 亚洲最大激情中文字幕| 精品成人国产在线观看男人呻吟| 国产精品午夜一区二区欲梦| 国产精品成熟老女人| 青青久久av北条麻妃海外网| 日本在线观看天堂男亚洲| 国产精品热视频| 午夜精品免费视频| 亚洲欧美激情视频| 午夜精品国产精品大乳美女| 国产激情久久久久| 日韩国产在线播放| 川上优av一区二区线观看|