Rumah Tutorial sistem LINUX Modul mengelak melindungi tapak web anda daripada serangan DOS lapisan aplikasi

Modul mengelak melindungi tapak web anda daripada serangan DOS lapisan aplikasi

Apr 30, 2024 pm 05:34 PM
linux apache tutorial linux Topi Merah sistem linux arahan linux pensijilan linux linux topi merah video linux

Terdapat banyak kaedah serangan yang boleh menyebabkan laman web menjadi luar talian Kaedah yang lebih kompleks memerlukan pengetahuan teknikal dalam pangkalan data dan pengaturcaraan. Kaedah yang lebih mudah dikenali sebagai serangan "Denial Of Service" (DOS). Nama kaedah serangan ini berasal dari niatnya: untuk menyebabkan permintaan perkhidmatan biasa daripada pelanggan biasa atau pelawat laman web ditolak.

evasive 模块保护您的网站免受应用层 DOS 攻击

Secara umumnya, terdapat dua bentuk serangan DOS:

    Lapisan ketiga dan keempat model OSI iaitu serangan lapisan rangkaian
  1. Tujuh lapisan model OSI iaitu serangan lapisan aplikasi
Jenis serangan DOS pertama - lapisan rangkaian, berlaku apabila sejumlah besar trafik sampah mengalir ke pelayan web. Apabila trafik spam melebihi keupayaan rangkaian untuk mengendalikannya, tapak web akan turun.

Jenis kedua serangan DOS adalah pada lapisan aplikasi dan mengeksploitasi permintaan perkhidmatan yang sah dan bukannya trafik sampah. Apabila bilangan permintaan halaman melebihi kapasiti pelayan web, pelawat yang sah pun tidak akan dapat menggunakan tapak web tersebut.

Artikel ini akan menumpukan pada mengurangkan serangan lapisan aplikasi, kerana mengurangkan serangan lapisan rangkaian memerlukan sejumlah besar lebar jalur yang tersedia dan kerjasama penyedia huluan, yang biasanya tidak dapat dilakukan dengan mengkonfigurasi pelayan rangkaian.

Dengan mengkonfigurasi pelayan web biasa, halaman web boleh dilindungi daripada serangan lapisan aplikasi, sekurang-kurangnya pada tahap sederhana. Mencegah bentuk serangan ini adalah penting kerana Cloudflare

[1] baru-baru ini melaporkan [2] bahawa bilangan serangan lapisan rangkaian semakin berkurangan manakala bilangan serangan lapisan aplikasi semakin meningkat.

Artikel ini akan memperkenalkan cara menggunakan modul Apache2 mod_evasive

[4] yang dibangunkan oleh zdziarski[3].

Selain itu, mod_evasive menyekat percubaan penyerang untuk meneka (iaitu serangan brute force) dengan mencuba ratusan kombinasi nama pengguna dan kata laluan.

mod_evasive mencatatkan bilangan permintaan daripada setiap alamat IP. Apabila nombor ini melebihi satu daripada beberapa ambang untuk alamat IP yang sepadan, halaman ralat muncul. Halaman ralat memerlukan sumber yang jauh lebih sedikit daripada tapak web dalam talian yang boleh membalas lawatan yang sah.

Pasang mod_evasive pada Ubuntu 16.04

Pustaka perisian lalai Ubuntu 16.04 termasuk mod_evasive, dinamakan "libapache2-mod-evasive". Anda boleh menggunakan apt-get untuk melengkapkan pemasangan:

apt-get update
apt-get upgrade
apt-get install libapache2-mod-evasive
Salin selepas log masuk

Sekarang kita perlu mengkonfigurasi mod_evasive.

Fail konfigurasinya terletak di /etc/apache2/mods-available/evasive.conf. Secara lalai, semua tetapan modul diulas selepas pemasangan. Oleh itu, modul tidak akan mengganggu trafik tapak web sehingga fail konfigurasi diubah suai.

<IfModule mod_evasive20.c>
   #DOSHashTableSize    3097
   #DOSPageCount        2
   #DOSSiteCount        50
   #DOSPageInterval     1
   #DOSSiteInterval     1
   #DOSBlockingPeriod   10

   #DOSEmailNotify      you@yourdomain.com
   #DOSSystemCommand    "su - someuser -c '/sbin/... %s ...'"
   #DOSLogDir           "/var/log/mod_evasive"
</IfModule>
Salin selepas log masuk

Maksud bahagian pertama parameter adalah seperti berikut:

  • DOSHashTableSize - Senarai semasa alamat IP yang mengakses tapak web dan bilangan permintaannya.
  • DOSPageCount - Bilangan permintaan untuk setiap halaman dalam selang masa tertentu. Selang masa ditentukan oleh DOSPageInterval.
  • DOSPageInterval - mod_evasive mengira selang masa untuk permintaan halaman.
  • DOSSiteCount - Sama seperti DOSPageCount, tetapi mengira bilangan permintaan ke mana-mana halaman dalam tapak daripada alamat IP yang sama.
  • DOSSiteInterval - mod_evasive mengira selang masa untuk permintaan tapak web.
  • DOSBlockingPeriod - Berapa lama dalam beberapa saat alamat IP telah disenaraihitamkan.

Jika anda menggunakan konfigurasi lalai yang ditunjukkan di atas, alamat IP akan disenaraihitamkan jika:

  • Meminta halaman yang sama lebih daripada dua kali sesaat.
  • Minta lebih daripada 50 halaman berbeza sesaat.

Jika alamat IP melebihi ambang ini, ia akan disenaraihitamkan selama 10 saat.

Ini mungkin tidak kelihatan seperti masa yang lama, tetapi mod_evasive akan sentiasa memantau permintaan halaman untuk alamat IP yang disenaraihitamkan dan menetapkan semula masa mula senarai hitamnya. Selagi alamat IP terus cuba menyerang DOS tapak web, ia akan sentiasa berada dalam senarai hitam.

Parameter selebihnya ialah:

  • DOSEmailNotify - Alamat e-mel untuk menerima maklumat serangan DOS dan penyenaraian hitam alamat IP.
  • DOSSystemCommand - Perintah untuk dijalankan apabila serangan DOS dikesan.
  • DOSLogDir - Direktori yang digunakan untuk menyimpan fail sementara untuk mod_evasive.
Konfigurasikan mod_evasive

默认的配置是一个很好的开始,因为它不会阻塞任何合法的用户。取消配置文件中的所有参数(DOSSystemCommand 除外)的注释,如下所示:

<IfModule mod_evasive20.c>
   DOSHashTableSize   3097
   DOSPageCount       2
   DOSSiteCount       50
   DOSPageInterval    1
   DOSSiteInterval    1
   DOSBlockingPeriod  10

   DOSEmailNotify       JohnW@example.com
   #DOSSystemCommand    "su - someuser -c '/sbin/... %s ...'"
   DOSLogDir            "/var/log/mod_evasive"
</IfModule>
Salin selepas log masuk

必须要创建日志目录并且要赋予其与 apache 进程相同的所有者。这里创建的目录是 /var/log/mod_evasive ,并且在 Ubuntu 上将该目录的所有者和组设置为 www-data ,与 Apache 服务器相同:

mkdir /var/log/mod_evasive
chown www-data:www-data /var/log/mod_evasive
Salin selepas log masuk

在编辑了 Apache 的配置之后,特别是在正在运行的网站上,在重新启动或重新加载之前,最好检查一下语法,因为语法错误将影响 Apache 的启动从而使网站宕机。

Apache 包含一个辅助命令,是一个配置语法检查器。只需运行以下命令来检查您的语法:

apachectl configtest
Salin selepas log masuk

如果您的配置是正确的,会得到如下结果:

Syntax OK
Salin selepas log masuk

但是,如果出现问题,您会被告知在哪部分发生了什么错误,例如:

AH00526: Syntax error on line 6 of /etc/apache2/mods-enabled/evasive.conf:
DOSSiteInterval takes one argument, Set site interval
Action 'configtest' failed.
The Apache error log may have more information.
Salin selepas log masuk

如果您的配置通过了 configtest 的测试,那么这个模块可以安全地被启用并且 Apache 可以重新加载:

a2enmod evasive
systemctl reload apache2.service
Salin selepas log masuk

mod_evasive 现在已配置好并正在运行了。

测试

为了测试 mod_evasive,我们只需要向服务器提出足够的网页访问请求,以使其超出阈值,并记录来自 Apache 的响应代码。

一个正常并成功的页面请求将收到如下响应:

HTTP/1.1 200 OK
Salin selepas log masuk

但是,被 mod_evasive 拒绝的将返回以下内容:

HTTP/1.1 403 Forbidden
Salin selepas log masuk

以下脚本会尽可能迅速地向本地主机(127.0.0.1,localhost)的 80 端口发送 HTTP 请求,并打印出每个请求的响应代码。

你所要做的就是把下面的 bash 脚本复制到一个文件中,例如 mod_evasive_test.sh

#!/bin/bash
set -e

for i in {1..50}; do
        curl -s -I 127.0.0.1 | head -n 1
done
Salin selepas log masuk

这个脚本的部分含义如下:

  • curl - 这是一个发出网络请求的命令。
    • -s - 隐藏进度表。
    • -I - 仅显示响应头部信息。
  • head - 打印文件的第一部分。
    • -n 1 - 只显示第一行。

然后赋予其执行权限:

chmod 755 mod_evasive_test.sh
Salin selepas log masuk

在启用 mod_evasive 之前,脚本运行时,将会看到 50 行 “HTTP / 1.1 200 OK” 的返回值。

但是,启用 mod_evasive 后,您将看到以下内容:

HTTP/1.1 200 OK
HTTP/1.1 200 OK
HTTP/1.1 403 Forbidden
HTTP/1.1 403 Forbidden
HTTP/1.1 403 Forbidden
HTTP/1.1 403 Forbidden
HTTP/1.1 403 Forbidden
...
Salin selepas log masuk

前两个请求被允许,但是在同一秒内第三个请求发出时,mod_evasive 拒绝了任何进一步的请求。您还将收到一封电子邮件(邮件地址在选项 DOSEmailNotify 中设置),通知您有 DOS 攻击被检测到。

mod_evasive 现在已经在保护您的网站啦!


Atas ialah kandungan terperinci Modul mengelak melindungi tapak web anda daripada serangan DOS lapisan aplikasi. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Kenyataan Laman Web ini
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn

Alat AI Hot

Undresser.AI Undress

Undresser.AI Undress

Apl berkuasa AI untuk mencipta foto bogel yang realistik

AI Clothes Remover

AI Clothes Remover

Alat AI dalam talian untuk mengeluarkan pakaian daripada foto.

Undress AI Tool

Undress AI Tool

Gambar buka pakaian secara percuma

Clothoff.io

Clothoff.io

Penyingkiran pakaian AI

AI Hentai Generator

AI Hentai Generator

Menjana ai hentai secara percuma.

Artikel Panas

R.E.P.O. Kristal tenaga dijelaskan dan apa yang mereka lakukan (kristal kuning)
1 bulan yang lalu By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Tetapan grafik terbaik
1 bulan yang lalu By 尊渡假赌尊渡假赌尊渡假赌
Akan R.E.P.O. Ada Crossplay?
1 bulan yang lalu By 尊渡假赌尊渡假赌尊渡假赌

Alat panas

Notepad++7.3.1

Notepad++7.3.1

Editor kod yang mudah digunakan dan percuma

SublimeText3 versi Cina

SublimeText3 versi Cina

Versi Cina, sangat mudah digunakan

Hantar Studio 13.0.1

Hantar Studio 13.0.1

Persekitaran pembangunan bersepadu PHP yang berkuasa

Dreamweaver CS6

Dreamweaver CS6

Alat pembangunan web visual

SublimeText3 versi Mac

SublimeText3 versi Mac

Perisian penyuntingan kod peringkat Tuhan (SublimeText3)

Perbezaan antara centos dan ubuntu Perbezaan antara centos dan ubuntu Apr 14, 2025 pm 09:09 PM

Perbezaan utama antara CentOS dan Ubuntu adalah: asal (CentOS berasal dari Red Hat, untuk perusahaan; Ubuntu berasal dari Debian, untuk individu), pengurusan pakej (CentOS menggunakan yum, yang memberi tumpuan kepada kestabilan; Ubuntu menggunakan APT, untuk kekerapan yang tinggi) Pelbagai tutorial dan dokumen), kegunaan (CentOS berat sebelah ke arah pelayan, Ubuntu sesuai untuk pelayan dan desktop), perbezaan lain termasuk kesederhanaan pemasangan (CentOS adalah nipis)

Cara memasang centos Cara memasang centos Apr 14, 2025 pm 09:03 PM

Langkah Pemasangan CentOS: Muat turun Imej ISO dan Burn Bootable Media; boot dan pilih sumber pemasangan; Pilih susun atur bahasa dan papan kekunci; Konfigurasikan rangkaian; memisahkan cakera keras; Tetapkan jam sistem; Buat pengguna root; pilih pakej perisian; Mulakan pemasangan; Mulakan semula dan boot dari cakera keras selepas pemasangan selesai.

Pilihan Centos setelah menghentikan penyelenggaraan Pilihan Centos setelah menghentikan penyelenggaraan Apr 14, 2025 pm 08:51 PM

CentOS telah dihentikan, alternatif termasuk: 1. Rocky Linux (keserasian terbaik); 2. Almalinux (serasi dengan CentOS); 3. Ubuntu Server (Konfigurasi diperlukan); 4. Red Hat Enterprise Linux (versi komersial, lesen berbayar); 5. Oracle Linux (serasi dengan CentOS dan RHEL). Apabila berhijrah, pertimbangan adalah: keserasian, ketersediaan, sokongan, kos, dan sokongan komuniti.

Cara menggunakan desktop docker Cara menggunakan desktop docker Apr 15, 2025 am 11:45 AM

Bagaimana cara menggunakan desktop Docker? Docktop Docktop adalah alat untuk menjalankan bekas Docker pada mesin tempatan. Langkah -langkah untuk digunakan termasuk: 1. Pasang desktop Docker; 2. Mulakan desktop Docker; 3. Buat imej Docker (menggunakan Dockerfile); 4. Membina imej Docker (menggunakan Docker Build); 5. Jalankan bekas Docker (menggunakan Docker Run).

Penjelasan terperinci mengenai Prinsip Docker Penjelasan terperinci mengenai Prinsip Docker Apr 14, 2025 pm 11:57 PM

Docker menggunakan ciri -ciri kernel Linux untuk menyediakan persekitaran berjalan yang cekap dan terpencil. Prinsip kerjanya adalah seperti berikut: 1. Cermin digunakan sebagai templat baca sahaja, yang mengandungi semua yang anda perlukan untuk menjalankan aplikasi; 2. Sistem Fail Kesatuan (Unionfs) menyusun pelbagai sistem fail, hanya menyimpan perbezaan, menjimatkan ruang dan mempercepatkan; 3. Daemon menguruskan cermin dan bekas, dan pelanggan menggunakannya untuk interaksi; 4. Ruang nama dan cgroups melaksanakan pengasingan kontena dan batasan sumber; 5. Pelbagai mod rangkaian menyokong interkoneksi kontena. Hanya dengan memahami konsep -konsep teras ini, anda boleh menggunakan Docker dengan lebih baik.

Apa yang Harus Dilakukan Setelah CentOs Berhenti Penyelenggaraan Apa yang Harus Dilakukan Setelah CentOs Berhenti Penyelenggaraan Apr 14, 2025 pm 08:48 PM

Selepas CentOS dihentikan, pengguna boleh mengambil langkah -langkah berikut untuk menanganinya: Pilih pengedaran yang serasi: seperti Almalinux, Rocky Linux, dan CentOS Stream. Berhijrah ke pengagihan komersial: seperti Red Hat Enterprise Linux, Oracle Linux. Menaik taraf ke CentOS 9 Stream: Pengagihan Rolling, menyediakan teknologi terkini. Pilih pengagihan Linux yang lain: seperti Ubuntu, Debian. Menilai pilihan lain seperti bekas, mesin maya, atau platform awan.

Konfigurasi komputer apa yang diperlukan untuk vscode Konfigurasi komputer apa yang diperlukan untuk vscode Apr 15, 2025 pm 09:48 PM

Keperluan Sistem Kod Vs: Sistem Operasi: Windows 10 dan ke atas, MACOS 10.12 dan ke atas, pemproses pengedaran Linux: minimum 1.6 GHz, disyorkan 2.0 GHz dan ke atas memori: minimum 512 MB, disyorkan 4 GB dan ke atas ruang penyimpanan: minimum 250 mb, disyorkan 1 GB dan di atas keperluan lain:

Apa yang perlu dilakukan sekiranya imej docker gagal Apa yang perlu dilakukan sekiranya imej docker gagal Apr 15, 2025 am 11:21 AM

Langkah Penyelesaian Masalah untuk Gagal Docker Image Build: Semak Sintaks Dockerfile dan Versi Ketergantungan. Semak jika konteks binaan mengandungi kod sumber dan kebergantungan yang diperlukan. Lihat log binaan untuk butiran ralat. Gunakan pilihan sasaran untuk membina fasa hierarki untuk mengenal pasti titik kegagalan. Pastikan anda menggunakan versi terkini Enjin Docker. Bina imej dengan --t [nama imej]: mod debug untuk debug masalah. Semak ruang cakera dan pastikan ia mencukupi. Lumpuhkan Selinux untuk mengelakkan gangguan dengan proses binaan. Tanya platform komuniti untuk mendapatkan bantuan, sediakan dockerfiles dan bina deskripsi log untuk cadangan yang lebih spesifik.

See all articles