我正在加强学生代码执行的沙箱。 我觉得我很满意,学生们不能共享文件系统或信号上的数据,因为我发现明确的规则指出这些数据,他们作为不同的非特权用户执行。 然而,我正在很难查看文档来确定什么时候创build共享内存(或更一般的IPC – 队列或信号量),谁可以看到。 如果你创build共享内存,任何人都可以在同一台机器上打开它,或者有什么办法来控制它? 控制是在创build内存的程序中,还是由系统pipe理员限制?
共享内存:shmget()/共享内存是如何工作的?
通过共享内存IPC在进程之间共享指针
如何删除未使用的共享内存和信号量?
从共享内存段中读取和写入信号的地方在哪里?
Boost ::进程间共享内存总线错误
同一个ipc命名空间中的任何进程都可以看到并(潜在地)访问由同一个ipc命名空间中的其他进程创建的ipc对象。 每个ipc对象与文件系统对象具有相同的user / group / other-rwx权限 – 请参见svipc(7)手册页。
您可以通过使用具有CLONE_NEWIPC标志的clone(2)系统调用来创建新的ipc名称空间。 您可以使用unshare(1)程序来执行另一个程序的克隆+执行程序,或者使用其他CLONE标志。
总结以上是内存溢出为你收集整理的谁可以在Linux共享共享内存?全部内容,希望文章能够帮你解决谁可以在Linux共享共享内存?所遇到的程序开发问题。
如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)