SELinux:允许bash脚本在严格模式下运行

时间:2011-09-06 07:24:38

标签: rhel5 selinux

我有一台RHEL 5.5服务器,在strict模式下安装了SELinux。系统目前处于permissive模式。我正在尝试编写一个简单的shell脚本,比如setest.sh,并希望从bash终端显式运行它。

在许可模式下,我能够这样做,但在审核日志中将其记录为已拒绝:

Sep  6 12:49:58 rhel-vm-003 kern 5 kernel: type=1400 audit(1315293598.916:45417): 
avc:  denied  { execute_no_trans } for  pid=26602 comm="bash" path="/var/tmp/setest.sh"
dev=sda1 ino=1017036 scontext=system_u:system_r:sshd_t:s0-s0:c0.c1023
tcontext=system_u:object_r:test_policy_exec_t:s0 tclass=file

这显然意味着一旦我将SELinux切换到强制模式,我将无法从bash控制台运行脚本。我应该在策略模块中添加哪些允许/域转换规则,以便在强制执行SELinux时这可以工作?

的问候,
Nagendra U M

1 个答案:

答案 0 :(得分:0)

当我在'test_policy_exec_t'上运行网络搜索时,我得到的唯一一个就是这个帖子,所以我认为它是你创建的自定义上下文。只需将上下文更改为正常情况,您就可以运行脚本。

在我的RHEL 5服务器上使用默认的sepolicy,以下内容不会在审核日志中生成任何内容。

 $ echo -e '#!/bin/sh\necho Hi!' > /var/tmp/setest.sh
 $ ls -Z /var/tmp/setest.sh
 -rw-r--r--  polgar users user_u:object_r:tmp_t            /var/tmp/setest.sh
 $ /var/tmp/setest.sh
 Hi!