In our previous article, we showed you how to install TrueNAS server. This article will guide you through configuring TrueNAS to set up ZFS storage disks and create NFS shares, enabling you to store and share data efficiently across your network.
Hardware Requirements
Before diving into the configuration of TrueNAS, ensure that you have a minimum of two disks properly connected and recognized by the system to create a ZFS pool.
However, three or more disks are recommended for better performance and redundancy (RAID-Z1, RAID-Z2, or RAID-Z3).
Configuring ZFS Storage Disks
To add a ZFS storage disk, navigate to Storage > Disks and click on the Add Disk button to select and configure the disks you want to use for storage.
data:image/s3,"s3://crabby-images/e078c/e078c3a1fd212a054f9c76981cb1dc0b4a74f5ae" alt="Connected Disks"
To create a ZFS Pool, navigate to Storage > Pools and click on the Add button to create a new pool.
data:image/s3,"s3://crabby-images/b4ed6/b4ed68a67fc487eae25bba3a6685bc0ad5b683f6" alt="Create New ZFS Pool"
Next, enter a name for your pool and select the disks you want to include in the pool from the available list.
data:image/s3,"s3://crabby-images/bbc23/bbc23a4148135238634be7d09f1b3cfa72ed4621" alt="Create ZFS Storage Pool"
Your ZFS pool is now set up and ready for use.
data:image/s3,"s3://crabby-images/45c9e/45c9e126066aee97a15b6df6876e726ced958aeb" alt="ZFS Pool Storage"
After creating the storage pool, click on the pool you just created and click on the ...
(three dots) next to it and choose Add Dataset to create a new dataset.
data:image/s3,"s3://crabby-images/818ba/818baf0e8eb9630e422becd86b9e192d1d2e9c84" alt="Create a New Dataset"
Next, enter a name for the dataset and configure the permissions for the dataset by navigating to the Permissions tab. Set the owner and group permissions, as well as read, write, and execute permissions as needed.
data:image/s3,"s3://crabby-images/81593/815930584b9b7c6691d0faff29a3d12d7f790fbc" alt="Add Dataset Name"
data:image/s3,"s3://crabby-images/6331f/6331f4bc20c16659a1a4a9d699515c8ebfb62670" alt="Dataset Permissions"
Creating NFS Shares for ZFS Datasets
To share ZFS datasets on Unix machines, go to the “Sharing” tab from the top menu, and choose the Unix Shares (NFS) type.
data:image/s3,"s3://crabby-images/9076f/9076f77284626c6d98df52540840a102e23fb07c" alt="Choose Unix Shares NFS"
Next, click on the Add NFS Share button choose the location of the dataset you created earlier, and configure the share settings, including options for read/write access and allowed hosts.
data:image/s3,"s3://crabby-images/faf83/faf8315bdbf41f533817752a9d040c327cf102cc" alt="Choose ZFS Dataset for NFS Share"
After clicking on Submit, a confirmation message will prompt, asking if you would like to enable this service. Click Yes to enable the sharing. You will then see that the NFS service has been started.
data:image/s3,"s3://crabby-images/fdcf6/fdcf643611de77b0f5600854946a3721156a6f7d" alt="Enable NFS Service"
To confirm the NFS service status, navigate to Services and look for the NFS service. Make sure the toggle is in the ON position to confirm that the service is running.
data:image/s3,"s3://crabby-images/2364c/2364cac490a13fd2fadc79e63f94824a5bbcaee1" alt="Confirm NFS Status"
Mounting NFS Share on Unix Client
Now login to your Unix client machine (Here I’ve used Ubuntu 22.04 with IP Address 192.168.122.12), and check whether NFS share from TrueNAS works or not.
But, before checking TrueNAS NFS shares, your client machine must have the NFS package installed on the system.
sudo dnf install nfs-utils -y [On RedHat systems] sudo apt install nfs-common -y [On Debian systems]
After installing NFS, use the following command to list the NFS share from TrueNAS.
showmount -e 192.168.122.103
data:image/s3,"s3://crabby-images/6389c/6389c45c0f37b6f6a0b9e84e533dc8ea4464887f" alt="Check TrueNAS NFS Share"
Now, create a mount directory under ‘/mnt/TrueNAS_Share‘ in the client machine, mount the TrueNAS NFS Share in this mount point, and confirm it using the df command.
sudo mkdir /mnt/TrueNAS_Share sudo mount 192.168.122.103:/mnt/tecmint_pool/tecmint_docs /mnt/TrueNAS_Share/ df -hT
data:image/s3,"s3://crabby-images/f4ffe/f4ffe70215d94da29443e5d574be10585483e25e" alt="Mount TrueNAS NFS Share"
Once the NFS share is mounted, go inside that directory and try to create a file under this share to confirm that the root user has permission to this share.
sudo su cd /mnt/TrueNAS_Share/ touch tecmint.txt
data:image/s3,"s3://crabby-images/ca493/ca493cf947e961da61ceade50c6810114efb607c" alt="Create Files in TrueNAS NFS Share"
That’s it! we have configured the storage volume and defined an NFS share from TrueNAS.
Conclusion
TrueNAS provides a user-friendly interface to manage the storage server. TrueNAS supports a large file system using ZFS with features such as compression, quotas, and permissions.
In future articles, we’ll explore how to use TrueNAS as a streaming server and torrent server.