
Скомпилировал бинарный файл из исходников 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
существует специально для предотвращения проблем безопасности, возникающих из-за наличия мест, доступных для записи всем пользователям, для хранения исполняемых файлов; вы можете поместить туда файл, но кто-то другой может перезаписать его до того, как вы его запустите, и теперь вы не выполняете тот код, который, как вы думали, выполняете.