我有一个程序(https://github.com/raboof/connbeat)依赖于/proc/[pid]/fd/*
来查找给定(网络)inode的进程。
/proc/[pid]/fd
只能由root读取,但我希望尽可能多地删除权限以保证安全。
是否有某些方法可以(有效地)获取进程和inode之间的关系而无需完全root权限?也许有些系统调用可以选择性地授予使用功能的权限吗?
答案 0 :(得分:2)
能够读取您需要的所有过程的fd:
您可以将程序限制为仅这两项功能。然后,您可以使用普通的API调用来访问相关信息,例如readdir()
或readlink()
或您喜欢的其他任何内容。
有关这两项功能的更详细说明,请参阅capabilities(7)