精品欧美一区二区三区在线观看 _久久久久国色av免费观看性色_国产精品久久在线观看_亚洲第一综合网站_91精品又粗又猛又爽_小泽玛利亚一区二区免费_91亚洲精品国偷拍自产在线观看 _久久精品视频在线播放_美女精品久久久_欧美日韩国产成人在线

Linux大文件重定向和管道的效率對比

系統 Linux
大家先看一下二個命令,假如huge_dump.sql文件很大,然后猜測一下哪種導入方式效率會更高一些?

[[315910]]

  1. # 命令1,管道導入 
  2. shell> cat huge_dump.sql | mysql -uroot; 
  1. # 命令2,重定向導入 
  2. shell> mysql -uroot < huge_dump.sql

大家先看一下上面二個命令,假如huge_dump.sql文件很大,然后猜測一下哪種導入方式效率會更高一些?

這個問題挺有意思的,我的第一反應是:沒比較過,應該是一樣的,一個是cat負責打開文件,一個是bash

這種場景在MySQL運維操作里面應該比較多,所以就花了點時間做了個比較和原理上的分析:

我們先構造場景:

首先準備一個程序b.out來模擬mysql對數據的消耗:

  1. int main(int argc, char *argv[]) 
  2.   while(fread(buf, sizeof(buf), 1, stdin) > 0); 
  3.     return 0; 
  4.  
  5. $  gcc  -o b.out b.c 
  6. $ ls|./b.out 

再來寫個systemtap腳本用來方便觀察程序的行為。

  1. $ cat test.stp 
  2. function should_log(){ 
  3.   return (execname() == "cat" || 
  4.       execname() == "b.out" || 
  5.       execname() == "bash") ; 
  6. probe syscall.open, 
  7.       syscall.close, 
  8.       syscall.read, 
  9.       syscall.write, 
  10.       syscall.pipe, 
  11.       syscall.fork, 
  12.       syscall.execve, 
  13.       syscall.dup, 
  14.       syscall.wait4 
  15.   if (!should_log()) next; 
  16.   printf("%s -> %s\n", thread_indent(0), probefunc()); 
  17.   
  18. probe kernel.function("pipe_read"), 
  19.       kernel.function("pipe_readv"), 
  20.       kernel.function("pipe_write"), 
  21.       kernel.function("pipe_writev") 
  22.   if (!should_log()) next; 
  23.   printf("%s -> %s: file ino %d\n",  thread_indent(0), probefunc(), __file_ino($filp)); 
  24. probe begin { println(":~") } 

這個腳本重點觀察幾個系統調用的順序和pipe的讀寫情況,然后再準備個419M的大文件huge_dump.sql,在我們幾十G內存的機器很容易在內存里放下:

  1. $ sudo dd if=/dev/urandom of=huge_dump.sql bs=4096 count=102400 
  2. 102400+0 records in 
  3. 102400+0 records out 
  4. 419430400 bytes (419 MB) copied, 63.9886 seconds, 6.6 MB/s 

因為這個文件是用bufferio寫的,所以它的內容都cache在pagecahce內存里面,不會涉及到磁盤。

好了,場景齊全了,我們接著來比較下二種情況下的速度,第一種管道:

  1. # 第一種管道方式 
  2. $ time (cat huge_dump.sql|./b.out) 
  3.   
  4. real    0m0.596s 
  5. user    0m0.001s 
  6. sys     0m0.919s 
  7.   
  8. # 第二種重定向方式 
  9. $ time (./b.out <huge_dump.sql
  10.   
  11. real    0m0.151s 
  12. user    0m0.000s 
  13. sys     0m0.147s 

從執行時間數看出來速度有3倍左右的差別了,第二種明顯快很多。

是不是有點奇怪?好吧我們來從原來上面分析下,還是繼續用數據說話:

這次準備個很小的數據文件,方便觀察然后在一個窗口運行stap

  1. $ echo hello > huge_dump.sql 
  2. $ sudo stap test.stp 
  3. :~ 
  4.      0 bash(26570): -> sys_read 
  5.      0 bash(26570): -> sys_read 
  6.      0 bash(26570): -> sys_write 
  7.      0 bash(26570): -> sys_read 
  8.      0 bash(26570): -> sys_write 
  9.      0 bash(26570): -> sys_close 
  10.      0 bash(26570): -> sys_pipe 
  11.      0 bash(26570): -> sys_pipe 
  12.      0 bash(26570): -> do_fork 
  13.      0 bash(26570): -> sys_close 
  14.      0 bash(26570): -> sys_close 
  15.      0 bash(26570): -> do_fork 
  16.      0 bash(13775): -> sys_close 
  17.      0 bash(13775): -> sys_read 
  18.      0 bash(13775): -> pipe_read: file ino 20906911 
  19.      0 bash(13775): -> pipe_readv: file ino 20906911 
  20.      0 bash(13776): -> sys_close 
  21.      0 bash(13776): -> sys_close 
  22.      0 bash(13776): -> sys_close 
  23.      0 bash(13776): -> do_execve 
  24.      0 bash(26570): -> sys_close 
  25.      0 bash(26570): -> sys_close 
  26.      0 bash(26570): -> sys_close 
  27.      0 bash(13775): -> sys_close 
  28.      0 bash(26570): -> sys_wait4 
  29.      0 bash(13775): -> sys_close 
  30.      0 bash(13775): -> sys_close 
  31.      0 b.out(13776): -> sys_close 
  32.      0 b.out(13776): -> sys_close 
  33.      0 bash(13775): -> do_execve 
  34.      0 b.out(13776): -> sys_open 
  35.      0 b.out(13776): -> sys_close 
  36.      0 b.out(13776): -> sys_open 
  37.      0 b.out(13776): -> sys_read 
  38.      0 b.out(13776): -> sys_close 
  39.      0 cat(13775): -> sys_close 
  40.      0 cat(13775): -> sys_close 
  41.      0 b.out(13776): -> sys_read 
  42.      0 b.out(13776): -> pipe_read: file ino 20906910 
  43.      0 b.out(13776): -> pipe_readv: file ino 20906910 
  44.      0 cat(13775): -> sys_open 
  45.      0 cat(13775): -> sys_close 
  46.      0 cat(13775): -> sys_open 
  47.      0 cat(13775): -> sys_read 
  48.      0 cat(13775): -> sys_close 
  49.      0 cat(13775): -> sys_open 
  50.      0 cat(13775): -> sys_close 
  51.      0 cat(13775): -> sys_open 
  52.      0 cat(13775): -> sys_read 
  53.      0 cat(13775): -> sys_write 
  54.      0 cat(13775): -> pipe_write: file ino 20906910 
  55.      0 cat(13775): -> pipe_writev: file ino 20906910 
  56.      0 cat(13775): -> sys_read 
  57.      0 b.out(13776): -> sys_read 
  58.      0 b.out(13776): -> pipe_read: file ino 20906910 
  59.      0 b.out(13776): -> pipe_readv: file ino 20906910 
  60.      0 cat(13775): -> sys_close 
  61.      0 cat(13775): -> sys_close 
  62.      0 bash(26570): -> sys_wait4 
  63.      0 bash(26570): -> sys_close 
  64.      0 bash(26570): -> sys_wait4 
  65.      0 bash(26570): -> sys_write 

stap在收集數據了,我們在另外一個窗口運行管道的情況:

  1. $ cat huge_dump.sql|./b.out 

我們從systemtap的日志可以看出:

  • bash fork了2個進程。
  • 然后execve分別運行cat 和 b.out進程, 這二個進程用pipe通信。
  • 數據從由cat從 huge_dump.sql讀出,寫到pipe,然后b.out從pipe讀出處理。

那么再看下命令2重定向的情況:

  1. $ ./b.out < huge_dump.sql 
  2.   
  3. stap輸出: 
  4.       0 bash(26570): -> sys_read 
  5.      0 bash(26570): -> sys_read 
  6.      0 bash(26570): -> sys_write 
  7.      0 bash(26570): -> sys_read 
  8.      0 bash(26570): -> sys_write 
  9.      0 bash(26570): -> sys_close 
  10.      0 bash(26570): -> sys_pipe 
  11.      0 bash(26570): -> do_fork 
  12.      0 bash(28926): -> sys_close 
  13.      0 bash(28926): -> sys_read 
  14.      0 bash(28926): -> pipe_read: file ino 20920902 
  15.      0 bash(28926): -> pipe_readv: file ino 20920902 
  16.      0 bash(26570): -> sys_close 
  17.      0 bash(26570): -> sys_close 
  18.      0 bash(26570): -> sys_wait4 
  19.      0 bash(28926): -> sys_close 
  20.      0 bash(28926): -> sys_open 
  21.      0 bash(28926): -> sys_close 
  22.      0 bash(28926): -> do_execve 
  23.      0 b.out(28926): -> sys_close 
  24.      0 b.out(28926): -> sys_close 
  25.      0 b.out(28926): -> sys_open 
  26.      0 b.out(28926): -> sys_close 
  27.      0 b.out(28926): -> sys_open 
  28.      0 b.out(28926): -> sys_read 
  29.      0 b.out(28926): -> sys_close 
  30.      0 b.out(28926): -> sys_read 
  31.      0 b.out(28926): -> sys_read 
  32.      0 bash(26570): -> sys_wait4 
  33.      0 bash(26570): -> sys_write 
  34.      0 bash(26570): -> sys_read 
  • bash fork了一個進程,打開數據文件。
  • 然后把文件句柄搞到0句柄上,這個進程execve運行b.out。
  • 然后b.out直接讀取數據。

現在就非常清楚為什么二種場景速度有3倍的差別:

  • 命令1,管道方式: 讀二次,寫一次,外加一個進程上下文切換。
  • 命令2,重定向方式:只讀一次。

結論:Linux下大文件重定向效率更高。

責任編輯:趙寧寧 來源: Linux云計算網絡
相關推薦

2020-12-09 11:10:12

shellLinux管道

2022-11-14 15:07:09

Linux管道

2009-06-17 09:11:24

Unix管道重定向

2009-06-17 17:13:40

UNIX

2010-03-01 14:45:07

Linux文件重定向

2022-11-10 15:08:44

Linux輸入輸出

2010-12-14 15:07:15

ICMP路由重定向

2017-01-19 19:14:20

Linux重定向命令

2010-03-09 16:11:59

Linux重定向

2010-07-13 14:10:44

ICMP協議

2020-07-27 07:41:23

Linux重定向數據流

2014-08-07 10:23:24

linux重定向

2010-12-31 13:35:25

文件夾重定向

2010-06-23 16:14:52

Linux Bash

2021-02-20 20:36:56

Linux無名管道

2018-09-10 08:45:04

Linux管道命令

2009-06-25 14:54:22

Servlet轉發Servlet重定向

2011-04-20 10:15:02

Linuxconsole口

2014-09-04 11:39:43

Linux

2017-01-19 19:24:29

Linux重定向
點贊
收藏

51CTO技術棧公眾號

欧美网站一区二区| 欧美a级一区二区| 亚洲国产日韩欧美在线动漫| 成人免费aaa| 高清中文字幕一区二区三区| 国模大尺度一区二区三区| 欧美激情国产日韩精品一区18| 日本一级片在线播放| 日韩久久一区二区三区| 亚洲欧美日韩国产综合在线| 国产伦精品一区二区三区高清版| 伊人中文字幕在线观看 | 欧美一区二区三区公司| 免费在线观看视频a| 午夜不卡视频| 91丨国产丨九色丨pron| 91在线观看免费高清完整版在线观看| 日韩和一区二区| 999久久久国产精品| 日韩av在线免费播放| 午夜免费看毛片| 欧美伦理91| 一区二区三区在线视频播放| 四虎影院一区二区三区| 天天干天天插天天操| 国产一区二区三区免费观看| 国产精品久久久久高潮| 日韩男人的天堂| 综合视频在线| www日韩欧美| 国产精品无码网站| 91成人午夜| 欧美一级高清片| 在线观看的毛片| 亚洲第一二三四区| 天天操天天干天天综合网| 制服丝袜综合日韩欧美| 第一页在线观看| 久久一夜天堂av一区二区三区| 99蜜桃在线观看免费视频网站| 一区二区三区在线免费观看视频| 久久久精品性| 欧美综合在线第二页| 国产一级久久久| 亚洲色图欧美| 久久影视免费观看 | 成人在线国产| 亚洲性av网站| 日韩中文字幕有码| 久久99国内| 亚洲九九九在线观看| 好吊色视频一区二区三区| 91精品久久久久久综合五月天| 欧美一区二区精品| 男插女视频网站| 亚洲91网站| 日韩欧美电影在线| 成人在线短视频| 97久久超碰| 欧美精品一区二区久久婷婷| 国产精品亚洲一区二区无码| 粉嫩av一区二区| 精品sm在线观看| 国产不卡一二三| 色哟哟精品丝袜一区二区| 日韩精品久久久久久久玫瑰园| 一级特级黄色片| 亚洲图区在线| 三级精品视频久久久久| 免费成人深夜夜行网站| 欧美一区二区| 久久久亚洲福利精品午夜| 青青草av在线播放| 久久这里有精品15一区二区三区| 国产精品久久久久久久电影| 亚洲一卡二卡在线观看| 国产中文字幕一区| 国产成人精品自拍| 九色在线免费| 亚洲图片欧美激情| 日韩在线观看a| 中文在线8资源库| 欧美日韩一区二区欧美激情| 伊人精品视频在线观看| 国产精品三p一区二区| 亚洲欧美三级伦理| 日本精品在线免费观看| 亚洲国产99| 国产精品成人免费电影| 国产麻豆免费观看| 99久久精品国产导航| 日韩精品一区二区三区外面| 老司机福利在线视频| 婷婷国产在线综合| 激情五月俺来也| а√中文在线天堂精品| 亚洲性线免费观看视频成熟| 欧美丰满熟妇bbbbbb| 亚洲综合精品| 亚洲xxxxx性| 日本中文字幕一区二区有码在线 | 国产精品无码无卡无需播放器| 久久99国内| 国产欧美精品一区| 国模精品一区二区三区| 东热在线免费视频| 亚洲国产色一区| 中文字幕亚洲欧洲| 亚洲+变态+欧美+另类+精品| 久久久国产精品亚洲一区| 亚洲高清毛片一区二区| 国产一区二区成人久久免费影院 | 黄色毛片在线看| 亚洲天堂2016| 宅男噜噜噜66国产免费观看| а√中文在线天堂精品| 俺也去精品视频在线观看| 国内自拍视频在线播放| 国产宾馆实践打屁股91| 亚洲日本理论电影| 中文字幕在线视频网站| 日韩视频123| 国产精品酒店视频| 先锋影音久久| 国产伦精品一区二区三区免| 超鹏97在线| 欧美日韩一区二区三区免费看| 51调教丨国产调教视频| 欧美日韩国产欧| 成人在线观看视频网站| 最新av网站在线观看| 色偷偷久久一区二区三区| 漂亮人妻被黑人久久精品| 欧美在线免费一级片| 国产日韩欧美另类| av在线资源站| 91精品91久久久中77777| 亚洲制服丝袜在线播放| 很黄很黄激情成人| 99re在线国产| 亚洲小说区图片| 日韩欧美三级在线| 亚洲国产精品免费在线观看| 国产中文字幕一区| 少妇熟女一区二区| 成人豆花视频| 欧美成人午夜影院| 国产视频第二页| 一区二区三区在线视频播放| 毛毛毛毛毛毛毛片123| 午夜精品视频| 国产成人av一区二区三区| caoprom在线| 亚洲国产精品va在线观看黑人| 国产在线拍揄自揄拍| 懂色一区二区三区免费观看| 看一级黄色录像| silk一区二区三区精品视频| 久久久久久久香蕉网| 日本免费不卡视频| 色综合天天狠狠| 美国黑人一级大黄| 久久9热精品视频| www.黄色网址.com| 一区二区在线免费播放| 97国产精品久久| 亚洲三区在线播放| 欧美综合天天夜夜久久| 中文乱码字幕高清一区二区| 久久爱www久久做| 女女百合国产免费网站| 激情小说亚洲图片| 日本高清+成人网在线观看| 丁香婷婷在线| 日韩午夜精品电影| 国产午夜视频在线播放| 97久久超碰国产精品电影| 黄色片一级视频| 欧美成人自拍| 成人综合电影| 欧美xxx性| 久久激情五月丁香伊人| 亚洲奶汁xxxx哺乳期| 色域天天综合网| 蜜臀av午夜精品久久| 成人国产精品免费| 手机在线看福利| 激情五月***国产精品| 日本最新一区二区三区视频观看| 日韩欧美2区| 欧美激情视频一区| 国产三级在线看| 日韩精品在线看片z| 69成人免费视频| 日韩美女视频一区| 国内精品久久99人妻无码| 另类小说综合欧美亚洲| 日韩国产一级片| 日韩在线第七页| 国产一区二区三区高清| 日韩一区二区三区四区五区| 91高清在线免费观看| 免费成人黄色| 亚洲精品视频网上网址在线观看 | 成人网男人的天堂| 怡红院亚洲色图| 亚洲九九精品| 欧美精品一区二区性色a+v| 国产欧美一区二区精品久久久| 99re在线视频观看| 日韩毛片一区| 日本aⅴ大伊香蕉精品视频| 欧美1—12sexvideos| 深夜福利国产精品| 三级理论午夜在线观看| 日韩欧美中文一区| 亚洲天堂中文在线| 欧美性黄网官网| 久久综合色综合| 亚洲欧洲av色图| 精品一区二区6| 国产校园另类小说区| 亚洲自拍偷拍精品| 国产激情视频一区二区在线观看| 中文久久久久久| 视频一区视频二区中文| 熟女少妇在线视频播放| 一区二区视频欧美| 欧洲金发美女大战黑人| 97精品97| 一区二区精品视频| 欧美亚洲激情| 午夜精品一区二区三区四区| 亚洲三级网页| 久久久久资源| 啪啪国产精品| 精品一区国产| 天天久久夜夜| 精品网站在线看| 狠狠久久伊人| 精品国产电影| 欧美丝袜美腿| 鲁鲁视频www一区二区| 欧美日韩另类图片| 久久精品第九区免费观看| 精品精品精品| 久久99国产精品99久久| 极品国产人妖chinesets亚洲人妖 激情亚洲另类图片区小说区 | 色爱av美腿丝袜综合粉嫩av| 调教视频免费在线观看| 色噜噜狠狠狠综合曰曰曰| 五月婷婷在线视频| 日韩一区二区久久久| 麻豆传媒视频在线观看免费| 久久久久www| 超鹏97在线| 久久乐国产精品| 在线观看网站免费入口在线观看国内| 57pao成人永久免费视频| 最近高清中文在线字幕在线观看1| 97免费中文视频在线观看| 天堂在线中文网官网| 日韩av毛片网| 福利一区视频| 亚洲japanese制服美女| 777久久精品| 欧美精品v日韩精品v国产精品| 精品国产91| 警花观音坐莲激情销魂小说| 欧美日韩p片| 国产精品宾馆在线精品酒店| 日本中文在线一区| 色91精品久久久久久久久| 国产成人午夜片在线观看高清观看| 91精品国产高清91久久久久久| 97久久超碰国产精品| 超薄肉色丝袜一二三| 亚洲免费电影在线| 日韩无码精品一区二区三区| 欧洲一区二区三区免费视频| 一区二区三区免费在线| 精品国产1区二区| 国产主播福利在线| 久久天天躁狠狠躁夜夜躁2014| 后进极品白嫩翘臀在线播放| 日本免费在线精品| 国产一区二区三区免费在线 | 亚洲 欧美 激情 小说 另类| 一本色道久久88精品综合| 日本动漫同人动漫在线观看| 青草青草久热精品视频在线网站| 亚洲成人1区| 精品麻豆av| 一区二区三区四区在线观看国产日韩| 男人和女人啪啪网站| 久久爱www久久做| 国产精品1000部啪视频| 亚洲另类在线一区| 欧美超碰在线观看| 精品美女一区二区| 99视频在线观看地址| 久久久久久网站| 四虎永久精品在线| 欧美激情国产日韩| 国产精品v欧美精品v日本精品动漫| 国产精品涩涩涩视频网站| 成人免费毛片嘿嘿连载视频| 在线日韩国产网站| 色94色欧美sute亚洲线路一ni | 99热在这里有精品免费| 少妇高潮一区二区三区喷水| 色哟哟国产精品免费观看| 亚洲精品免费在线观看视频| 色噜噜久久综合伊人一本| 理论片午夜视频在线观看| 亚洲资源在线看| 日韩在线第七页| 黄色国产精品视频| 99这里只有久久精品视频| 免费一级片在线观看| 884aa四虎影成人精品一区| 国产精品久久久久久久龚玥菲 | 黄色一级片播放| 国产**成人网毛片九色| 欧美在线视频第一页| 欧美理论电影在线| h视频在线播放| 国产精品1234| 国语产色综合| 欧美黄色一级片视频| 99久久伊人精品| 久久精品女人毛片国产| 日韩欧美国产成人一区二区| 国产成人无吗| 96精品久久久久中文字幕| 色一区二区三区四区| 一区二区三区韩国| 亚洲国产精品黑人久久久| 国产无遮挡又黄又爽又色视频| 亚洲欧美国产精品| 91av亚洲| 日韩精品无码一区二区三区| 日本在线不卡视频| 人人妻人人澡人人爽| 在线观看区一区二| 番号集在线观看| 国产欧美欧洲在线观看| 欧美高清视频手机在在线| 亚洲va在线va天堂va偷拍| 日韩一区在线看| 999国产精品视频免费| 欧美美最猛性xxxxxx| 亚洲成人偷拍| 霍思燕三级露全乳照| 91丨porny丨国产| 91黑人精品一区二区三区| 在线视频欧美性高潮| 在线播放成人| 女人被男人躁得好爽免费视频| 成人av在线电影| 黄色片免费观看视频| 亚洲深夜福利在线| 激情久久99| 亚洲小视频在线播放| 成人福利在线看| 草久视频在线观看| 亚洲一区二区国产| 精品国产一区二区三区2021| www.国产在线视频| 久久天天做天天爱综合色| 国产在线观看第一页| 久久久成人精品| 国产精品黄网站| 老头吃奶性行交视频| 综合久久一区二区三区| 亚洲不卡免费视频| 奇米一区二区三区四区久久| 日韩在线看片| 亚洲丝袜在线观看| 欧美午夜片在线免费观看| av福利精品| 国产精品二区在线| 日韩在线a电影| 久久久久亚洲av无码专区体验| 亚洲精品美女久久久久| 韩国理伦片久久电影网| 欧美视频在线观看网站| 国产精品久久777777| 无码精品人妻一区二区| 国产精品主播视频| 99精品国产福利在线观看免费| 在线免费观看视频| 欧美电影免费观看完整版| 日韩成人影音| 成年女人18级毛片毛片免费 | 国产一级视频在线播放| 最近2019中文字幕一页二页| 老司机凹凸av亚洲导航| 天天看片天天操| 日本乱人伦一区|