search
  • Sign In
  • Sign Up
Password reset successful

Follow the proiects vou are interested in andi aet the latestnews about them taster

Table of Contents
Install Fail2Ban on Debian/Ubuntu
Configure Fail2Ban Safely (Don't Lock Yourself Out)
Enable and Test the Configuration
Optional: Add Custom Filter for Nginx or Apache
Home Operation and Maintenance Linux Operation and Maintenance How to Install Fail2Ban to Protect Your Linux Server? (Configuration Example)

How to Install Fail2Ban to Protect Your Linux Server? (Configuration Example)

Dec 28, 2025 am 02:34 AM

Three-step method to install and configure Fail2Ban: first use apt to install and enable the service; then securely configure SSH protection through jail.local (enable, set maxretry=3, bantime=1h, findtime=10m, ignoreip including local IP); finally restart the test to avoid locking up due to direct changes to jail.conf or missing ignoreip.

How to Install Fail2Ban to Protect Your Linux Server? (Configuration Example)

Fail2Ban is a powerful intrusion prevention tool that monitors log files for suspicious activity and automatically blocks malicious IP addresses using firewall rules. Installing and configuring it on your Linux server is straightforward — here's how to do it with a practical, working example.

Install Fail2Ban on Debian/Ubuntu

On Debian-based systems, run:

 sudo apt update && sudo apt install fail2ban -y

That's it — the package includes default configs and starts the service automatically. You can verify it's running with:

 sudo systemctl status fail2ban

Configure Fail2Ban Safely (Don't Lock Yourself Out)

Never edit /etc/fail2ban/jail.conf directly — always use jail.local instead. Create or edit it:

 sudo nano /etc/fail2ban/jail.local

Add this minimal but effective setup for SSH protection:

 [sshd]
enabled = true
port=ssh
logpath = %(sshd_log)s
maxretry = 3
bantime=1h
findtime=10m
ignoreip = 127.0.0.1/8 ::1 YOUR_TRUSTED_IP

Replace YOUR_TRUSTED_IP with your own IP (or subnet) to avoid accidental lockout. The settings mean: ban after 3 failed attempts within 10 minutes, for 1 hour.

Enable and Test the Configuration

Restart Fail2Ban to apply changes:

 sudo systemctl restart fail2ban

Check active jails and bans:

  • sudo fail2ban-client status — shows enabled jails
  • sudo fail2ban-client status sshd — lists banned IPs for SSH
  • sudo tail -f /var/log/fail2ban.log — watch real-time events

To test safely, try logging in with wrong credentials from another machine (not your main admin IP). After 3 failures, the IP should appear in the ban list.

Optional: Add Custom Filter for Nginx or Apache

If you run a web server, create a custom filter to block repeated 404s or login brute-forcing. For example, save this as /etc/fail2ban/filter.d/nginx-badbots.conf :

 [Definition]
failregex = ^<HOST>.*"(GET|POST).*HTTP\/[0-9] \.[0-9] " 404
ignoreregex=

Then enable it in jail.local :

 [nginx-badbots]
enabled = true
filter = nginx-badbots
logpath = /var/log/nginx/access.log
maxretry=5
bantime = 1d

This bans IPs hitting 5 non-existent pages in one go — useful against scanners and bots.

Basically just three steps: install, configure jail.local with safe values, then test. It's not complex — but skipping the ignoreip step or editing jail.conf directly is where most people get locked out.

The above is the detailed content of How to Install Fail2Ban to Protect Your Linux Server? (Configuration Example). 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

Undress AI Tool

Undress AI Tool

Undress images for free

AI Clothes Remover

AI Clothes Remover

Online AI tool for removing clothes from photos.

Undresser.AI Undress

Undresser.AI Undress

AI-powered app for creating realistic nude photos

ArtGPT

ArtGPT

AI image generator for creative art from text prompts.

Stock Market GPT

Stock Market GPT

AI powered investment research for smarter decisions

Popular tool

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)

How to manage software packages using Dnf and Rpm in Linux? How to manage software packages using Dnf and Rpm in Linux? Mar 07, 2026 am 01:50 AM

dnfinstall prompts packagenotfound because it queries the enabled warehouse rather than the local installation status; rpm-q queries the local RPM database, and the scopes of the two are different.

How to monitor system performance and resources in Linux? (Top & Htop) How to monitor system performance and resources in Linux? (Top & Htop) Mar 06, 2026 am 01:04 AM

The total top CPU usage is not 100% because it is calculated based on a single core, and the maximum is 800% for an 8-core system; the htop terminal size error needs to be fixed with eval$(resize); the real memory pressure is available rather than used; top command line truncation can be solved with the -c parameter.

How to setup file sharing using Samba on Linux? (SMB Protocol) How to setup file sharing using Samba on Linux? (SMB Protocol) Mar 13, 2026 am 12:33 AM

The main reason why Windows cannot see the Samba share is that the firewall blocks UDP137–139/TCP445 or NetBIOS name resolution fails; it is necessary to confirm that the workgroup is consistent, the interfaces are configured correctly, the file permissions match forceuser/forcegroup, and set doscharset=UTF-8 to solve Chinese garbled characters.

How to extend a Logical Volume (LVM) in Linux without downtime? How to extend a Logical Volume (LVM) in Linux without downtime? Mar 13, 2026 am 12:53 AM

Logical volumes and file systems can be expanded online. You need to expand the LV first and then the file system. It is recommended to use lvextend-r for automatic synchronization adjustment, but you must ensure that the LVM and file system tool versions are compatible.

How to check open ports and listening services in Linux? (Netstat & SS) How to check open ports and listening services in Linux? (Netstat & SS) Mar 10, 2026 am 01:08 AM

Netstat displays fewer LISTEN ports than ss because it does not display process information by default that non-root users do not have access to; ss can read all listening sockets by default without process names, and sudonetstat-tulpn is required to display them completely.

How to set up SSH key authentication on Linux? (Passwordless Login) How to set up SSH key authentication on Linux? (Passwordless Login) Mar 11, 2026 am 12:46 AM

It is recommended to use ssh-keygen-ted25519 to generate a key pair, because it is faster, more secure, and has a shorter key than the default RSA; it is necessary to strictly set the ~/.ssh directory permissions to 700 and authorized_keys to 600, and use ssh-v to confirm whether the client is Offering public key and whether the server rejects it.

How to format disk partitions using the command line in Linux? How to format disk partitions using the command line in Linux? Mar 15, 2026 am 12:01 AM

When fdisk is stuck at the Command prompt, it is normally waiting for input. Enter q to exit safely; you must umount before mkfs, otherwise it may fail silently; partedmkpart does not support the specified file system type, and mkfs needs to be executed separately.

How to configure a static IP address on Linux? (Netplan & NetworkManager) How to configure a static IP address on Linux? (Netplan & NetworkManager) Mar 14, 2026 am 12:02 AM

Netplan reports "InvalidYAML" when configuring a static IP due to indentation errors, missing spaces after colons, or mixed tabs; gateway4 has been deprecated and routes to:default must be used instead; NetworkManager needs to be modified before down/up takes effect; the renderer field is used to determine the backend during coexistence; incorrect DNS configuration will cause ping to succeed but curl to fail.

Related articles