I’ve seen many comments here in Ask Ubuntu regarding preference in using sudo -s
rather than sudo su
.
For me, that two commands do exactly the same. But why is sudo -s
supposed to be better?
I’ve seen many comments here in Ask Ubuntu regarding preference in using sudo -s
rather than sudo su
.
For me, that two commands do exactly the same. But why is sudo -s
supposed to be better?
I think
sudo -s
is not "better", it's just different.sudo -s
keeps your $HOME directory, so when you start programs, they will use your (and not root's) config files etc. Disadvantage: they can also change the ownership of your files in the $HOME directory, typical example is the
.Xauthority
file, but I have never experienced a problem with that.sudo su
orsudo -i
programs will use the root's home directory and its config files. This might be more intuitive, but it also means that it will not use any configuration you may have set for yourself (aliases, bash history,...).
Because
sudo -s
will not change your environment variables, especially$HOME
, which will stayHOME=/home/USER
. If you usesudo su
this will change toHOME=/root
which can have negative side effects when programs you start try to access your user's home directory.So basically it's like
sudo
vsgksudo
when running graphical programs.Aside from the already mentioned differences with environment variables, I find
sudo su
silly and wasteful because you are askingsudo
to runsu
as root, and ask it to run a shell as root. Why ask a program to ask a program to give you a root shell, when you can just have the first program give you that shell? Does that matter in any practical sense? No, I'm just pedantic.I would disagree with other answers when considering the cases when you want to log in as a user who do not have a shell. That is a very common case with users assigned to services.
Using "sudo su" will start the shell specified by the user. However in the case of a user assigned to server process, the shell is /usr/bin/false and the logging will fail. Instead you should enter as:
that will log you in and cd to its home path, even if the user does not have a shell assigned