Настройка $PATH в /etc / profile не влияет на root

я добавил в каталог PATH in /etc/profile. Это работает для моей учетной записи пользователя, но не для root. Его легко добавить в мой /root/.bashrc но я хотел бы понять, что случилось. Это в основном немодифицированный Debian 6, поэтому я думаю, что мои изменения должны сделать трюк.

вот мой /etc/profile:

# /etc/profile: system-wide .profile file for the Bourne shell (sh(1))
# and Bourne compatible shells (bash(1), ksh(1), ash(1), ...).

if [ "`id -u`" -eq 0 ]; then
  PATH="/usr/lib/distcc/bin:/usr/local/sbin:/usr/local/bin:/usr/sbin:/usr/bin:/sbin:/bin"
else
  PATH="/usr/lib/distcc/bin:/usr/local/bin:/usr/bin:/bin:/usr/local/games:/usr/games"
fi
export PATH

if [ "$PS1" ]; then
  if [ "$BASH" ]; then
    # The file bash.bashrc already sets the default PS1.
    # PS1='h:w$ '
    if [ -f /etc/bash.bashrc ]; then
      . /etc/bash.bashrc
    fi
  else
    if [ "`id -u`" -eq 0 ]; then
      PS1='# '
    else
      PS1='$ '
    fi
  fi
fi

# The default umask is now handled by pam_umask.
# See pam_umask(8) and /etc/login.defs.

if [ -d /etc/profile.d ]; then
  for i in /etc/profile.d/*.sh; do
    if [ -r $i ]; then
      . $i
    fi
  done
  unset i
fi

редактировать: я добавил Это distcc-stuff. Вот какой echo $PATH говорит:

$ echo $PATH
/usr/lib/distcc/bin:/usr/local/bin:/usr/bin:/bin:/usr/local/games:/usr/games
# echo $PATH
/usr/local/sbin:/usr/local/bin:/usr/sbin:/usr/bin:/sbin:/bin
14
задан phs
24.04.2023 2:36 Количество просмотров материала 2558
Распечатать страницу

3 ответа

вам нужно запустить оболочку входа (или запустить неинтерактивную оболочку, но это не то, что вы хотите), чтобы загрузить /etc/profile.

использовать

su - username

или в случае root

su -

для этого.

- то же самое, что -l или --login и делает оболочку оболочкой входа.

6
отвечен Daniel Beck 2023-04-25 10:24

необходима оболочка входа в систему, которую можно создать с помощью sudo:

sudo bash --login <command>
0
отвечен Hazok 2023-04-25 12:41

вам нужно имитировать оболочку входа, которую вы можете сделать с помощью sudo -i:

sudo -i <command>

С man sudo:

 -i [command]
             The -i (simulate initial login) option runs the shell specified by the password
             database entry of the target user as a login shell.  This means that login-spe‐
             cific resource files such as .profile or .login will be read by the shell.  If a
             command is specified, it is passed to the shell for execution via the shell's -c
             option.  If no command is specified, an interactive shell is executed.  sudo
             attempts to change to that user's home directory before running the shell.  The
             security policy shall initialize the environment to a minimal set of variables,
             similar to what is present when a user logs in.  The Command Environment section
             in the sudoers(5) manual documents how the -i option affects the environment in
             which a command is run when the sudoers policy is in use.
0
отвечен phs 2023-04-25 14:58

Постоянная ссылка на данную страницу: [ Скопировать ссылку | Сгенерировать QR-код ]

Ваш ответ

Опубликуйте как Гость или авторизуйтесь

Имя
Вверх