Table of Contents
Step 1: Create Disk Partitions
Step 2: Format New Partitions
Step 3: Mount New Partitions
Step 4: New Partition Encryption
Step 4: Mount Encrypted Partitions Automatically
Home System Tutorial LINUX LUKS: Linux Hard Disk Data Encryption with NTFS in Linux

LUKS: Linux Hard Disk Data Encryption with NTFS in Linux

May 15, 2025 am 09:23 AM

LUKS, which stands for Linux Unified Key Setup, is a robust disk encryption method used by the Linux Kernel. It is implemented using the cryptsetup package. The cryptsetup command-line tool encrypts a volume disk in real-time using a symmetric encryption key derived from a passphrase that must be entered every time a volume, partition, or entire disk (including a USB stick) is mounted in the filesystem hierarchy. It employs the aes-cbc-essiv:sha256 cipher for encryption.

LUKS is highly recommended for encrypting entire block devices such as hard disks, USB sticks, flash disks, partitions, and volume groups on Linux systems. It is particularly useful for securing removable storage media, laptop hard drives, or Linux swap files, though it is not advised for file-level encryption.

NTFS, or New Technology File System, is a proprietary file system developed by Microsoft.

Ubuntu 24.04 offers full support for LUKS encryption and also provides native support for NTFS for Windows systems through the ntfs-3g package.

To illustrate this, I have added a new hard disk to an Ubuntu 24.04 system (identified as /dev/vdb), which will be divided into two partitions:

  • The first partition (/dev/vdb1 - primary) will be used for LUKS encryption.
  • The second partition (/dev/vdb2 - extended) will be formatted as NTFS for compatibility with both Linux and Windows systems.

These partitions will be set to mount automatically on Ubuntu 24.04 after a reboot.

Step 1: Create Disk Partitions

1. Once the hard disk is physically connected to your machine, use the ls command to list all /dev devices (the new disk will be /dev/vdb) or check the newly added HDD with the fdisk command.

<code>ls /dev/vd*
sudo fdisk -l /dev/vdb</code>
Copy after login

LUKS: Linux Hard Disk Data Encryption with NTFS in Linux

Since no filesystem has been written yet, the disk does not contain a valid partition table.

2. Next, use the cfdisk disk utility to partition the hard disk into two parts. This utility provides a text-based interface for disk partitioning.

<code>sudo cfdisk /dev/vdb</code>
Copy after login

If you are using cfdisk for the first time on this disk, you may need to select a partition table type (e.g., MBR for older systems or GPT for newer systems).

LUKS: Linux Hard Disk Data Encryption with NTFS in Linux

3. The cfdisk utility will open in interactive mode. Select the "Free Space" on your hard disk and navigate to the "New" option using the left/right arrow keys.

LUKS: Linux Hard Disk Data Encryption with NTFS in Linux

4. Choose the partition type (Primary or Extended) if prompted and set the size of the partition (in MB or GB) to create the first partition.

LUKS: Linux Hard Disk Data Encryption with NTFS in Linux

5. After creating the first partition, select "Free Space" again and choose "New" to create the second partition.

LUKS: Linux Hard Disk Data Encryption with NTFS in Linux

6. Choose the partition type (Primary or Extended) if prompted and set the size of the partition (in MB or GB) to create the second partition.

LUKS: Linux Hard Disk Data Encryption with NTFS in Linux

7. After reviewing and verifying the partitions, select "Write" to confirm and save the partitions.

LUKS: Linux Hard Disk Data Encryption with NTFS in Linux

8. Select "Quit" to exit the cfdisk utility.

LUKS: Linux Hard Disk Data Encryption with NTFS in Linux

Congratulations! Your partitions have been successfully created and are now ready to be formatted and used.

Step 2: Format New Partitions

9. To verify the disk's Partition Table again, use the fdisk command, which will display detailed partition table information.

<code>sudo fdisk -l /dev/vdb</code>
Copy after login

LUKS: Linux Hard Disk Data Encryption with NTFS in Linux

10. To format the first partition as ext4, use the following command:

<code>sudo mkfs.ext4 /dev/vdb1</code>
Copy after login

LUKS: Linux Hard Disk Data Encryption with NTFS in Linux

11. To format the second partition as NTFS, you need to install ntfs-3g and then format the second partition as NTFS.

<code>sudo apt install ntfs-3g
sudo mkfs.ntfs /dev/vdb2</code>
Copy after login

LUKS: Linux Hard Disk Data Encryption with NTFS in Linux

Step 3: Mount New Partitions

12. To make the partitions available, they must be mounted to mount points on the filesystem.

<code>sudo mkdir /mnt/partition1
sudo mkdir /mnt/partition2</code>
Copy after login

13. Next, mount the partitions to the newly created mount directories.

<code>sudo mount /dev/vdb1 /mnt/partition1
sudo mount /dev/vdb2 /mnt/partition2</code>
Copy after login

LUKS: Linux Hard Disk Data Encryption with NTFS in Linux

14. To enable auto-mounting of partitions, you need to find the UUIDs of the partitions using the blkid command.

<code>sudo blkid /dev/vdb1
sudo blkid /dev/vdb2</code>
Copy after login
Copy after login

LUKS: Linux Hard Disk Data Encryption with NTFS in Linux

15. Next, edit the /etc/fstab file and add entries for the new partitions using their UUIDs.

<code>UUID=7a1e356f-f782-4835-bd1c-5e6d64378869 /mnt/partition1 ext4 defaults 0 2
UUID=0A9AABBB53B3165A /mnt/partition2 ntfs defaults 0 2</code>
Copy after login

Step 4: New Partition Encryption

16. To encrypt partitions using cryptsetup, you need to install the cryptsetup tool as shown below:

<code>sudo apt install cryptsetup [On <b>Debian</b> Based Systems]
sudo dnf install cryptsetup [On <b>RedHat</b> Based Systems]</code>
Copy after login

17. Now, encrypt the first partition on the hard disk by issuing the following command, which will prompt you to confirm and enter a passphrase to unlock the encrypted partition.

<code>sudo cryptsetup luksFormat /dev/vdb1</code>
Copy after login

LUKS: Linux Hard Disk Data Encryption with NTFS in Linux

18. To activate this encrypted partition, it must be initialized with a name entry in the /dev/mapper directory using the cryptsetup package.

<code>sudo cryptsetup open --type luks /dev/vdb1 <strong>crypted_volume</strong></code>
Copy after login

19. Next, format the encrypted partition and mount it.

<code>sudo mkfs.ext4 /dev/mapper/crypted_volume
sudo mkdir /mnt/encrypted1
sudo mount /dev/mapper/crypted_volume /mnt/encrypted1</code>
Copy after login

LUKS: Linux Hard Disk Data Encryption with NTFS in Linux

20. For the second partition, initialize encryption using the following command.

<code>sudo cryptsetup luksFormat /dev/vdb2</code>
Copy after login

LUKS: Linux Hard Disk Data Encryption with NTFS in Linux

21. To activate this second encrypted partition, it must be initialized with a name entry in the /dev/mapper directory using the cryptsetup package.

<code>sudo cryptsetup open --type luks /dev/vdb2 crypted_volume2</code>
Copy after login

22. Next, format the second encrypted partition and mount it.

<code>sudo mkfs.ntfs /dev/mapper/crypted_volume2
sudo mkdir /mnt/encrypted2
sudo mount /dev/mapper/crypted_volume2 /mnt/encrypted2</code>
Copy after login

LUKS: Linux Hard Disk Data Encryption with NTFS in Linux

Step 4: Mount Encrypted Partitions Automatically

23. To automatically unlock and mount the encrypted partitions at boot, you need to update /etc/crypttab and /etc/fstab.

<code>sudo nano /etc/crypttab</code>
Copy after login

24. Use the blkid command to find the UUIDs of the partitions.

<code>sudo blkid /dev/vdb1
sudo blkid /dev/vdb2</code>
Copy after login
Copy after login

25. Then add encrypted partition entries in the /etc/crypttab file.

<code>crypted_volume UUID=d29f57c3-fe00-41d5-8095-d68f7f04823d none luks
crypted_volume2 UUID=1DF9CC677F758914 none luks</code>
Copy after login

26. Similarly, edit /etc/fstab and specify your device name, mount point, filesystem type, and other options.

<code>sudo nano /etc/fstab</code>
Copy after login

Add entries for the filesystems:

<code>/dev/mapper/crypted_volume /mnt/encrypted1 ext4 defaults 0 2
/dev/mapper/crypted_volume2 /mnt/encrypted2 ntfs defaults 0 2</code>
Copy after login

27. Finally, verify that the encrypted partitions are mounted correctly.

<code>df -hT</code>
Copy after login

LUKS: Linux Hard Disk Data Encryption with NTFS in Linux

As you can see, both disk partitions were automatically mounted on the Ubuntu filesystem hierarchy. As a precaution, avoid using automatically encrypted volumes from the fstab file on physically remote servers if you cannot access the reboot sequence to provide your encrypted volume password.

These settings can also be applied to all types of removable media such as USB sticks, flash memory, and external hard disks to protect important, secret, or sensitive data from eavesdropping or theft.

The above is the detailed content of LUKS: Linux Hard Disk Data Encryption with NTFS in Linux. For more information, please follow other related articles on the PHP Chinese website!

Statement of this Website
The content of this article is voluntarily contributed by netizens, and the copyright belongs to the original author. This site does not assume corresponding legal responsibility. If you find any content suspected of plagiarism or infringement, please contact admin@php.cn

Hot AI Tools

Undresser.AI Undress

Undresser.AI Undress

AI-powered app for creating realistic nude photos

AI Clothes Remover

AI Clothes Remover

Online AI tool for removing clothes from photos.

Undress AI Tool

Undress AI Tool

Undress images for free

Clothoff.io

Clothoff.io

AI clothes remover

Video Face Swap

Video Face Swap

Swap faces in any video effortlessly with our completely free AI face swap tool!

Hot Article

Roblox: Bubble Gum Simulator Infinity - How To Get And Use Royal Keys
4 weeks ago By 尊渡假赌尊渡假赌尊渡假赌
Nordhold: Fusion System, Explained
4 weeks ago By 尊渡假赌尊渡假赌尊渡假赌
Mandragora: Whispers Of The Witch Tree - How To Unlock The Grappling Hook
4 weeks ago By 尊渡假赌尊渡假赌尊渡假赌
Clair Obscur: Expedition 33 - How To Get Perfect Chroma Catalysts
2 weeks ago By 尊渡假赌尊渡假赌尊渡假赌

Hot Tools

Notepad++7.3.1

Notepad++7.3.1

Easy-to-use and free code editor

SublimeText3 Chinese version

SublimeText3 Chinese version

Chinese version, very easy to use

Zend Studio 13.0.1

Zend Studio 13.0.1

Powerful PHP integrated development environment

Dreamweaver CS6

Dreamweaver CS6

Visual web development tools

SublimeText3 Mac version

SublimeText3 Mac version

God-level code editing software (SublimeText3)

Hot Topics

Java Tutorial
1677
14
PHP Tutorial
1278
29
C# Tutorial
1257
24
What is the salary of Linux administrator? What is the salary of Linux administrator? Apr 17, 2025 am 12:24 AM

The average annual salary of Linux administrators is $75,000 to $95,000 in the United States and €40,000 to €60,000 in Europe. To increase salary, you can: 1. Continuously learn new technologies, such as cloud computing and container technology; 2. Accumulate project experience and establish Portfolio; 3. Establish a professional network and expand your network.

What are the main tasks of a Linux system administrator? What are the main tasks of a Linux system administrator? Apr 19, 2025 am 12:23 AM

The main tasks of Linux system administrators include system monitoring and performance tuning, user management, software package management, security management and backup, troubleshooting and resolution, performance optimization and best practices. 1. Use top, htop and other tools to monitor system performance and tune it. 2. Manage user accounts and permissions through useradd commands and other commands. 3. Use apt and yum to manage software packages to ensure system updates and security. 4. Configure a firewall, monitor logs, and perform data backup to ensure system security. 5. Troubleshoot and resolve through log analysis and tool use. 6. Optimize kernel parameters and application configuration, and follow best practices to improve system performance and stability.

What is the main purpose of Linux? What is the main purpose of Linux? Apr 16, 2025 am 12:19 AM

The main uses of Linux include: 1. Server operating system, 2. Embedded system, 3. Desktop operating system, 4. Development and testing environment. Linux excels in these areas, providing stability, security and efficient development tools.

What are the differences in virtualization support between Linux and Windows? What are the differences in virtualization support between Linux and Windows? Apr 22, 2025 pm 06:09 PM

The main differences between Linux and Windows in virtualization support are: 1) Linux provides KVM and Xen, with outstanding performance and flexibility, suitable for high customization environments; 2) Windows supports virtualization through Hyper-V, with a friendly interface, and is closely integrated with the Microsoft ecosystem, suitable for enterprises that rely on Microsoft software.

Is it hard to learn Linux? Is it hard to learn Linux? Apr 18, 2025 am 12:23 AM

Learning Linux is not difficult. 1.Linux is an open source operating system based on Unix and is widely used in servers, embedded systems and personal computers. 2. Understanding file system and permission management is the key. The file system is hierarchical, and permissions include reading, writing and execution. 3. Package management systems such as apt and dnf make software management convenient. 4. Process management is implemented through ps and top commands. 5. Start learning from basic commands such as mkdir, cd, touch and nano, and then try advanced usage such as shell scripts and text processing. 6. Common errors such as permission problems can be solved through sudo and chmod. 7. Performance optimization suggestions include using htop to monitor resources, cleaning unnecessary files, and using sy

The Future of Linux Software: Will Flatpak and Snap Replace Native Desktop Apps? The Future of Linux Software: Will Flatpak and Snap Replace Native Desktop Apps? Apr 25, 2025 am 09:10 AM

For years, Linux software distribution relied on native formats like DEB and RPM, deeply ingrained in each distribution's ecosystem. However, Flatpak and Snap have emerged, promising a universal approach to application packaging. This article exami

Top 7 Tools to Compare Files in Linux (with Examples) Top 7 Tools to Compare Files in Linux (with Examples) Apr 28, 2025 am 09:21 AM

This guide explores various methods for comparing text files in Linux, a crucial task for system administrators and developers. We'll cover command-line tools and visual diff tools, highlighting their strengths and appropriate use cases. Let's assum

What are the differences in user account management between Linux and Windows? What are the differences in user account management between Linux and Windows? May 02, 2025 am 12:02 AM

The main difference between Linux and Windows in user account management is the permission model and management tools. Linux uses Unix-based permissions models and command-line tools (such as useradd, usermod, userdel), while Windows uses its own security model and graphical user interface (GUI) management tools.

See all articles