在EC2(Ubuntu)上运行bash脚本时出现奇怪的“Permission denied”异常

时间:2013-11-22 06:45:17

标签: linux bash ubuntu amazon-ec2

我已经附加了一个EBS块并将其安装在我的EC2实例上的“/ data”上,该实例运行Ubuntu 12.04。有一个备份脚本运行正常,但在我将脚本移动到“/ data / backup”文件夹后,它无法执行,错误:

-bash: ./db_backup.sh: Permission denied

许可是:

-rwxr-xr-x 1 ubuntu ubuntu 2.3K Nov 22 03:25 db_backup.sh

如果我用“sudo”运行它,没有错误也没有输出,但应该有一些东西回显到控制台。

我也尝试使用“strace”来执行,但得到了:

execve("./db_backup.sh", ["./db_backup.sh"], [/* 19 vars */]) = -1 EACCES (Permission   denied)
dup(2)                                  = 3
fcntl(3, F_GETFL)                       = 0x8002 (flags O_RDWR|O_LARGEFILE)
fstat(3, {st_mode=S_IFCHR|0620, st_rdev=makedev(136, 1), ...}) = 0
mmap(NULL, 4096, PROT_READ|PROT_WRITE, MAP_PRIVATE|MAP_ANONYMOUS, -1, 0) =     0x7f354f010000
lseek(3, 0, SEEK_CUR)                   = -1 ESPIPE (Illegal seek)
write(3, "strace: exec: Permission denied\n", 32strace: exec: Permission denied
) = 32
close(3)                                = 0
munmap(0x7f354f010000, 4096)            = 0
exit_group(1)                           = ?

但是如果我把这个脚本放在哪里,说“/ tmp”,它就没问题了。为了缩小根本原因,我还创建了一个测试脚本:

#!/bin/bash

echo "hello"

可悲的是,如果我把它放在/ data文件夹中,这也不行。

1 个答案:

答案 0 :(得分:8)

最有可能是它上面带有noexec标志。您可以通过以下方式确认:

mount | grep /data

在输出中,您可能会在行尾看到(rw,noexec)之类的内容。 noexec标志不是默认标志,因此通常在明确配置为以此方式安装时会发生这种情况。

我不知道你是怎么装的,但是必须有一个配置。你可以改变它,但也许这不是一个好主意,这些默认值存在是有原因的。更好的选择是在bash或sh中显式运行脚本,如下所示:

sh db_backup.sh

<强>更新

在某些情况下,@Doc的评论也可能有所帮助:

  

我正在处理同样的行为。我注意到在我的/ etc / fstab中,即使我在那里明确地为我的分区“exec”,我之后也有“用户”..一旦我删除了用户并重新安装了分区,我的用户就可以执行分区。