3

编辑:这个问题仍然存在:我重建了我的整个系统,我在一个理智的主机上使用它的 chroot 就像一个魅力。但是一旦我启动同一个目标系统,问题又出现了:perl 和 python 的 shebang 被错误地解释了......

我已经成功构建和管理自己的 Linux 系统大约 4 年了,但我现在有点卡住了,我非常感谢获得解决这个可怕问题的方向:

一些 Python、Perl 脚本甚至“配置”脚本中的命令都被误解了:我发现 python-config、xscreensaver-text 和 intltool-merge(Perl 脚本)的 Shebang 不被尊重或仅由 shell 解释。

我们一直在搞乱语言环境、编码、关于 UTF-8 的考虑、检查 env、$LANG、$TERM 等,切换 Linux 内核(3.1.5、3.5.4、3.8.1、3.11.1),但是仍然没有成功。

这是来自 xscreensaver-text 的 strace 输出,首先使用 CLI 的简单调用,然后使用显式 Perl 进行第二次调用。它的shebang是:

#!/bin/perl -w

root@poopy:~# strace /usr/bin/xscreensaver-text
execve("/usr/bin/xscreensaver-text", ["/usr/bin/xscreensaver-text"], [/* 32 vars */]) = -1 ENOEXEC (Exec format error)
write(2, "strace: exec: Exec format error\n", 32strace: exec: Exec format error
) = 32
exit_group(1)                           = ?
+++ exited with 1 +++

root@poopy:~# strace perl /usr/bin/xscreensaver-text
execve("/usr/bin/perl", ["perl", "/usr/bin/xscreensaver-text"], [/* 32 vars */]) = 0
brk(0)                                  = 0x601000
mmap(NULL, 4096, PROT_READ|PROT_WRITE, MAP_PRIVATE|MAP_ANONYMOUS, -1, 0) = 0x7fd74eb1d000
access("/etc/ld.so.preload", R_OK)      = -1 ENOENT (No such file or directory)
open("/etc/ld.so.cache", O_RDONLY|O_CLOEXEC) = 3
fstat(3, {st_mode=S_IFREG|0644, st_size=198969, ...}) = 0
mmap(NULL, 198969, PROT_READ, MAP_PRIVATE, 3, 0) = 0x7fd74eaec000
close(3)                                = 0
open("/usr/lib64/libc.so.6", O_RDONLY|O_CLOEXEC) = 3
read(3, "\177ELF\2\1\1\0\0\0\0\0\0\0\0\0\3\0>\0\1\0\0\0 \37\2\0\0\0\0\0"..., 832) = 832
fstat(3, {st_mode=S_IFREG|0755, st_size=1868472, ...}) = 0
mmap(NULL, 3981888, PROT_READ|PROT_EXEC, MAP_PRIVATE|MAP_DENYWRITE, 3, 0) = 0x7fd74e52f000
mprotect(0x7fd74e6f1000, 2097152, PROT_NONE) = 0
mmap(0x7fd74e8f1000, 24576, PROT_READ|PROT_WRITE, MAP_PRIVATE|MAP_FIXED|MAP_DENYWRITE, 3, 0x1c2000) = 0x7fd74e8f1000
mmap(0x7fd74e8f7000, 16960, PROT_READ|PROT_WRITE, MAP_PRIVATE|MAP_FIXED|MAP_ANONYMOUS, -1, 0) = 0x7fd74e8f7000
close(3)                                = 0
mmap(NULL, 4096, PROT_READ|PROT_WRITE, MAP_PRIVATE|MAP_ANONYMOUS, -1, 0) = 0x7fd74eaeb000
mmap(NULL, 8192, PROT_READ|PROT_WRITE, MAP_PRIVATE|MAP_ANONYMOUS, -1, 0) = 0x7fd74eae9000
arch_prctl(ARCH_SET_FS, 0x7fd74eae9740) = 0
mprotect(0x7fd74e8f1000, 16384, PROT_READ) = 0
mprotect(0x7fd74eb1e000, 4096, PROT_READ) = 0
munmap(0x7fd74eaec000, 198969)          = 0
brk(0)                                  = 0x601000
brk(0x622000)                           = 0x622000
clone(child_stack=0, flags=CLONE_CHILD_CLEARTID|CLONE_CHILD_SETTID|SIGCHLD, child_tidptr=0x7fd74eae9a10) = 16061
wait4(16061, poopy
Linux 3.11.1

ven. 27 sept. 2013 14:06:27 CEST

up  2:17,  1 user
load average: 0,03, 0,06, 0,12

[{WIFEXITED(s) && WEXITSTATUS(s) == 0}], 0, NULL) = 16061
--- SIGCHLD {si_signo=SIGCHLD, si_code=CLD_EXITED, si_pid=16061, si_status=0, si_utime=2, si_stime=0} ---
exit_group(0)                           = ?
+++ exited with 0 +++

我的路径是:

/usr/local/sbin:/usr/sbin:/sbin:/usr/local/bin:/usr/bin:/bin:/usr/lib64/jdk/bin:/usr/lib64/jdk/jre/bin

它位于具有 i686 多库功能的 x86_64 系统上。我的语言环境是 fr_FR.utf8($LANG 和 $LC_ALL)。我会添加你们需要的任何信息。我在 '/etc/passwd' 中的 shell 是 '/bin/bash',它存在并且工作完美。用普通用户和root试过,没有区别。重击 4.2、Linux 3.11.1、glibc 2.17。在 xterms、xfce-terminal 和 ttys 中尝试过,同样的问题。

“python-config”或“intltool-merge”(以及许多其他)具有完全相同的行为。我什至曾经看到一个“配置”脚本失败并显示消息“ac_cv_somevariable:找不到命令”。知道在哪里寻找调试吗?

谢谢。

4

4 回答 4

3

从 Linux 3.10 开始,如果您希望内核处理解释脚本,则必须将名为 CONFIG_BINFMT_SCRIPT 的新选项设置为 Y。

更多解释:http: //cateee.net/lkddb/web-lkddb/BINFMT_SCRIPT.html

如果您将其编译为模块,请尝试 modprobe binfmt_script 模块,然后测试您的脚本。

于 2013-10-06T03:09:57.063 回答
1

你试过了吗

#!/usr/bin/perl

代替

#!/bin/perl

?

于 2013-09-27T12:46:13.877 回答
1

解决!

内核从 3.10 开始有了一个新选项:CONFIG_BINFMT_SCRIPT。它在这里被编译为一个模块,所以默认不加载!加载模块modprobe binfmt_script或构建内核可以CONFIG_BINFMT_SCRIPT=y解决问题。谢谢!

于 2013-10-06T08:49:29.273 回答
0

注意:这个分析是错误的。 od -x输出“短转换(2 字节)整数”。我认为它正在输出od -xC网络顺序中的所有字节。

快速分析二进制转储:

2123 752f 7273 622f 6e69  // hex bytes
! #  u /  r s  b /  n i

!#u/rsb/ni     // condensed
#!/usr/bin     // 2-flipped
#!/bin/perl -w // question line

我的猜测是问题不在您的系统上,而是在您的系统和每个文件的在线公共存储库之间的一个系统上进行编码和解释。

在下载文件时嗅探文件可能会有所帮助吗?(希望你能找到未加密的东西,你也可以检查每个机器跃点的二进制转储)

编辑:/etc/inputrc在大多数情况下,Vim 键应该通过更正来修复。如果不是(并且您没有使用 zsh),那么它可能是相关的。

于 2013-09-27T13:35:56.743 回答