技术头条 - 一个快速在微博传播文章的方式     搜索本站
您现在的位置首页 --> 系统运维 --> 使用tcpdump搞定一个替换问题

使用tcpdump搞定一个替换问题

浏览:2494次  出处信息

   今天碰到一个替换问题:需要把全部接口中出现的一个链接改成另一个链接。虽然链接地址是保存在数据库中的,但是由于某些原因,不能直接修改数据库中的内容,只能在渲染结果的时候再进行替换。

   如果有很好的逻辑封装的话,这个问题并不是什么难事儿,可恰恰代码一团乱,搞不清楚到底哪些接口需要修改。我本打算依靠蛮力挨个文件查,但试了试发现工作量实在太大了,没办法只能想想别的招儿。

   最后找到的招儿就是「tcpdump」,通过它可以直接过滤服务器渲染的内容:

shell> tcpdump -i eth0 src port 80 -l -s 0 -w - | strings | grep www.foo.com -B 100

   好在访问量大,通过一段不长时间的采样,就可以捕捉到绝大部分有问题的请求。

   不过仅仅这样还不够,因为虽然我们过滤出了有问题的内容,但是我们并不知道其对应的地址是什么,所以我们需要想办法把地址放到响应结果里去。

   如果用PHP的话,可以借助「auto_prepend_file」为所有的PHP响应增加一个头:

<?php

header('X-Request-URI: ' . $_SERVER['REQUEST_URI']);

?>

   如果用Nginx的话,可以借助「add_header」为所有的响应增加一个头:

http {
    add_header X-Request-URI $request_uri;
}

   有了这些铺垫工作,再用「tcpdump」过滤内容的时候,就能直观的看到地址了:

HTTP/1.1 200 OK
Server: nginx
Date: Fri, 22 Mar 2013 07:50:39 GMT
Content-Type: text/html
Transfer-Encoding: chunked
Connection: close
X-Powered-By: PHP
X-Request-URI: /path/to/foo

   找到了地址,剩下的工作就简单了。这个替换问题并不难,不过如果选错了方法,那么耗费的时间可能会多很多,可见即便是简单的问题也值得深思熟虑。

   BTW:Nginx有一个「Substitution」模块能完成替换,但对本例而言有点太重了。

建议继续学习:

  1. VIM查找替换归纳总结    (阅读:4361)
  2. vim替换^M字符    (阅读:3695)
  3. string替换所有指定字符串(C++)    (阅读:3255)
  4. 使用Vim(gvim)实现复杂的查找替换的一个例子    (阅读:2462)
  5. CSS图片替换    (阅读:1871)
QQ技术交流群:445447336,欢迎加入!
扫一扫订阅我的微信号:IT技术博客大学习
© 2009 - 2024 by blogread.cn 微博:@IT技术博客大学习

京ICP备15002552号-1