V2EX = way to explore
V2EX 是一个关于分享和探索的地方
现在注册
已注册用户请  登录
推荐学习书目
Learn Python the Hard Way
Python Sites
PyPI - Python Package Index
http://diveintopython.org/toc/index.html
Pocoo
值得关注的项目
PyPy
Celery
Jinja2
Read the Docs
gevent
pyenv
virtualenv
Stackless Python
Beautiful Soup
结巴中文分词
Green Unicorn
Sentry
Shovel
Pyflakes
pytest
Python 编程
pep8 Checker
Styles
PEP 8
Google Python Style Guide
Code Style from The Hitchhiker's Guide
bbbb
V2EX  ›  Python

Python 新手请教 mitmproxy 多进程问题

  •  
  •   bbbb · 2019-01-22 21:30:54 +08:00 via iPhone · 2696 次点击
    这是一个创建于 2180 天前的主题,其中的信息可能已经有所发展或是发生改变。
    • 使用 mitmproxy,自定义脚本中,需求是把 flow 传递到其他进程去处理。查了半天好像不支持多进程?反正没查到。

    • 目前研究的方案将 flow 存本地,也就是二进制,进程间传递文件名字,另一个进程去读。

    • 想实现直接传 json 或者对象更好。把 flow 存为 json,har 格式,直接传 json,查了半天,没查到如何从 json 恢复为 flow。

    8 条回复    2020-03-06 11:10:39 +08:00
    momocraft
        1
    momocraft  
       2019-01-22 21:52:51 +08:00
    在 mitmproxy 进程内搞这些方便吗? 你的最终问题是 "用 mitmproxy 拦截连接然后换一个后端服务器" 无法解决的吗?
    bbbb
        2
    bbbb  
    OP
       2019-01-22 22:27:42 +08:00 via iPhone
    @momocraft 可以… 已经拿到了所有的参数。其实就想找一个简单的方法。
    484A4B
        3
    484A4B  
       2019-01-22 23:19:17 +08:00
    另一个进程要做什么事情,拿到 json 中的信息还不够吗
    bbbb
        4
    bbbb  
    OP
       2019-01-22 23:30:21 +08:00 via iPhone
    @484A4B 拦截到请求了以后还要做其他事,开线程处理有点慢,开进程就涉及到通讯问题了,原始对象不知道如何传。其实就是想另外一个进程分担点任务。
    想的流程是这样,将 flow 转为 json 字符串,还原为之前的 flow 对象,然后延用 mitmproxy 的逻辑。
    看了初始化 flow 的方法,是读二进制的。转成 json 应该也能还原回来,不知道这样做的方向对不对。
    自己埋头苦干,有点晕了。
    momocraft
        5
    momocraft  
       2019-01-24 14:14:10 +08:00
    要做这么多很难说是“简单”了,不妨再考虑一下你的目的和手段
    bbbb
        6
    bbbb  
    OP
       2019-01-24 16:15:45 +08:00 via iPhone
    @momocraft 读了源码满足了需求,目前不可控,总是出现莫名的问题。
    "简单"是想用 mitm 原始方法构建请求,整个请求逻辑由 mitm 负责。
    在看看不行自己构建请求了。
    geekgu
        7
    geekgu  
       2019-10-14 20:25:26 +08:00
    楼主最后解决方案如何,mitmproxy 启动的时候类似一个 web 服务器,没有触发点去处理保存下来的 flow,我在想只是只能保存成比较通用的数据形式,然后再用 requests 等库发请求。
    bbbb
        8
    bbbb  
    OP
       2020-03-06 11:10:39 +08:00
    @geekgu 算是解决了吧,直接在 `def request(flow: HTTPFlow):` 把请求数据推到了 redis 队列,另外到机器在读取,用 requests 也可以。但是请求上下文的没有去解决。
    关于   ·   帮助文档   ·   博客   ·   API   ·   FAQ   ·   实用小工具   ·   963 人在线   最高记录 6679   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 · 28ms · UTC 22:05 · PVG 06:05 · LAX 14:05 · JFK 17:05
    Developed with CodeLauncher
    ♥ Do have faith in what you're doing.