Jump to content

Featured Replies

Posted

You are reading Part 24 of the 57-part series: Harden and Secure Linux Servers. [Level 3]

This series covers progressive security measures, from fundamental hardening techniques to enterprise-grade defense strategies. Each article delves into a specific security practice, explaining its importance and providing step-by-step guidance for implementation.

To explore more security best practices, visit the main guide for a full breakdown of all levels and recommendations.

Encryption ensures that even if attackers gain access to your data, they cannot read or modify it without the correct decryption key. This is crucial for:
Protecting sensitive files from unauthorized access.
Securing network communication to prevent interception.
Ensuring compliance with security regulations (GDPR, HIPAA, PCI-DSS).

Encryption is applied in two main areas:

  1. Data at Rest – Encrypting files, directories, and disk partitions.

  2. Data in Transit – Securing data transferred over networks.

How to Encrypt Data at Rest (Stored Data)

1. Encrypt Files and Directories Using eCryptfs (Ubuntu/Debian)

eCryptfs is a simple file-level encryption tool that encrypts files on-the-fly.

  1. Install eCryptfs:

    sudo apt install ecryptfs-utils -y
    
  2. Enable private directory encryption for a user:

    sudo ecryptfs-setup-private
    
  3. After setup, encrypted files are stored in:

    ~/.Private
    
2. Encrypt Entire Disk or Partitions with LUKS

LUKS (Linux Unified Key Setup) is the standard for full-disk encryption.

  1. Install LUKS:

    sudo apt install cryptsetup -y
    
  2. Encrypt a partition (e.g., /dev/sdb1):

    sudo cryptsetup luksFormat /dev/sdb1
    
  3. Open and mount the encrypted partition:

    sudo cryptsetup luksOpen /dev/sdb1 my_secure_data
    sudo mkfs.ext4 /dev/mapper/my_secure_data
    sudo mount /dev/mapper/my_secure_data /mnt/secure
    
  4. Automatically unlock LUKS partitions at boot (optional):

    sudo nano /etc/crypttab
    

    Add:

    my_secure_data /dev/sdb1 none luks
    

How to Encrypt Data in Transit (Network Traffic)

1. Force HTTPS for Web Traffic (SSL/TLS Encryption)

Use Let’s Encrypt to install SSL certificates for web servers.

  1. Install Certbot (Let’s Encrypt SSL tool):

    sudo apt install certbot -y
    
  2. Enable HTTPS on Nginx/Apache:

    sudo certbot --nginx  # For Nginx
    sudo certbot --apache  # For Apache
    
  3. Verify HTTPS is working:

    curl -I https://yourdomain.com
    
2. Encrypt File Transfers Using SFTP (Instead of FTP)

Regular FTP is insecure. Use SFTP (SSH File Transfer Protocol) instead.

  • To transfer files securely using SFTP:

    sftp username@your_server_ip
    
  • To securely copy files via SCP:

    scp file.txt username@your_server_ip:/home/username/
    
3. Secure Remote Access with a VPN (WireGuard or OpenVPN)

A VPN encrypts all network traffic between your devices and the server.

  1. Install WireGuard:

    sudo apt install wireguard -y
    
  2. Generate keys:

    wg genkey | tee privatekey | wg pubkey > publickey
    
  3. Set up WireGuard configuration in /etc/wireguard/wg0.conf (Example for private networking).

Best Practices for Encryption Security

Use strong encryption algorithms (AES-256, RSA-4096).
Rotate encryption keys regularly to prevent long-term compromise.
Store encryption keys securely (use hardware security modules (HSMs) if available).
Monitor logs for encryption failures (journalctl -xe | grep crypt).
Use end-to-end encryption when communicating over untrusted networks.

By encrypting data at rest and in transit, you protect sensitive information from unauthorized access, breaches, and data leaks, ensuring a secure Linux environment.

  • Views 184
  • Created
  • Last Reply

Create an account or sign in to comment

Important Information

Terms of Use Privacy Policy Guidelines We have placed cookies on your device to help make this website better. You can adjust your cookie settings, otherwise we'll assume you're okay to continue.

Configure browser push notifications

Chrome (Android)
  1. Tap the lock icon next to the address bar.
  2. Tap Permissions → Notifications.
  3. Adjust your preference.
Chrome (Desktop)
  1. Click the padlock icon in the address bar.
  2. Select Site settings.
  3. Find Notifications and adjust your preference.