01. User Permissions id

Let's talk some history before we get into the technicalities..

A multi-user system

Before the advent of the personal computer, computer systems were centralized. For example, in a university, a computer would be located in one building on campus, while multiple users in other buildings accessed it via ssh (secure shell, just a way to login to another computer via the command line).

A centralized computing system

Since there were multiple users accessing this centralized computer at once, computer architects had to come up with a way to secure files and folders.

For example in the figure above, we needed a way for Professor Paul to read and edit students' grades files, while Bobby, Anna and Joe could only read their respective grade reports.

Thus, scientists came up with user permissions to manage the security threats of hosting a multi-user system.

Three groups for accessions

There are three groups in the Linux world in which permissions apply to.

The creator of the file, who has control over the file's accessions.
One or more users who are given access to the file/directories.
World (all)
Everyone else.

Using id to see who you are

To display the user and group names and numeric IDs of a calling process, use the id command.

$ id
uid=501(JohnDoe) gid=20(staff) groups=20(staff)

When accounts are created, they are given a uid (user ID), which is then mapped to a username. The user can then be assigned a primary gid (group ID).

Using who to see who is logged in

To display all current users logged in, use the who command.

$ who
JohnDoe console  Aug  3 12:56
JohnDoe ttys000  Aug 30 21:17
JohnDoe ttys002  Sep  5 21:49
JohnDoe ttys003  Sep  6 19:35

To display just the terminal session where the commands are coming from, user:

$ whoami
JohnDoe ttys000 Aug 30 21:17

Last logged in users

The to check who was last logged in, use the last command.

$ last
JohnDoe ttys000 Mon Apr 20 12:00 - 16:28 (2+04:27) JohnDoe ttys002 Mon Apr 20 11:27 - 11:48 (00:21) JohnDoe ttys001 Mon Apr 20 11:27 - 11:48 (00:21) JohnDoe ttys000 Mon Apr 20 11:27 - 11:48 (00:21) JohnDoe console Mon Apr 20 11:26 - 12:46 (94+01:19) reboot ~ Mon Apr 20 11:26 shutdown ~ Mon Apr 20 11:26 JohnDoe ttys002 Mon Apr 20 00:17 - 11:26 (11:08) JohnDoe ttys001 Sun Apr 19 23:09 - 11:26 (12:16) JohnDoe ttys000 Sun Apr 19 20:17 - 11:26 (15:08) JohnDoe ttys000 Sun Apr 19 09:32 - 19:25 (09:53)

Important files regarding permissions

There are two main files that store permission information on uid and gid.


The /etc/passwd is a file that contains information about every registered user on a system. It is a colon-separated file that contains the username, encrypted password, and user ID number.


The /etc/group text file defines which groups users belong to.


This file contains encrypted passwords and information about accounts and password reset dates. This information is held secure from normal users, and is only accessible by root.


This is a directory that contains the base files and directories moved into a new user's home folder upon creation.

Take your Linux skills to the next level!

How Linux Works

Take your Linux skills to the next level! Try Linux & UNIX

In this completely revised second edition of the perennial best seller How Linux Works, author Brian Ward makes the concepts behind Linux internals accessible to anyone curious about the inner workings of the operating system. Inside, you'll find the kind of knowledge that normally comes from years of experience doing things the hard way.

$ Check price
39.9539.95Amazon 5 logo(114+ reviews)

More Linux & UNIX resources

Aching back from coding all day?

Acupressure Mat & Pillow

Aching back from coding all day? Try Back Problems

Relieve your stress, back, neck and sciatic pain through 1,782 acupuncture points for immediate neck pain relief. Made for lower, upper and mid chronic back pain treatment, and improves circulation, sleep, digestion and quality of life.

$$ Check price
144.87144.87Amazon 4.5 logo(1,890+ reviews)

More Back Problems resources