Long-Term Supported Versions

    User and User Group Management

    In Linux, each common user has an account, including the user name, password, and home directory. There are also special users created for specific purposes, and the most important special user is the admin account whose default user name is root. In addition, Linux provides user groups so that each user belongs to at least one group, facilitating permission management.

    The control of users and user groups is a core element of openEuler security management. This topic introduces the user and group management commands and explains how to assign privileges to common users in graphical user interface and on command lines.

    Managing Users

    Adding a User

    useradd Command

    Run the useradd command as the user root to add user information to the system. In the command, options indicates related parameters and username indicates the user name.

    useradd [options] username
    

    User Information Files

    The following files contain user account information:

    • /etc/passwd: user account information
    • /etc/shadow file: user account encryption information
    • /etc/group file: group information
    • /etc/default/useradd: default configurations
    • /etc/login.defs: system wide settings
    • /etc/skel: default directory that holds initial configuration files

    Example

    For example, to create a user named userexample, run the following command as the user root:

    # useradd userexample
    

    NOTE:
    If no prompt is displayed, the user is successfully created. After the user is created, run the passwd command to assign a password to the user. A new account without a password will be banned.

    To view information about the new user, run the id command:

    # id userexample
    uid=502(userexample)    gid=502(userexample)    groups=502(userexample)
    

    To change the password of the userexample, run the following command:

    # passwd userexample
    

    It is recommended that the new user password meet the complexity requirements. The password complexity requirements are as follows:

    1. A password must contain at least eight characters.
    2. A password must contain at least three of the following types: uppercase letters, lowercase letters, digits, and special characters.
    3. A password must be different from the account name.
    4. A password cannot contain words in the dictionary.
      • Querying a dictionary In the installed openEuler environment, you can run the following command to export the dictionary library file dictionary.txt, and then check whether the password is in the dictionary.
        cracklib-unpacker /usr/share/cracklib/pw_dict > dictionary.txt
        
      • Modifying a dictionary
        1. Modify the exported dictionary library file, and then run the following command to update the dictionary library:
          # create-cracklib-dict dictionary.txt
          
        2. Run the following command to add another dictionary file custom.txt to the original dictionary library.
          # create-cracklib-dict dictionary.txt custom.txt
          

    Then, enter the password and confirm it as prompted:

    # passwd userexample
    Changing password for user userexample.
    New password:
    Retype new password:
    passwd: all authentication tokens updated successfully.
    

    NOTE:
    If the command output contains BAD PASSWORD: The password fails the dictionary check - it is too simplistic/sytematic, the password is too simple and needs to be reset.

    Modifying a User Account

    Changing a Password

    Common users can change their passwords using the passwd command. Only the admin is allowed to use the passwd username command to change passwords for other users.

    Changing User's Login Shell

    Common users can use the chsh command to change their login shell. Only the admin is allowed to run the chsh username command to change login shell for other users.

    Users can also run the usermod command as the user root to modify the shell information. In the command, new_shell_path indicates the target shell path, and username indicates the user name to be modified. Change them based on the site requirements.

    usermod -s new_shell_path username
    

    For example, to change the shell of userexample to csh, run the following command:

    # usermod -s /bin/csh userexample
    

    Changing the Home Directory

    • To change the home directory, run the following command as the user root. In the command, new_home_directory indicates the created target home directory, and username indicates the user name to be changed. Change them based on the site requirements.

      usermod -d new_home_directory username
      
    • To move the content in the current home directory to a new one, run the usermod command with the -m option:

      usermod -d new_home_directory -m username
      

    Changing a UID

    To change the user ID, run the following command as the user root. In the command, UID indicates the target user ID and username indicates the user name. Change them based on the site requirements.

    usermod -u UID username
    

    The usermod command can change a user's UID in all files and directories under the user's home directory. However, for files outside the user's home directory, their owners can only be changed using the chown command.

    Changing Account Expiry Date

    If the shadow password is used, run the following command as the user root to change the validity period of an account. In the command, MM, DD, and YY indicate the month, day, and year, respectively, and username indicates the user name. Change them based on the site requirements.

    usermod -e MM/DD/YY username
    

    Deleting a User

    Run the userdel command as the user root to delete an existing user.

    For example, run the following command to delete user Test:

    # userdel Test
    

    If you also need to delete the user's home directory and all contents in the directory, run the userdel command with the -r option to delete them recursively.

    NOTE:
    You are not advised to directly delete a user who has logged in to the system. To forcibly delete a user, run the userdel -f Test command.

    Granting Rights to a Common User

    The sudo command allows common users to execute commands that can be executed only by administrator accounts.

    The sudo command allows the user specified in the /etc/sudoers file to execute the administrator account commands. For example, an authorized common user can run:

    sudo /usr/sbin/useradd newuserl
    

    The sudo command can specify a common user that has been added to the /etc/sudoers file to process tasks as required.

    The information configured in the /etc/sudoers file is as follows:

    • Blank lines or comment lines starting with #: Have no specific functions.

    • Optional host alias lines: Create the name of a host list. The lines must start with Host_Alias. The host names in the list must be separated by commas (,). For example:

      Host_Alias  linux=ted1,ted2
      

      ted1 and ted2 are two host names, which can be called linux.

    • Optional user alias lines: Create the name of a user list. The lines must start with User_Alias. The user names in the list must be separated by commas (,). The user alias lines have the same format as the host alias lines.

    • Optional command alias lines: Create the name of a command list. The lines must start with Cmnd_Alias. The commands in the list must be separated by commas (,).

    • Optional running mode alias lines: Create the name of a user list. The difference is that such alias can enable a user in the list to run the sudo command.

    • Necessary declaration lines for user access:

      The declaration syntax for user access is as follows:

      user host = [ run as user ] command list
      

      Set the user to a real user name or a defined user alias, and set the host to a real host name or a defined host alias. By default, all the commands executed by sudo are executed as user root. If you want to use another account, you can specify it. command list is either a command list separated by commas (,) or a defined command alias. For example:

      ted1   ted2=/sbin/shutdown
      

      In this example, ted1 can run the shutdown command on ted2.

      newuser1 ted1=(root) /usr/sbin/useradd,/usr/sbin/userdel
      

      This indicates that newuser1 on the ted1 host can run the useradd and userdel commands as the user root.

      NOTE:

      • You can define multiple aliases in a line and separate them with colons (:).
      • You can add an exclamation mark (!) before a command or a command alias to make the command or the command alias invalid.
      • There are two keywords: ALL and NOPASSWD. ALL indicates all files, hosts, or commands, and NOPASSWD indicates that no password is required.
      • By modifying user access, you can change the access permission of a common user to be the same as that of the user root. Then, you can grant rights to the common user.

    The following is an example of the sudoers file:

    #sudoers files
    #User alias specification
    User_Alias ADMIN=ted1:POWERUSER=globus,ted2
    #user privilege specification
    ADMIN ALL=ALL
    POWERUSER ALL=ALL,!/bin/su
    

    In the preceding information:

    • User_Alias ADMIN=ted1:POWERUSER=globus,ted2

      Two aliases ADMIN and POWERUSER are defined.

    • ADMIN ALL=ALL

      ADMIN can run all commands as the user root on all hosts.

    • POWERUSER ALL=ALL,!/bin/su

      POWERUSER can run all commands except the su command as the user root on all hosts.

    Managing User Groups

    Adding a User Group

    groupadd Command

    Run the groupadd command as the root user to add user group information to the system. In the command, options indicates related parameters and groupname indicates the group name.

    groupadd [options] groupname
    

    User Group Information Files

    The following files contain user group information:

    • /etc/gshadow file: user group encryption information
    • /etc/group file: group information
    • /etc/login.defs: system wide settings

    Example

    For example, to create a user group named groupexample, run the following command as the root user:

    # groupadd groupexample
    

    Modifying a User Group

    Changing a GID

    To change the user group ID, run the following command as the root user. In the command, GID indicates the target user group ID and groupname indicates the user group name. Change them based on the site requirements.

    groupmod -g GID groupname
    

    Changing a User Group Name

    To change the user group name, run the following command as the root user. In the command, newgroupname indicates the user group new name and oldgroupname indicates the user group name. Change them based on the site requirements.

    groupmod -n newgroupname oldgroupname
    

    Deleting a User Group

    Run the groupdel command as the root user to delete an existing user group.

    For example, run the following command to delete user group Test:

    # groupdel Test
    

    NOTE:
    The user's primary group cannot be directly deleted. To forcibly delete a user's primary group, run the groupdel -f Test command.

    Adding a User to a Group or Removing a User from a Group

    Run the gpasswd command as the root user to add a user to a group or remove a user from a group.

    For example, run the following command to add the user userexample to the user group Test:

    # gpasswd -a userexample Test
    

    For example, run the following command to remove the user userexample from the user group Test:

    # gpasswd -d userexample Test
    

    Changing the Current Group of a User to a Specified Group

    If a user belongs to multiple user groups, run the newgrp command to switch the user to another user group after logging in to the system. Then, the user has the permission of other user groups.

    For example, run the following command to change the current group of the user userexample to the user group Test:

    $ newgrp Test
    

    Bug Catching

    Buggy Content

    Bug Description

    Submit As Issue

    It's a little complicated....

    I'd like to ask someone.

    PR

    Just a small problem.

    I can fix it online!

    Bug Type
    Specifications and Common Mistakes

    ● Misspellings or punctuation mistakes;

    ● Incorrect links, empty cells, or wrong formats;

    ● Chinese characters in English context;

    ● Minor inconsistencies between the UI and descriptions;

    ● Low writing fluency that does not affect understanding;

    ● Incorrect version numbers, including software package names and version numbers on the UI.

    Usability

    ● Incorrect or missing key steps;

    ● Missing prerequisites or precautions;

    ● Ambiguous figures, tables, or texts;

    ● Unclear logic, such as missing classifications, items, and steps.

    Correctness

    ● Technical principles, function descriptions, or specifications inconsistent with those of the software;

    ● Incorrect schematic or architecture diagrams;

    ● Incorrect commands or command parameters;

    ● Incorrect code;

    ● Commands inconsistent with the functions;

    ● Wrong screenshots.

    Risk Warnings

    ● Lack of risk warnings for operations that may damage the system or important data.

    Content Compliance

    ● Contents that may violate applicable laws and regulations or geo-cultural context-sensitive words and expressions;

    ● Copyright infringement.

    How satisfied are you with this document

    Not satisfied at all
    Very satisfied
    Submit
    Click to create an issue. An issue template will be automatically generated based on your feedback.
    Bug Catching
    编组 3备份