~/.profile
zazwyczaj nie jest odczytywany podczas uruchamiania ssh somecommand
, w przeciwieństwie do interaktywnej sesji ssh (lub innej metody logowania, w której rozpoczyna się sesję interaktywną).
Ssh obsługuje wysyłanie zmiennych środowiskowych. W OpenSSH użyj SendEnv
dyrektywy w ~/.ssh/config
. Jednak konkretna zmienna środowiskowa musi być włączona z AcceptEnv
dyrektywą w konfiguracji serwera , więc może to nie zadziałać.
OpenSSH umożliwia także ustawianie zmiennych środowiskowych po stronie serwera. Ponownie należy to włączyć w konfiguracji serwera, tutaj z PermitUserEnvironment
dyrektywą. Zmienne można ustawić w pliku ~/.ssh/environment
. Zakładając, że korzystasz z uwierzytelniania za pomocą klucza publicznego, możesz również ustawić zmienne dla poszczególnych kluczy w ~/.ssh/authorized_keys
: dodaj environment="FOO=bar"
na początku odpowiedniego wiersza.
Jedną rzeczą, która moim zdaniem zawsze działa (co dziwne), o ile korzystasz z uwierzytelniania za pomocą klucza publicznego, to (ab) użycie command=
opcji z authorized_keys
pliku. Klawisz z command
opcją nadaje się tylko do uruchomienia określonej komendy; ale polecenie w authorized_keys
pliku działa ze zmienną środowiskową SSH_ORIGINAL_COMMAND
ustawioną na polecenie określone przez użytkownika (puste dla sesji interaktywnych). Możesz więc użyć czegoś takiego w ~/.ssh/authorized_keys
(oczywiście nie będzie to miało zastosowania, jeśli nie użyjesz tego klucza do uwierzytelnienia):
command="export LD_LIBRARY_PATH=\"$HOME\"/lib;
if [ -n \"$SSH_ORIGINAL_COMMAND\" ]; then
eval \"$SSH_ORIGINAL_COMMAND\";
else exec \"$SHELL\"; fi" ssh-rsa …
Zauważ, że wstawiłem powyżej podziału linii dla czytelności, ale tak naprawdę musi to być wszystko w jednym wierszu.
Inną możliwością jest napisanie skryptu opakowania ~/bin/rsync-wrapper
na serwerze, coś w rodzaju
#!/bin/sh
. ~/.profile
exec rsync "$@"
Następnie przejść --rsync-path='bin/rsync-wrapper'
na rsync
linii poleceń. Argument do --rsync-path
jest rozszerzany przez powłokę, więc jeśli wolisz, możesz ustawić linię poleceń rsync na własną rękę, przekazując coś podobnego --rsync-path='. ~/.profile; rsync'
.
Istnieje inna droga, która zależy od tego, czy twoja powłoka logowania jest bash lub zsh. Bash zawsze czyta, ~/.bashrc
gdy jest wywoływany przez rshd lub sshd, nawet jeśli nie jest interaktywny (ale nie, jeśli jest wywoływany jako sh
). Zsh zawsze czyta ~/.zshenv
.
## ~/.bashrc
if [[ $- != *i* ]]; then
# Either .bashrc was sourced explicitly, or this is an rsh/ssh session.
. ~/.profile
fi
## ~/.zshenv
if [[ $(ps -p $PPID -o comm=) = [rs]shd && $- != *l* ]]; then
# Not a login shell, but this is an rsh/ssh session
. ~/.profile
fi