У меня есть общее представление о том, как можно установить $ PATH, но есть ли документация, которая полностью описывает, где Mac OS получает все пути, которые добавляются к $ PATH? Мне известны такие вещи, как /etc/profile , /etc/paths и /etc/profile.d , но есть ли другие сценарии, которые в конечном итоге влияют на значение $ PATH? Я также не очень хорошо знаком между не входящими в систему и входящими в нее оболочками (.bashrc , .bash_profile), но я знаю об основных различиях.
2 ответа
Обычно ваш PATH устанавливается оболочкой. Для Bash все объяснено в руководстве. Вы также можете открыть man bash и перейти к INVOCATION .
Вызывается как интерактивная оболочка для входа или с --login
Когда Bash вызывается как интерактивная оболочка входа в систему или как неинтерактивная оболочка с параметром --login, она сначала читает и выполняет команды из файла /etc /profile, если этот файл существует. После прочтения этого файла он ищет ~ /.bash_profile, ~ /.bash_login и ~ /.profile в указанном порядке, а также читает и выполняет команды из первой, которая существует и доступна для чтения.
Вызывается как интерактивная оболочка без авторизации
Когда запускается интерактивная оболочка, которая не является оболочкой входа в систему, Bash читает и выполняет команды из ~ /.bashrc, если этот файл существует. В OS X, кроме того, есть
path_helperкоторый читает содержимое/etc/paths.dи добавляет его к вашему пути.
Ключевым моментом здесь является то, что в OS X Терминал открывает оболочку входа по умолчанию, в то время как в Linux оболочки обычно запускаются как оболочки без входа в систему. У Джоша Стейгера есть хорошее объяснение того, как входить в систему и не входить в систему.
Итак, по сути, есть только эти два три, где вы можете установить пути:
/etc/profile(который вызываетpath_helper)/etc/pathsи/etc/paths.d( вызывается изpath_helper)- ваш файл конфигурации оболочки (
.bash_profile)
Пути в /etc/paths и /etc/paths.d/* обычно добавляются в PATH помощью path_helper. path_helper запускается из /etc/profile , поэтому он запускается, когда bash вызывается как интерактивная оболочка входа в систему, но не когда bash вызывается как оболочка без входа в систему или неинтерактивная оболочка.
/etc/paths по умолчанию содержит /usr/local/bin , а /etc/paths.d/ по умолчанию пуст.
Terminal и iTerm 2 по умолчанию открывают новые оболочки в качестве оболочек входа в систему, и оболочка, открываемая при подключении к компьютеру по ssh, также является оболочкой входа в систему. Многие эмуляторы терминалов на других платформах, tmux и в режиме оболочки в Emacs открывают новые оболочки как оболочки без входа в систему.
Я добавил эту строку в /etc/launchd.conf:
setenv PATH ~/bin:/usr/local/bin:/usr/local/sbin:/usr/bin:/bin:/usr/sbin:/sbin:/usr/libexec:/usr/texbin
Изменяет значение PATH корневого процесса launchd. Это значение наследуется всеми другими процессами, включая процессы, запускаемые пользователем. Вы можете применить изменения к /etc/launchd.conf , перезапустив или запустив launchctl < /etc/launchd.conf; sudo launchctl < /etc/launchd.conf и процессы перезапуска.
В OS X ~/.profile не читается при графическом входе в систему. Если существуют и ~/.bash_profile и ~/.profile , bash также не читает ~/.profile .
~/.MacOSX/environment.plist перестал работать в 10.8.
