В скриптах первая строка должна указывать путь к интерпретатору.
Но на разных серверах Linux, Unix или BSD этот путь может быть разным.
Что предпочтительнее?
#!/usr/bin/env bash
или
#!/bin/bash
Если вы хотите использовать установленную системой версию данного интерпретатора, установленного в стандартном месте, используйте прямой путь. Если вы хотите использовать любую версию интерпретатора, которая появляется первой у пользователя $PATH
, используйте #!/usr/bin/env ...
.
Команда env
вызывает указанную команду, позволяя вам устанавливать или сбрасывать переменные окружения:
env FOO=BAR do-something
env DISPLAY=:0.0 xterm -ls &
Если вы не укажете какие-либо переменные окружения или другие параметры, он просто вызовет именованную команду. (Использовать его таким образом, возможно, немного хак.)
Цель написания Шебанга как
#!/usr/bin/env interp
это вызвать все, что interp
появляется первым в $PATH
.
Это означает , что вы не должны знать, когда писал сценарий, где именно interp
находится (скажем, если он может быть в любом /bin
, /usr/bin
или /usr/local/bin
). Конечно, вы должны знать, что env
это так /usr/bin/env
, но это кажется достаточно универсальным.
Преимущество состоит в том, что он вызывает любую версию интерпретатора, которая появляется первой у пользователя $PATH
. Недостаток является то , что он вызывает какая версия интерпретатора появляется первой в пользователе $PATH
.
Например, предположим, что я установил личную сборку в perl
своем домашнем каталоге, как $HOME/bin/perl
и у меня $HOME/bin
в передней части $PATH
. Если я запускаю скрипт, чей шебанг
#!/usr/bin/env perl
тогда он будет запущен с моим собственным установленным perl
исполняемым файлом - что может быть не очень хорошо. Автор сценария, вероятно, не проверял его с использованием Perl, который я создал из исходного кода месяц назад.
Для чего-то вроде Perl или Bash, которые могут быть установлены в согласованном месте на большинстве систем ( /usr/bin/perl
и /bin/bash
, соответственно), я бы использовал прямой путь к команде. Для чего-то более неясного, что могло бы быть установлено по-разному в разных системах, я бы либо воспользовался /usr/bin/env
уловкой, либо я бы написал установщик, который корректирует строку shebang по мере установки скрипта. (Раньше я делал это для моих скриптов Perl.)
ОБНОВЛЕНИЕ: В этом ответе на этот вопрос я подробно остановился на сайте Unix & Linux .
#!/usr/bin/perl
а затем использоватьuse strict; use warnings;
в теле сценария, а не#!/usr/bin/perl -w
. Но-T
должен быть на Шебанге.#!
линии не использовать$PATH
. Вы должны указать путь переводчика. (Я только что понял, что, по крайней мере, в моей системе, это может быть относительный путь, но это редко полезно.)Лучшая практика заключается в следующем:
И так далее...
Когда Ubuntu впервые начал использовать dash, некоторые скрипты сломались. Была дискуссия по этому поводу. Большинство сценариев были написаны
#!/bin/sh
с ссылкой на / bin / bash. Согласие таково: автор сценария отвечает за указание интерпретатора. Поэтому, если ваш скрипт всегда должен вызываться с помощью BASH, укажите его из среды. Это избавляет вас от необходимости угадывать путь, который отличается в разных системах Unix / Linux. Кроме того, это будет работать, если завтра / bin / sh станет ссылкой на какую-то другую оболочку, например / bin / wthsh, или на какую-то другую неявку.источник
#!/bin/bash
. Я согласен, что автор сценария отвечает за указание переводчика, но все, что это означает, это если вам нужен bash, скажем, bash, а не shК вашему сведению, она
#!
нужна вам#
. Вы используете эту строку, чтобы определить, с каким интерпретатором запускать скрипт.По умолчанию Ubuntu ссылается
/bin/sh
на dashВ зависимости от того, как много вы хотели бы узнать о dash и почему dash используется для системных оболочек или оболочек deamon, смотрите:
cyberciti.biz тире
Справочная страница Ubuntu dash
Bash является оболочкой по умолчанию, используемой большинством пользователей Linux, и имеет функции, отличные от dash. Сценарий, написанный для bash, может работать или не работать должным образом, если он запускается с помощью dash, чем сложнее скрипт, тем меньше вероятность его запуска.
Скрипт, написанный для perl, python и т. Д., Вообще не будет работать с
/bin/sh
или/bin/bash
.Поэтому, когда вы пишете сценарий, вы определяете, какой интерпретатор следует использовать с ши-бен
Выбор того, что использовать, сделан автором сценария, и одно не лучше другого, все они имеют различные особенности, преимущества и недостатки.
источник