Adding New User in Linux
Adding a new user to your linuxbox is as simple as running a command with a argument which is the username to be created
[root@ashwin ~]# useradd ashwin
Great You have created a new user but now into the technical details how does the user gets the home directory, how is the UID,GID set, how the default shell is assigned and other different features gets assigned when addding a user.
When you add a user immediately some files are checked if the user is already present Files
1. /etc/passwd
2. /etc/groups
3. /etc/shadows
If the user is not present in the above 3 files the next step is to look for another set of files which by default assign values to a newly added user the file which is looked is
# cat /etc/login.defs
The above file contains all the default parameter like, UID, GID to be set for new user, Home Directory (If not specified explicitly). Now once the user is added the home directory is created in /home/username by default and assigned a unique UID,GID. When you see the contents of /home/username you will find files
[ashwin@ashwin ~]$ ll -a /home/ashwin/
-rw-r--r--. 1 root root 18 2009-04-08 16:16 .bash_logout
-rw-r--r--. 1 root root 176 2009-04-08 16:16 .bash_profile
-rw-r--r--. 1 root root 124 2009-04-08 16:16 .bashrc
-rw-r--r--. 1 root root 500 2009-04-10 17:22 .emacs
drwxr-xr-x. 2 root root 4096 2009-03-18 06:22 .gnome2
drwxr-xr-x. 4 root root 4096 2010-03-19 12:20 .mozilla
-rw-r--r--. 1 root root 658 2009-03-02 22:50 .zshrc
Now from where these files came from, yes this files are copied to every newly added user from the /etc/skel folder.
[ashwin@ashwin ~]$ ll -a /etc/skel/
-rw-r--r--. 1 root root 18 2009-04-08 16:16 .bash_logout
-rw-r--r--. 1 root root 176 2009-04-08 16:16 .bash_profile
-rw-r--r--. 1 root root 124 2009-04-08 16:16 .bashrc
-rw-r--r--. 1 root root 500 2009-04-10 17:22 .emacs
drwxr-xr-x. 2 root root 4096 2009-03-18 06:22 .gnome2
drwxr-xr-x. 4 root root 4096 2010-03-19 12:20 .mozilla
-rw-r--r--. 1 root root 658 2009-03-02 22:50 .zshrc
Now a Bit more depth on useradd, we'll now discuss some parameters while adding a new user to change the default home directory, UID, GID, Default Shell Login, Password
The Following arguments can be used to the command useradd
-b, --base-dir BASE_DIR base directory for the new user account
home directory
-c, --comment COMMENT set the GECOS field for the new user account
-d, --home-dir HOME_DIR home directory for the new user account
-D, --defaults print or save modified default useradd
configuration
-e, --expiredate EXPIRE_DATE set account expiration date to EXPIRE_DATE
-f, --inactive INACTIVE set password inactive after expiration to INACTIVE
-g, --gid GROUP force use GROUP for the new user account
-G, --groups GROUPS list of supplementary groups for the new user account
-h, --help display this help message and exit
-k, --skel SKEL_DIR specify an alternative skel directory
-K, --key KEY=VALUE overrides /etc/login.defs defaults
-l, do not add the user to the lastlog and faillog databases
-m, --create-home create home directory for the new user account
-M, do not create user's home directory(overrides /etc/login.defs)
-N, --no-user-group do not create a group with the same name as the user
-o, --non-unique allow create user with duplicate (non-unique) UID
-p, --password PASSWORD use encrypted password for the new user account
-r, --system create a system account
-s , --shell SHELL the login shell for the new user account
-u, --uid UID force use the UID for the new user account
-U, --user-group create a group with the same name as the user
-Z, --selinux-user SEUSER use a specific SEUSER for the SELinux user mapping
Examples
1. Add user with home directory in /opt/username
[root@ashwin ~]# useradd -d /opt/ username
2. Add user with defined home directory UID, GID
[root@ashwin ~]# useradd -d /opt/ -u 800 -g 800 username
3. Defining password while adding a new user
[root@ashwin ~]# useradd -d /opt/ -u 800 -g 800 -p password username
4. Defining the login shell for the new user account
[root@ashwin ~]# useradd -d /opt/ -u 800 -g 800 -p password -s /bin/sh username
[root@ashwin ~]# useradd -d /opt/ -u 800 -g 800 -p password -s /bin/nologin username
Explore around with the parameters you would find many features in it.
Also Look For Parts Two to know more depth knowledge of User and Group adding in Linux
Very interesting website, but you must improve your logo graphics.
ReplyDelete