49. User Management - su, sudo
Contents
We can switch between users through the su and sudo commands. Also, we can use these two commands to perform certain command operations with the privileges of other users.
su
Here are two arguments for mesg command:
Option | Meaning |
---|---|
- or -l or ‑‑login | Start a shell as a login shell and switch to the specified user’s home directory. |
Stay on the Current Working Directory After Switching User
By default, the su command replaces the current user with the root user.
|
|
data:image/s3,"s3://crabby-images/4e0e8/4e0e8218b1f5ea21927aabe22b3f5b40bbceacb1" alt="img"
Stay on current working directory after replacing the user
When we replace root with user, we don’t need to enter a password.
Change Current Working Directory to the Switched User Home Directory
With the - or -l or -login option, we can use the new current user’s home directory as the working directory after replacing the user:
|
|
data:image/s3,"s3://crabby-images/087e8/087e881c4bc32b3a4fdb3e96fb8bee12f3e4cc9f" alt="img"
Change to root's current working directory after replacing the user
sudo
Edit Sudoers File
Locked Before Editing
A more rigorous approach, which locks the /etc/sudoers file and then opens it:
|
|
At this point, if a user logged in via another terminal also wants to edit the / etc/sudoers file via visudo, the following alert will appear:
data:image/s3,"s3://crabby-images/16ad0/16ad02875dde01bd040f02b1dbc1bb04255b9808" alt="img"
When a user is editing the / etc/sudoers file through the visudo command, there is no way for other users to use the visudo command at this point.
Naked Editing
One less rigorous approach is to open the /etc/sudoers file directly and others can edit it at the same time:
|
|
Editing the Content
|
|
|
|
data:image/s3,"s3://crabby-images/7cbfa/7cbfa417b0737f40bac73b1933846b05954401f0" alt="img"
The line that starts with usropt is our newly added configuration to the sudoers file
|
|
Run the Command as Another User
Let’s replace the current user with the newly created user:
|
|
data:image/s3,"s3://crabby-images/3c8a3/3c8a3706e6ee5e9a5a04cd8362097028a9231cf0" alt="img"
We can't run the administrator's command directly
We need to use the sudo command to run the administrator’s command:
|
|
data:image/s3,"s3://crabby-images/9567e/9567e362fd71ae67f41b3290271da974f499a3f3" alt="img"
With the sudo command, we ran the administrator's command
When configured, if the command is assigned under passwd, you need to enter the user’s password when using the command to prevent malicious abuse of account permissions by others:
|
|
data:image/s3,"s3://crabby-images/69199/6919916973e4e45c8d62c99599fde70dc4a70a3a" alt="img"
After entering the password of the usropt user, the command can be executed
Alias
We can subdivide each as a part through alias:
|
|
|
|
data:image/s3,"s3://crabby-images/bcd60/bcd60cc1058a92e5a76dd9b69b25489a66b87265" alt="img"
Replace the newer settings with the older one
wheel group
We can configure a user’s privileges the same as root through the wheel group:
|
|
|
|
data:image/s3,"s3://crabby-images/69106/691061ad0a4c2578d7a096725064cbbb3c3180c3" alt="img"
The default setting that comes with the sudoers file
Create a new user to append a wheel supplementary group to that user:
|
|
data:image/s3,"s3://crabby-images/1fb5d/1fb5d374a1557203c1c6ea5259c82f07315be9e1" alt="img"
Enables users to have root permissions by appending the wheel group to the user's supplementary group
References 22.5 su: Run a command with substitute user and group id, SU(1), Sudoers Manual, Visudo 1.8.23 Manual
Author Dong Chen
LastMod Thu Mar 21 2019