バイナリは golang ソースでコンパイルされますが、実行されません。バイナリをダウンロードしてみましたが、やはり動作しませんでした。権限がすべて正しいようです。何らかの理由でこのファイルをgoで実行すると機能します。
出力~/go$ go run src/github.com/exercism/cli/exercism/main.go1
:
NAME:
exercism - A command line tool to interact with http://exercism.io
USAGE:
main [global options] command [command options] [arguments...]
出力~/go/bin$ ./exercism
:
bash: ./exercism: Permission denied
出力~/go/bin$ ls -al
:
total 9932
drwxr-xr-x 2 joshua joshua 4096 Apr 28 12:17 .
drwxr-xr-x 5 joshua joshua 4096 Apr 28 12:17 ..
-rwxr-xr-x 1 joshua joshua 10159320 Apr 28 12:17 exercism
出力~/go/bin$ strace ./exercism
:
execve("./exercism", ["./exercism"], [/* 42 vars */]) = -1 EACCES (Permission denied)
write(2, "strace: exec: Permission denied\n", 32strace: exec: Permission denied
) = 32
exit_group(1) = ?
+++ exited with 1 +++
答え1
この設定がnoexec
関連する取り付けポイントに影響しないことを確認してください。または、スクリプトを実行するのに最適な場所を選択してください。
$ mount | grep noexec
[ snip ]
shm on /dev/shm type tmpfs (rw,nosuid,nodev,noexec,relatime)
$ cat > /dev/shm/some_script
#!/bin/sh
echo hi
$ chmod +x /dev/shm/some_script
$ /dev/shm/some_script
bash: /dev/shm/some_script: Permission denied
$ mv /dev/shm_script .
$ ./some_script
hi
noexec
誰でも書き込み可能な場所に実行可能ファイルを保存するときに発生するセキュリティ上の問題を防ぐために特別に設計されています。ファイルをそこに保存することもできますが、実行する前に他の人がファイルを書き換えることができ、今はコードを実行しません。