go2ban
go2ban is a service for protecting VDS and VPS from password brute force, scanners and DDoS attacks. It uses firewall rules to block malicious IPs and also checks the log files of services such as databases, webservers and even those in docker containers. Additionally it features whitelisting, fake trap ports, REST and gRPC servers to manually block IPs. All these features combined provide a comprehensive solution for safeguarding your systems from malicious attacks.
Configuration
The config file allows for various settings to be customized, including:
- firewall: can be set to "auto" for automatic firewall rule management or "off" to disable firewall functionality.
- log_dir: directory for go2ban log files.
- white_list: IP addresses or subnets that will never be blocked.
- grpc_port: port for gRPC communication (default is off).
- rest_port: port for manual IP blocking through REST requests (default is off).
- blocked_ips: maximum number of IPs that can be blocked at one time.
- abuseipdb_apikey: specify the API key for AbuseIPDB, a free service that allows you to check if an IP address has been reported for malicious activity such as spamming, hacking, or other forms of abuse. By default, this option is disabled.
- abuseipdb_ips: number of blacklisted IP addresses that AbuseIPDB will request to block.
- trap_ports: local ports to be opened and appear to the scanner as open, but will not respond to connections (default is off).
- trap_fails: number of failed connection attempts before an IP is blocked.
- local_service_check_minutes: frequency of checking local services for brute force attempts.
- local_service_fails: number of failed attempts before an IP is blocked.
- Additionally, the config file allows for the customization of local service checks, with options to specify the service name, regular expression for detecting failed attempts, and log file location. You can tell docker to check all files syslog in containers.
Installation
-
Prerequisites: Make sure that you have a working Go development environment and that you have Go version >=1.15 installed on your machine.
-
Clone the repository:
git clone https://github.com/vv198x/go2ban.git
- Build the binary:
make
- Run the installer:
sudo make install
- Configure go2ban by editing the configuration file:
vi /etc/go2ban/go2ban.conf
- Start the service:
systemctl start go2ban
- Enable the service:
systemctl enable go2ban
Command-line:
-cfgFile
Path to config file
-clear
Unlock all
-d
Run as daemon
Usage
go2ban runs as a background service, continually monitoring for malicious IPs and applying firewall rules as necessary. The service can be controlled through gRPC commands or by sending REST requests to the specified port.
Blocking in the iptables(netfilter) raw table has several advantages, including:
-
Speed: The raw table is the earliest table in the iptables firewall rule evaluation, allowing for quick and efficient blocking of incoming packets.
-
Security: The raw table provides a strong first line of defense against incoming network traffic, helping to prevent malicious activity from reaching other parts of the system.
-
Connection don't established: Blocking traffic in the raw table ensures that the connection never even opens, which can be useful for mitigating DDoS attacks and reducing CPU load.
Development
The go2ban service is developed in Go and makes use of iptables for firewall management. The codebase is open-source and contributions are welcome.
Changelog
For a detailed list of changes made in each version, please refer to the change.log file in the repository.
Support
If you encounter any issues or have any questions, please open an issue in the repository or contact the developer.