- 1 Guide to SSH Configuration and Security Hardening on Ubuntu
- 1.1 1. What is SSH? How to Use It on Ubuntu
- 1.2 2. How to Install SSH on Ubuntu
- 1.3 3. Checking SSH Service Status and Enabling It at System Startup
- 1.4 4. How to Allow SSH Through the Firewall
- 1.5 5. How to Connect to an Ubuntu SSH Server
- 1.6 6. Advanced SSH Settings (Changing Ports, Disabling Root Login)
- 1.7 7. Best Practices for Securing Your SSH Server
- 1.8 8. Common SSH Connection Troubleshooting
- 1.9 Conclusion
Guide to SSH Configuration and Security Hardening on Ubuntu
1. What is SSH? How to Use It on Ubuntu
SSH (Secure Shell) is a protocol used to securely connect to and operate a remote server. In Linux-based systems like Ubuntu, SSH is an essential command-line management tool. By using SSH, communication with the server is encrypted, preventing unauthorized access and eavesdropping by third parties.
Related Link: What is SSH? Official Ubuntu Documentation
2. How to Install SSH on Ubuntu
To use SSH, follow these steps to install the SSH server on Ubuntu.
- Update the package list:
sudo apt update
- Install OpenSSH Server:
sudo apt install openssh-server
- Start the service and check its status:
sudo systemctl status ssh
Note: You can find more details about OpenSSH on the Ubuntu official page.
data:image/s3,"s3://crabby-images/89866/89866048e6b4e4173aee35241fe30d39232bf2d5" alt=""
3. Checking SSH Service Status and Enabling It at System Startup
Verify that SSH is running properly and configure it to start automatically when the system boots.
- Check the service status:
sudo systemctl status ssh
- Enable SSH to start automatically at boot:
sudo systemctl enable ssh
4. How to Allow SSH Through the Firewall
Use Ubuntu’s default firewall, UFW (Uncomplicated Firewall), to allow SSH access.
- Allow SSH connections through the firewall:
sudo ufw allow ssh
- Check the status of UFW:
sudo ufw status
data:image/s3,"s3://crabby-images/89866/89866048e6b4e4173aee35241fe30d39232bf2d5" alt=""
5. How to Connect to an Ubuntu SSH Server
Follow these steps to connect to your Ubuntu server via SSH remotely.
- Check the IP address:
ip a
- Connect using SSH:
ssh username@ip_address
If a security warning appears on the first connection, type yes
and then enter your password to proceed.
Tip: Windows users can use PuTTY as an SSH client.
6. Advanced SSH Settings (Changing Ports, Disabling Root Login)
Enhance SSH security by modifying default settings.
- Change the default SSH port:
Changing the default port (22) reduces the risk of brute-force attacks.
sudo nano /etc/ssh/sshd_config
#Port 22 → Change to a preferred number
- Disable root login:
For security reasons, it is recommended to disable root login.
PermitRootLogin no
After making changes, restart the SSH service.
sudo systemctl restart ssh
data:image/s3,"s3://crabby-images/89866/89866048e6b4e4173aee35241fe30d39232bf2d5" alt=""
7. Best Practices for Securing Your SSH Server
Follow these best practices to enhance SSH security.
- Use SSH key authentication:
Instead of password authentication, use public key authentication for enhanced security.
Refer to the SSH Key Generation Guide to set up key pairs. - Restrict SSH access to specific users:
Limit SSH access to specific users using theAllowUsers
directive. - Use Fail2Ban to prevent brute-force attacks:
Fail2Ban automatically blocks repeated failed login attempts.
sudo apt install fail2ban
For configuration details, refer to the Fail2Ban documentation.
8. Common SSH Connection Troubleshooting
If you experience SSH connection issues, use the following checklist to troubleshoot.
- Firewall settings misconfiguration: Check if UFW or other firewalls are configured correctly.
- Verify IP address: Ensure you are using the correct IP address.
- Check SSH configuration file for errors: Review
/etc/ssh/sshd_config
for mistakes and restart SSH if needed.
Conclusion
This guide covered how to install and configure SSH on Ubuntu securely. Implement best practices to maintain a secure and efficient server environment. For more detailed information, refer to the Official Ubuntu SSH Configuration Guide.