利用tcpdump抓取mysql sql語句
這個腳本是我之前在網上無意間找個一個利用tcpdump 抓包工具獲取mysql流量,并通過過濾把sql 語句輸入。
腳本不是很長,但是效果很好。
#!/bin/bash #this script used montor mysql network traffic.echo sql tcpdump -i eth0 -s 0 -l -w - dst port 3306 | strings | perl -e ' while(<>) { chomp; next if /^[^ ]+[ ]*$/; if(/^(SELECT|UPDATE|DELETE|INSERT|SET|COMMIT|ROLLBACK|CREATE|DROP|ALTER|CALL)/i) { if (defined $q) { print "$q\n"; } $q=$_; } else { $_ =~ s/^[ \t]+//; $q.=" $_"; } }'
下面是執行腳本的輸出:
SELECT b.id FROM module as a,rights as b where a.id=b.module_id and b.sid='179' and a.pname like 'vip/member_order_manage.php%' SELECT count(id) as cc,sum(cash) as total from morder_stat_all where (ymd BETWEEN '1312214400' and '1312336486') and depart_id=5 an d order_class=2 select id,name from media where symd='0000-00-00' select id,name from depart where s_flag=' ' and onoff=1 order by sno select id,name from plank where depart_id=5 and onoff=1 order by no select id,name from grp where plank_id=0 and onoff=1 order by no select id,CONCAT(pname,'-',name) as name from pvc order by pname select id,CONCAT(no,'-',name) as name from local where pvc_id=0 order by no select id,name from product_breed select color_name from product_color where id=5 select id,name from product where id = '0' select * from morder_stat_all where (ymd BETWEEN '1312214400' and '1312336486') and depart_id=5 and order_class=2 order by ymd DESC LIMIT 0,50 select urlkey from sys_config where id=1 select name from morder where id=7195793 select no,name from staff where id=5061 select product_id,amt,price0 from order_product where order_id = 7195793 select concat_ws('/',name,NULLIF((select color_name as cn from product_color where id=color_id),''),NULLIF((select style_name from p roduct_style where id=style_id),'')) as name,spec,weight,price from product where id = 16938 select concat_ws('/',name,NULLIF((select color_name as cn from product_color where id=color_id),''),NULLIF((select style_name from p roduct_style where id=style_id),'')) as name,spec,weight,price from product where id = 19005 select name from morder where id=7195768 select no,name from staff where id=221 select product_id,amt,price0 from order_product where order_id = 7195768 select concat_ws('/',name,NULLIF((select color_name as cn from product_color where id=color_id),''),NULLIF((select style_name from p roduct_style where id=style_id),'')) as name,spec,weight,price from product where id = 18978 select concat_ws('/',name,NULLIF((select color_name as cn from product_color where id=color_id),''),NULLIF((select style_name from p roduct_style where id=style_id),'')) as name,spec,weight,price from product where id = 18282 select concat_ws('/',name,NULLIF((select color_name as cn from product_color where id=color_id),''),NULLIF((select style_name from p roduct_style where id=style_id),'')) as name,spec,weight,price from product where id = 19740
從上面的日志可以看出,腳本的功能還是很強大吧 。
轉自: http://www.cnblogs.com/ylqmf/archive/2012/07/11/2586741.html
本文由用戶 jopen 自行上傳分享,僅供網友學習交流。所有權歸原作者,若您的權利被侵害,請聯系管理員。
轉載本站原創文章,請注明出處,并保留原始鏈接、圖片水印。
本站是一個以用戶分享為主的開源技術平臺,歡迎各類分享!