微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

Ruby – 在分叉进程上的set_trace_func

我想实现以下目标:

构建一个注册一些set_trace_func事件的Ruby命令行实用程序,然后调用传递给它的任何ruby-executable参数(比如rspec).然后,已注册的事件将继承到调用的命令.

myutility的伪代码

set_trace_func() # Set some events here

exec(ARGV.join(' ')) # Execute argument passed

然后称为myutility rspec.

我的目标是在任意命令上实际注册跟踪点(只要它们使用ruby垫片).

我尝试过的事情:

> exec由于显而易见的原因(它完全取代了这个过程)不起作用.
> popen,系统,反引号.这些开始一个独立的过程.

我可以使用某种形式的IPC,但它假设控制我用我的实用程序调用的命令.不是这种情况;我想接受任意Ruby可执行参数.

这可能吗?我没有密切关注的一件事是drb,但这也假设对外界争论有些干扰.

解决方法

您可以通过向ruby解释器添加参数将一些代码注入ruby进程,因此您的实用程序可以分为两部分 – runner和payload. Payload只是另一个脚本,它根据需要注册set_trace_func等,并且运行器将前者注入目标脚本,如下所示:
exec('/usr/bin/env','ruby','-r',payload_full_filename,*ARGV)

这将使ruby首先要求您的有效负载进入进程,然后继续运行目标脚本本身(即使目标脚本无法编译,有效负载也会运行)

原文地址:https://www.jb51.cc/ruby/268060.html

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐