The instructions in How do I set PATH variables for all users on a server? work to set the PATH for all ‘normal’ users. However, if I do sudo -s
and then printenv PATH
the updated path is not shown. I’ve taken a look at for example Setting TeX Live path for root, but this does not seem to make sense to me, perhaps as I’m from a Windows background. Is there any way to set the truly system-wide path, such that the entries are inherited by absolutely every process running on the system?
SOLUTION
Setting global environment variables should still be performed in /etc/environment
, but as you pointed out, using sudo -s
has the effect of these variables are “vanished”.
The reason for that is sudo
has a policy of resetting the Environment and setting a secure path. It is enabled by default:
/etc/sudoers:
Defaults env_reset
Defaults secure_path="/usr/local/sbin:/usr/local/bin:/usr/sbin:/usr/bin:/sbin:/bin"
Thus whatever is set in the /etc/environment
for the path is overridden by sudo
.
The manual page for sudoers
states:
env_reset If set, sudo will reset the environment to only contain
the LOGNAME, MAIL, SHELL, USER, USERNAME and the SUDO_*
variables. Any variables in the caller's environment
that match the env_keep and env_check lists are then
added. The default contents of the env_keep and
env_check lists are displayed when sudo is run by root
with the -V option. If the secure_path option is set,
its value will be used for the PATH environment
variable. This flag is on by default.
As a workaround, you can use sudo su
that will provide a shell with root privileges but containing the right PATH.
Original Answer
You should set it in /etc/environment
.
Try sudo YOUR_TEXT_EDITOR /etc/environment
(make sure to create a backup first).
For more information: EnvironmentVariables
System-wide environment variables
Environment variable settings that affect the system as a whole (rather then just a particular user) should not be placed in any of the many system-level scripts that get executed when the system or the desktop session are loaded, but into
/etc/environment
– This file is specifically meant for system-wide environment variable settings. It is not a script file, but rather consists of assignment expressions, one per line. Specifically, this file stores the system-wide locale and path settings.Not recommended:
/etc/profile
– This file gets executed whenever a bash login shell is entered (e.g. when logging in from the console or over ssh), as well as by the DisplayManager when the desktop session loads. This is probably the file you will get referred to when asking veteran UNIX system administrators about environment variables. In Ubuntu, however, this file does little more then invoke the /etc/bash.bashrc file.
/etc/bash.bashrc
– This is the system-wide version of the ~/.bashrc file. Ubuntu is configured by default to execute this file whenever a user enters a shell or the desktop environment.