如果您可以启动该过程,则:
1) 使用 lxc (Linux Containers) 将应用程序放在它自己的网络命名空间中。您可以仅为该容器设置 netfilter 规则。哎呀,如果你愿意,你可以给应用程序它自己的 IP 地址。
/usr/bin/lxc-execute -n app_container -f my_net_lxc.conf your_application
2)正如吴指出的,您可以使用 LD_PRELOAD 覆盖标准库。只需将它指向一些包装函数,您就可以拦截来自应用程序的所有调用。
LD_PRELOAD=/usr/lib/mylib.so your_application
# See here for info: https://github.com/wh5a/ld_preload
3) 正如 Giles 指出的,您可以使用 iptables。您必须仅为该应用程序创建一个特殊用户。
# Setup: Add a user and give him some rules
adduser --shell /bin/false --no-create-home tempuser
iptables -A OUTPUT -m owner --uid-owner tempuser -j ACCEPT
# Run your app
sudo -u tempuser your_application
4) 您可以在 VM 技术下运行应用程序,例如用户模式 Linux 或 QEMMU,这为应用程序提供了一个完整的内核,您可以在多个级别上修改/控制。
如果您没有启动该进程,您仍然可以使用 ptrace 附加到该进程。这使您可以检查进程进行的每个系统调用。