Home  >  Article  >  Operation and Maintenance  >  How to Protect CentOS Servers Using Network Intrusion Detection Systems (NIDS)

How to Protect CentOS Servers Using Network Intrusion Detection Systems (NIDS)

WBOY
WBOYOriginal
2023-07-05 14:13:061632browse

How to use Network Intrusion Detection System (NIDS) to protect CentOS servers

Introduction:
In modern network environments, server security is crucial. Attackers use a variety of means to try to break into our servers and steal sensitive data or compromise systems. To ensure server security, we can use a Network Intrusion Detection System (NIDS) for real-time monitoring and detection of potential attacks.

This article will introduce how to configure and use NIDS on CentOS server to protect the server.

Step 1: Install and configure SNORT
SNORT is an open source intrusion detection system that we can use to monitor network traffic and detect possible attacks. First, we need to install SNORT.

  1. Open a terminal and log in to the server with root privileges.
  2. Use the following command to install SNORT:
yum install epel-release
yum install snort
  1. After the installation is complete, we need to configure SNORT. First, we need to create a new configuration file. Use the following command to create and open a new configuration file:
cp /etc/snort/snort.conf /etc/snort/snort.conf.backup
vim /etc/snort/snort.conf
  1. In the configuration file, you can customize SNORT as needed. Also, make sure to uncomment the following lines to enable the corresponding features:
include $RULE_PATH/local.rules
include $RULE_PATH/snort.rules
include $RULE_PATH/community.rules
  1. Save and close the configuration file.

Step 2: Configure NIDS rules
In SNORT, rules are used to define the types of attacks we wish to detect. We can use an existing rule set or create custom rules.

  1. Open a terminal and use the following command to enter the SNORT rules directory:
cd /etc/snort/rules/
  1. Use the following command to download the latest rule set:
wget https://www.snort.org/downloads/community/community-rules.tar.gz
tar -xvf community-rules.tar.gz
  1. After the download and extraction is completed, we can find the rule file in the rules directory. These rules files have the extension .rules.
  2. If we want to add custom rules, we can create a new rules file and add rules in it. For example, we can create a rules file named custom.rules using the following command:
vim custom.rules
  1. In the rules file, we can add custom rules. Here is an example:
alert tcp any any -> any any (msg:"Possible SSH brute force attack"; 
                         flow:from_client,established; content:"SSH-"; 
                         threshold:type limit, track by_src, count 5, 
                         seconds 60; sid:10001; rev:1;)
  1. Save and close the rules file.

Step 3: Start SNORT and monitor traffic
After configuring SNORT and rules, we can start SNORT and start monitoring traffic.

  1. Open a terminal and use the following command to start SNORT:
snort -A console -c /etc/snort/snort.conf -i eth0

Among them, -A console specifies to output the alert message to the console, -c /etc/snort/snort .conf specifies to use the SNORT configuration file we configured previously, and -i eth0 specifies the network interface to be monitored.

  1. SNORT will start monitoring traffic and detect potential attacks. If there is any suspicious activity, it will generate an alert message and output it to the console.

Step 4: Set up SNORT alarm notification
In order to get the alarm message in time, we can use the email notification function to send the alarm message to our email address.

  1. Open a terminal and use the following command to install the email notification plug-in:
yum install barnyard2
yum install sendmail
  1. After the installation is complete, we need to create a new configuration file. Copy the example configuration file and open a new configuration file using the following command:
cp /etc/barnyard2/barnyard2.conf /etc/barnyard2/barnyard2.conf.backup
vim /etc/barnyard2/barnyard2.conf
  1. In the configuration file, find the following lines and uncomment them:
output alert_syslog_full
output database: log, mysql, user=snort password=snort dbname=snort host=localhost
output alert_fast: snort.alert

config reference_file: reference.config
config classification_file:classification.config
config gen_file: gen-msg.map
config sid_file: sid-msg.map
  1. Modify the following lines as appropriate based on our SMTP server and email settings:
output alert_full: alert.full
output log_unified2: filename unified2.log, limit 128
output smtp: email@example.com
  1. Save and close the configuration file.
  2. Start barnyard2 using the following command:
barnyard2 -c /etc/barnyard2/barnyard2.conf -d /var/log/snort/
  1. Later, if SNORT detects suspicious activity, it will generate an alert message and send it to our specified email address.

Conclusion:
It is very important to protect our CentOS servers by deploying a Network Intrusion Detection System (NIDS). We can use SNORT to monitor network traffic and detect potential attacks. By following the steps in this article, we can configure SNORT and set up rules to monitor and protect our servers. In addition, we can also use the email notification function to obtain alert messages in time.

The above is the detailed content of How to Protect CentOS Servers Using Network Intrusion Detection Systems (NIDS). For more information, please follow other related articles on the PHP Chinese website!

Statement:
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