网络应用开发与调试全解析
1. 进程管理与权限控制
在系统操作中,我们常常会遇到需要管理进程的情况。例如,当我们查看系统进程时,可能会看到类似如下的输出:
1 27996 27995 27995 ? -1 S 502 0:00 ./daemon2
27959 27998 27997 27350 pts/2 27997 S 0 0:00 grep daemon2
从这个输出中我们可以注意到, grep 命令关联的用户 ID 是 0,也就是超级用户;而 daemon2 进程关联的用户 ID 是 502,这是特定系统上的无特权用户。如果我们想要停止 daemon2 进程,可以向它发送终止信号,具体命令如下:
kill -TERM 27996
此外,当我们尝试以非超级用户或“无特权”用户的身份运行程序时,会发现 setuid 调用并不会改变用户 ID。这是因为 setuid() 调用会失败,进程将继续以我们登录的用户身份运行。
2. chroot() 监狱机制
为了增强服务器的安全性,我们可以限制其对文件系统的访问。在 Linux 系统中,文件系统层次结构以根目录 / 为起点。 chroot() 命
超级会员免费看
订阅专栏 解锁全文

被折叠的 条评论
为什么被折叠?



