\n
sudo apt update<\/p>\n<\/div><\/div>\n\n\n\n <\/figure>\n\n\n\n\n
sudo apt upgrade<\/p>\n<\/div><\/div>\n\n\n\n <\/figure>\n\n\n\nType ‘y<\/strong>‘ and press enter to proceed with any pending updates.<\/p>\n\n\n\nNext, we want to take advantage of Uncomplicated Firewall (ufw) that comes with Ubuntu. If you have just installed your Ubuntu operating system there is a high possibility that it is not enabled by default. We want to check the current status by running the following command:<\/p>\n\n\n\n
\n
sudo ufw status<\/p>\n<\/div><\/div>\n\n\n\n <\/figure>\n\n\n\nWe can enable it with one simple command:<\/p>\n\n\n\n
\n
sudo ufw enable<\/p>\n<\/div><\/div>\n\n\n\n
Now we will allow SSH connections and also check the status:<\/p>\n\n\n\n
\n
sudo ufw allow ssh sudo ufw status<\/p>\n<\/div><\/div>\n\n\n\n <\/figure>\n\n\n\nIf you want to take one step further, you can allow SSH connections only from specific IP addresses. To do that you can run the following commands:<\/p>\n\n\n\n
\n
sudo ufw allow from 192.168.1.100 proto tcp to any port 22<\/p>\n<\/div><\/div>\n\n\n\n
This command adds a rule to allow incoming connections from 192.168.1.100 to port which is the default port for SSH. Make sure to replace it with your IP address.<\/p>\n\n\n\n
\n
sudo ufw deny 22<\/p>\n<\/div><\/div>\n\n\n\n
This command will block all other incoming traffic to port 22.<\/p>\n\n\n\n
Simple UFW syntax allows quickly adding or removing other ports and exposing applications to the public with ports 80 and 443. It\u2019s a security best practice to setup a bastion server to reduce attack surface area and to protect your private network.<\/p>\n\n\n\n
Step 2: Enable and configure AppArmor <\/h2>\n\n\n\n AppArmor (Application Armor) is a Linux kernel security module that gives mandatory access to programs thus enhancing the security of the Ubuntu operating system. With Ubuntu 24.04, it comes as AppArmor 4 and brings improvements over an older version. It is mainly designed to restrict the capabilities of programs and limit their access to resources so this also helps with limiting the potential damage that could be caused by a compromised application. These security policies are defined using profiles and each profile will provide the appropriate level of permissions. These profiles can be either set in enforce mode or complain mode when AppArmor logs the violations without the enforcing process.<\/p>\n\n\n\n
First, we will ensure that AppArmor is installed and enabled:<\/p>\n\n\n\n
\n
sudo apt install apparmor apparmor-utils sudo systemctl enable apparmor sudo systemctl start apparmor<\/p>\n<\/div><\/div>\n\n\n\n
Now we will use the aa-genprof<\/strong> command for the nano editor where we will restrict nano usage in a certain directory.<\/p>\n\n\n\nFirst we will create a new directory in the jumpcloud home directory:<\/p>\n\n\n\n
\n
mkdir ~\/private<\/p>\n<\/div><\/div>\n\n\n\n
Next, we will run the aa-genprof command with appropriate arguments, and that starts the profiling in real time.<\/p>\n\n\n\n
\n
sudo aa-genprof nano<\/p>\n<\/div><\/div>\n\n\n\n <\/figure>\n\n\n\nWe will open up a new terminal and start editing a new file:<\/p>\n\n\n\n
\n
nano ~\/tmp_file<\/p>\n<\/div><\/div>\n\n\n\n
Now, we can get back to our initial terminal and press ‘S’ for scanning for events, here we will need to press A to Allow each line that fills the information in the AppArmor’s config for the nano editor.<\/p>\n\n\n\n <\/figure>\n\n\n\nAdd the end of the process we can press ‘S’ for saving changes.<\/p>\n\n\n\n <\/figure>\n\n\n\nThen let’s change this basic profile for the nano editor, by editing the following file:\u00a0<\/p>\n\n\n\n
\n
sudo vi \/etc\/apparmor.d\/usr.bin.nano<\/p>\n<\/div><\/div>\n\n\n\n
Near the end of the file we can add the deny <\/strong>directive for the specific directory:<\/p>\n\n\n\n\n
deny \/home\/jumpcloud\/private r,<\/p>\n<\/div><\/div>\n\n\n\n <\/figure>\n\n\n\nAfter this action, and editing the profile, we need to reload it to apply the changes:<\/p>\n\n\n\n
\n
sudo apparmor_parser -r \/etc\/apparmor.d\/usr.bin.nano<\/p>\n<\/div><\/div>\n\n\n\n
and then we will run AppArmor in the enforce mode:<\/p>\n\n\n\n
\n
sudo aa-enforce \/etc\/apparmor.d\/usr.bin.nano<\/p>\n<\/div><\/div>\n\n\n\n
This will most probably cause additional permissions errors if you are trying to use nano somewhere, so it’s a good idea to run ‘aa-logprof’ <\/strong>command, and in the same way confirm the Allow <\/strong>directives.<\/p>\n\n\n\n\n
sudo aa-logprof\u00a0<\/p>\n<\/div><\/div>\n\n\n\n
Make sure to reload the profile again apply the changes and then start enforcing the profile.<\/p>\n\n\n\n
\n
sudo apparmor_parser -r \/etc\/apparmor.d\/usr.bin.nano sudo aa-enforce \/etc\/apparmor.d\/usr.bin.nano<\/p>\n<\/div><\/div>\n\n\n\n
Now when you try to create a new file and start editing in our denied directory, the editor will report an error.<\/p>\n\n\n\n
\n
sudo nano \/home\/jumpcloud\/private\/tmp_file<\/p>\n<\/div><\/div>\n\n\n\n <\/figure>\n\n\n\nFeel free to adjust your AppArmor profiles as it is very flexible and it can increase the security of your Ubuntu system.<\/p>\n\n\n\n
Step 3: Set Unprivileged User Namespace Restrictions<\/h2>\n\n\n\n Ubuntu 24.04 offers enhanced security features, including improved security restrictions on unprivileged users’ namespaces to provide additional security isolation for applications. <\/p>\n\n\n\n
The main purpose of this feature is to minimize the attack surface within the Linux kernel by limiting the permissions within these unprivileged user namespaces. The new version of Ubuntu brings additional improvements compared to the older 23.04 version, bringing better default semantics and improved coverage. <\/p>\n\n\n\n
The end result is that applications can better handle default restrictions while maintaining functionality, because trusted components can gain additional permissions within the sandbox.<\/p>\n\n\n\n
First, let’s check if user namespaces are currently enabled:<\/p>\n\n\n\n
\n
sudo sysctl kernel.unprivileged_userns_clone<\/p>\n<\/div><\/div>\n\n\n\n <\/figure>\n\n\n\nBased on the output we can see that unprivileged user namespaces are enabled currently, so we can disable them with the following command:<\/p>\n\n\n\n
\n
sudo sysctl -w kernel.unprivileged_userns_clone=0<\/p>\n<\/div><\/div>\n\n\n\n
To make this change permanent we can edit the file \/etc\/sysctl.conf<\/p>\n\n\n\n
\n
sudo vi \/etc\/sysctl.conf<\/p>\n<\/div><\/div>\n\n\n\n
and add the following line:<\/p>\n\n\n\n
\n
kernel.unprivileged_userns_clone=0<\/p>\n<\/div><\/div>\n\n\n\n <\/figure>\n\n\n\nUbuntu 24.04 also allows setting default restrictions for additional permissions within unprivileged user namespaces so we can fine-tune our profiles.<\/p>\n\n\n\n
To configure these default settings, use the following command:<\/p>\n\n\n\n
\n
sudo sysctl -w kernel.unprivileged_userns_apparmor_policy=1<\/p>\n<\/div><\/div>\n\n\n\n
In case we want to make it permanent, we can add the following line to the \/etc\/sysctl.conf:<\/p>\n\n\n\n
\n
kernel.unprivileged_userns_apparmor_policy=1<\/p>\n<\/div><\/div>\n\n\n\n
This setting makes sure that in cases where unprivileged user namespaces are enabled, applications cannot gain additional permissions within these namespaces.<\/p>\n\n\n\n
Step 4: Test Binary Hardening<\/h2>\n\n\n\n With the newest Ubuntu 24.04 version we have access to FORTIFY_SOURCE=3 macro that mainly protects the system from dangerous buffer overflows. This macro adds runtime checks to detect and prevent certain types of buffer overflows and other string-handling operations that can cause issues on your system. The latest version, level 3 set by default, provides even greater protection compared to previous versions. <\/p>\n\n\n\n
We can create a simple C program that uses string handling to test the safety of a function that attempts to copy a string longer than the buffer can hold, causing a buffer overflow.<\/p>\n\n\n\n
\n
vi unsafe_program.c<\/p>\n<\/div><\/div>\n\n\n\n
\n
#include <stdio.h> #include <string.h> void unsafe_function(char *input) { \u00a0 \u00a0 char buffer[10]; \u00a0 \u00a0 strcpy(buffer, input); \u00a0 \u00a0 printf(“Buffer content: %s\\n”, buffer); } int main(int argc, char *argv[]) { \u00a0 \u00a0 if (argc != 2) { \u00a0 \u00a0 \u00a0 \u00a0 fprintf(stderr, “Usage: %s <input>\\n”, argv[0]); \u00a0 \u00a0 \u00a0 \u00a0 return 1; \u00a0 \u00a0 } \u00a0 \u00a0 unsafe_function(argv[1]); \u00a0 \u00a0 return 0; }<\/p>\n<\/div><\/div>\n\n\n\n
Next, we want to make sure we have gcc<\/strong> packages on our system:<\/p>\n\n\n\n\n
sudo apt install gcc<\/p>\n<\/div><\/div>\n\n\n\n
After the installation process, let’s compile the program with FORTIFY_SOURCE level 3:<\/p>\n\n\n\n
\n
gcc -D_FORTIFY_SOURCE=3 -o unsafe_program_fortify3 unsafe_program.c<\/p>\n<\/div><\/div>\n\n\n\n
Run the program with a short string:<\/p>\n\n\n\n
\n
.\/unsafe_program_fortify3 “short”<\/p>\n<\/div><\/div>\n\n\n\n <\/figure>\n\n\n\nNow try to extend the string size by typing more characters in the input:<\/p>\n\n\n\n
\n
.\/unsafe_program_fortify3 “verylongstringsize”<\/p>\n<\/div><\/div>\n\n\n\n <\/figure>\n\n\n\nAs we can see the FORTIFY_SOURCE=3 protection forbids the buffer overflow in our program and thus protects the system and its memory. Stack smashing occurs when a program writes more data to a buffer located on the stack than the buffer can hold. This kind of protection can save the system from crashing, arbitrary code execution, denial of service attacks, or data corruption. <\/p>\n\n\n\n
Step 5: Encrypt the Home directory and Swap<\/h2>\n\n\n\n In case that you installed your Ubuntu operating system without any encryption, then full disk encryption is not an option. We still can use Ubuntu’s command line tools for encrypting home directories and the swap space, which can contain some personal information and can be exploited in the process, so it is recommended that you encrypt the swap space as well. <\/p>\n\n\n\n
Make sure to backup your data and also store your passphrases in a secure location, and evade any data loss in the process.<\/p>\n\n\n\n
We will first make sure to install the necessary tools:<\/p>\n\n\n\n
\n
sudo apt install ecryptfs-utils cryptsetup<\/p>\n<\/div><\/div>\n\n\n\n
After the installation, we will add a separate user just for encryption. It is also important that this user has sudo permissions.<\/p>\n\n\n\n
\n
sudo adduser ubuntu_encryption<\/p>\n<\/div><\/div>\n\n\n\n
Make sure to get through the whole process including setting up the password for the new user.<\/p>\n\n\n\n <\/figure>\n\n\n\nNow, we will add this user to the sudo group:<\/p>\n\n\n\n
\n
sudo usermod -aG sudo ubuntu_encryption<\/p>\n<\/div><\/div>\n\n\n\n
Next, we will change our user and log in as ubuntu_encryption<\/strong><\/p>\n\n\n\n\n
su ubuntu_encryption<\/p>\n<\/div><\/div>\n\n\n\n
Once we are logged as our encryption user, we will encrypt the home directory for the user ‘jumpcloud<\/strong>‘. We can do so, by running the following command:<\/p>\n\n\n\n\n
sudo ecryptfs-migrate-home -u jumpcloud<\/p>\n<\/div><\/div>\n\n\n\n <\/figure>\n\n\n\nHere we want to enter the password for the user ‘jumpcloud<\/strong>‘ and that will start the encryption process. Once done, as an output, the instructions will be shown on the screen:<\/p>\n\n\n\n <\/figure>\n\n\n\nChange the user to ‘jumpcloud’ and also record their randomly generated mount passphrase.<\/p>\n\n\n\n
\n
su jumpcloud<\/p>\n<\/div><\/div>\n\n\n\n
Make sure you can read and write in your home directory. We will also create a new test file:<\/p>\n\n\n\n
\n
echo “this is a test” > test_file<\/p>\n<\/div><\/div>\n\n\n\n <\/figure>\n\n\n\nNext, we will use the command to print out the passphrase on our command line.<\/p>\n\n\n\n
\n
ecryptfs-unwrap-passphrase<\/p>\n<\/div><\/div>\n\n\n\n
When prompted for a passphrase, enter your user’s account password, and this will show the randomly generated password which you need to store in a secure location.<\/p>\n\n\n\n <\/figure>\n\n\n\nIn this process, as we have mentioned at the beginning of this step, it is important to encrypt swap space as well.<\/p>\n\n\n\n
First, we will check whether we have a swap added to our system.<\/p>\n\n\n\n
\n
swapon -s<\/p>\n<\/div><\/div>\n\n\n\n <\/figure>\n\n\n\nNext, we will use the command to encrypt the swap:<\/p>\n\n\n\n
\n
sudo ecryptfs-setup-swap<\/p>\n<\/div><\/div>\n\n\n\n <\/figure>\n\n\n\nConfirm with ‘y’ and press Enter, which completes the process.<\/p>\n\n\n\n
Finally, we can remove our encryption user and also the backup home folder that was created when the migration command.<\/p>\n\n\n\n
\n
sudo deluser –remove-home ubuntu_encryption<\/p>\n<\/div><\/div>\n\n\n\n <\/figure>\n\n\n\n\n
sudo rm -rf \/home\/jumpcloud.pE1kM5Jr<\/p>\n<\/div><\/div>\n\n\n\n
By using these techniques, you can greatly improve the security of your Ubuntu 24.04 operating system.<\/p>\n","protected":false},"excerpt":{"rendered":"
Learn how to enhance Ubuntu security in this step-by-step tutorial.<\/p>\n","protected":false},"author":150,"featured_media":112176,"comment_status":"closed","ping_status":"closed","sticky":false,"template":"","format":"standard","meta":{"_acf_changed":false,"_oasis_is_in_workflow":0,"_oasis_original":0,"_oasis_task_priority":"","inline_featured_image":false,"footnotes":""},"categories":[2781],"tags":[],"collection":[2778],"platform":[],"funnel_stage":[3017],"coauthors":[2535],"acf":[],"yoast_head":"\n
How to Enhance Ubuntu Security - JumpCloud<\/title>\n \n \n \n \n \n \n \n \n \n \n \n \n\t \n\t \n\t \n \n \n \n\t \n\t \n\t \n