Types of Linux File Permissions

 

Understanding File Permissions in Linux – A Complete Beginner to Advanced Guide

Introduction

Understanding file permissions in Linux is a fundamental skill for system administrators, developers, DevOps engineers, and cybersecurity professionals. Linux is a multi-user operating system, and file permissions ensure data security, system stability, and controlled access to files and directories.

This SEO-focused guide explains Linux file permissions in simple language, with practical commands, real-world examples, and best practices.

basic of Linux File Permissions



What Are File Permissions in Linux?

File permissions define who can access a file and what actions they can perform on it. Each file and directory in Linux has a permission set that controls:

  • Who can read it

  • Who can modify it

  • Who can execute it

Linux permission model is based on:

  • User (Owner)

  • Group

  • Others (Everyone else)


Types of Linux File Permissions

PermissionSymbolMeaning
ReadrView file content
WritewModify file content
ExecutexRun file as program

For directories:

  • r → list files

  • w → create/delete files

  • x → access directory


Linux Permission Structure Explained

Example output:

-rwxr-xr-- 1 root admin 4096 file.txt

Breakdown:

  • - → File type (d = directory)

  • rwx → Owner permissions

  • r-x → Group permissions

  • r-- → Others permissions


Numeric (Octal) Permission Representation

PermissionValue
r4
w2
x1

Examples:

  • 777 → Full access to everyone

  • 755 → Owner full, others read+execute

  • 644 → Owner read/write, others read

chmod 755 script.sh

Common Permission Commands

Check Permissions

ls -l

Change Permissions

chmod 644 file.txt
chmod u+x script.sh

Change Ownership

chown user:group file.txt

Special Permissions in Linux

1. SUID (Set User ID)

Runs file with owner's privileges

chmod u+s file

2. SGID (Set Group ID)

Runs file with group privileges

chmod g+s file

3. Sticky Bit

Prevents deletion by non-owners

chmod +t /shared

Default Permissions and Umask

umask

Controls default permission creation

Example:

umask 022

File Permission Best Practices

✔ Avoid 777 permissions
✔ Use groups properly
✔ Apply least privilege principle
✔ Secure executable files
✔ Audit permissions regularly


Real-World Use Cases

  • Web server security (Apache/Nginx)

  • CI/CD pipelines

  • Docker containers

  • DevOps automation

  • Cloud server access control


FAQs

What does 755 mean in Linux permissions?

Owner has full access, others can read and execute.

What is chmod in Linux?

chmod changes file permissions.

What is chown?

chown changes file ownership.

What is umask?

Defines default permissions for new files.


Visual Explanation

Linux File Permission Structure

Conclusion

Linux file permissions are the foundation of system security and user management. Mastering them helps you prevent unauthorized access, improve server security, and manage enterprise systems efficiently.

If you're learning Linux for DevOps, cloud computing, cybersecurity, or backend development, file permission knowledge is mandatory.


Comments

Popular posts from this blog

How to Improve Node.js Performance (100% Working Techniques)

Top 10 Linux File System Basics – A Complete for Beginners