Depois de ler várias perguntas sobre este tópico, ainda me sinto perdido. Eu li sugestões de que se deve definir as variáveis de ambiente incluindo $PATH
em em .profile
vez de especificamente em .bashrc
ou .zshrc
, e foi isso que fiz.
Meu shell padrão é zsh
e eu configurei set-option -g default-shell $SHELL
em tmux.conf
.
No entanto, agora, sempre que inicio as sessões do tmux, aparentemente ele não detecta nenhuma modificação $PATH
e apenas fontes .zshrc
. Minha solução atual é adicionar source ~/.profile
no final de .zshrc
, o que não acho que seja a coisa certa a fazer.
Esta postagem indica que o tmux/screen geralmente é executado como subshells em vez de shells de login e, portanto, não necessariamente origina arquivos .profile
. No entanto, outro post afirmou que, se você pode executar logout
no shell, é um shell de login, o que eu realmente consegui. Muitas postagens também alegaram que tmux
deveria procurar .bash_profile
plus .profile
, mas ignoraria .bashrc
, o que aparentemente não é o que aconteceu no meu caso do equivalente zsh.
Qual é a melhor prática para usar o tmux com o zsh e fazer com que ele colete corretamente as variáveis de ambiente, afinal?
O comportamento que você descreve é o esperado. As variáveis de ambiente são definidas em
.profile
, que é lido quando você faz login. Iniciar uma nova sessão do tmux não faz o login. O Tmux inicia um shell de login por padrão, mas você desativou isso na configuração, então as janelas do tmux apenas herdar o ambiente externo.Se você colocar
source .profile
no seu.zshrc
, isso substituirá qualquer ambiente em que o shell esteja sendo executado. Isso significa que você não pode executar um shell dentro de um ambiente diferente do seu padrão, por exemplo, tentar algo com umPATH
.Basta remover
source .profile
de.zshrc
. Você terá seu ambiente padrão, definido no momento do login, em todos os shells.Se o seu shell de login for zsh, observe que ele lê
.zprofile
no momento do login, não.profile
. Isso é diferente do bash, que lê.profile
se não houver nenhum arquivo.bash_profile
. Zsh funciona de forma diferente porque sua sintaxe é diferente de sh, então ele não pode ler.profile
diretamente. Se você quiser ter um.profile
que funcione em sh para logins de GUI e também usar o mesmo arquivo para logins em modo de texto, e você tiver zsh definido como seu shell de login, use a seguinte linha como seu~/.zprofile
:Se o tmux estiver configurado para executar um shell de login, todas as janelas do tmux substituirão o ambiente circundante em vez de herdá-lo. Isso significa que se você definir novas variáveis fora do tmux, você ainda as terá na sessão do tmux, mas se você alterar os valores das variáveis que já estão definidas, suas alterações serão perdidas dentro do tmux. Em suma, o comportamento padrão do tmux não faz muito sentido. Evitar isso é o ponto da
set-option -g default-command $SHELL
linha em~/.tmux.conf
.Se você usa o tmux como uma forma de fazer um “novo login”, você pode preferir que cada janela seja executada em um novo ambiente. Nesse caso, você provavelmente deve limpar seu ambiente com algo como
E lembre-se que se o seu shell de login for zsh, então ele lê
.zprofile
, não.profile
.Você deve remover o seu
set-option -g default-shell $SHELL
de.tmux.conf
; não é necessário, poistmux
usará oSHELL
envvar por padrão.Isto é o que a página de manual diz:
tmux
iniciará um shell de login (ou seja, um shell que está originando~/.profile
ou~/.zprofile
-- e~/.zlogout
ou~/.bash_logout
antes de sair) por padrão:Veja aqui uma discussão sobre esse comportamento - que é bastante surpreendente e diferente do de
screen
.Portanto, se você deseja
tmux
iniciar um shell sem login usando seu shell padrão, coloque o seguinte em seu~/.tmux.conf
:e se você quiser executar um shell de login com outro shell que não seja o padrão: