ホームページ >運用・保守 >Nginx >Nginx に基づく Web サイトへの特定の IP および外部 IP のアクセスを禁止する方法

Nginx に基づく Web サイトへの特定の IP および外部 IP のアクセスを禁止する方法

王林
王林転載
2023-05-23 19:13:432146ブラウズ

    Nginx を使用して、指定した IP および外部 IP による Web サイトへのアクセスを禁止する

    この機能を実現するには、さまざまな方法があります。 Nginx ngx_http_geoip2 モジュールで、外部 IP が Web サイトにアクセスするのを防ぎます。

    ①geoip2 拡張機能の依存関係をインストールします:

    [root@fxkj ~]# yum install libmaxminddb-devel -y

    ②ngx_http_geoip2_module モジュールをダウンロードします:

    [root@fxkj tmp]#  git clone https://github.com/leev/ngx_http_geoip2_module.git
    [ro tmp]#

    ③モジュールを指定されたパスに解凍します

    ここで /usr/ に解凍しますローカル ディレクトリの下:

    [root@fxkj tmp]# mv ngx_http_geoip2_module/ /usr/local/
    [root@fxkj local]# ll ngx_http_geoip2_module/
    total 60
    -rw-r--r-- 1 root root  1199 Aug 13 17:20 config
    -rw-r--r-- 1 root root  1311 Aug 13 17:20 LICENSE
    -rw-r--r-- 1 root root 23525 Aug 13 17:20 ngx_http_geoip2_module.c
    -rw-r--r-- 1 root root 21029 Aug 13 17:20 ngx_stream_geoip2_module.c
    -rw-r--r-- 1 root root  3640 Aug 13 17:20 README.md

    ④nginx モジュールをインストールします

    まず環境について説明します。私の nginx バージョンは 1.16 です。ngx_http_geoip2 モジュールをインストールするには、少なくともバージョン 1.18 以降が必要であることをオンラインで確認しました。最初のインストール中に、nginx1.18 をアップグレードし、ngx_http_geoip2 モジュールを追加しました。

    nginx 1.18 バージョンをダウンロード:

    [root@fxkj ~]# yum install libmaxminddb-devel -y

    nginx1.18 ソフトウェア パッケージを解凍し、nginx1.18 にアップグレードし、ngx_http_geoip2 モジュールを追加します。

    注:

    • nginx をアップグレードしてモジュールを追加するには、コンパイルして make 操作を実行するだけです。 make install を実行すると、新しいバージョンの nginx がオンライン nginx を完全に置き換えます。

    • コンパイルする前に、現在 nginx にインストールされているモジュールを確認する必要があります。

    [root@fxkj tmp]# /usr/local/nginx/sbin/nginx -V
    nginx version: nginx/1.16.0
    built by gcc 4.8.5 20150623 (Red Hat 4.8.5-39) (GCC)
    built with OpenSSL 1.0.2k-fips 26 Jan 2017
    TLS SNI support enabled
    configure arguments: –with-http_stub_status_module –prefix=/usr/local/nginx –user=nginx –group=nginx –with-http_ssl_module –with-stream

    コンパイルとインストール:

    [root@fxkj tmp]# tar -xf nginx-1.18.0.tar.gz
    [root@fxkj tmp]# cd nginx-1.18.0/
    [root@fxkj nginx-1.18.0]# ./configure --with-http_stub_status_module \
     --prefix=/usr/local/nginx \
     --user=nginx --group=nginx --with-http_ssl_module --with-stream \
     --add-module=/usr/local/ngx_http_geoip2_module
    [root@fxkj nginx-1.18.0]# make
    [root@fxkj nginx-1.18.0]# cp /usr/loca/nginx/sbin/nginx /usr/loca/nginx/sbin/nginx1.16    #备份
    [root@fxkj nginx-1.18.0]# cp objs/nginx /usr/local/nginx/sbin/    #用新的去覆盖旧的
    [root@fxkj nginx-1.18.0]# pkill nginx     #杀死nginx
    [root@fxkj nginx-1.18.0]# /usr/local/nginx/sbin/nginx    #再次启动Nginx

    nginx のバージョンとインストールされているモジュールを確認します:

    [root@fxkj nginx-1.18.0]# /usr/local/nginx/sbin/nginx -V
    nginx version: nginx/1.18.0
    built by gcc 4.8.5 20150623 (Red Hat 4.8.5-39) (GCC)
    built with OpenSSL 1.0.2k-fips 26 Jan 2017
    TLS SNI support enabled
    configure arguments: –with-http_stub_status_module –prefix=/usr/local/nginx –user=nginx –group=nginx –with-http_ssl_module –with-stream –add-module=/usr/local/ngx_http_geoip2_module

    ⑤最新の IP アドレス データベース ファイルをダウンロードします

    モジュールが正常にインストールされた後、Nginx でデータベースを指定する必要があります。ランタイム ライブラリをインストールすると、デフォルトで 2 つが /usr/share/GeoIP/ ディレクトリにインストールされ、1 つは IPv4 のみを備え、もう 1 つは IPv4 のみをサポートします。 IPv4 と IPv6 が含まれます。

    www.maxmind.com Web サイトにアクセスし、アカウントを登録して、最新のライブラリ ファイルをダウンロードします。左側の [ファイルのダウンロード] をクリックし、アカウント作成手順をスキップします。

    Nginx に基づく Web サイトへの特定の IP および外部 IP のアクセスを禁止する方法

    GeoLite2 国を選択し、[GZIP のダウンロード] をクリックしてダウンロードします:

    Nginx に基づく Web サイトへの特定の IP および外部 IP のアクセスを禁止する方法

    ##/usr/share/GeoIP/ にアップロードして解凍します:

    [root@fxkj local]# cd /usr/share/GeoIP/
    [root@fxkj GeoIP]# ll
    total 69612
    lrwxrwxrwx. 1 root root       17 Mar  7  2019 GeoIP.dat -> GeoIP-initial.dat
    -rw-r--r--. 1 root root  1242574 Oct 30  2018 GeoIP-initial.dat
    lrwxrwxrwx. 1 root root       19 Mar  7  2019 GeoIPv6.dat -> GeoIPv6-initial.dat
    -rw-r--r--. 1 root root  2322773 Oct 30  2018 GeoIPv6-initial.dat
    -rw-r--r--  1 root root  3981623 Aug 12 02:37 GeoLite2-Country.mmdb

    ⑥nginx 構成ファイルを構成します

    変更する前に構成ファイルをバックアップします:

    [root@fxkj ~]# cp /usr/local/nginx/conf/nginx.conf /usr/local/nginx/conf/nginx.conf-bak
    [root@fxkj ~]# vim /usr/local/nginx/conf/nginx.conf

    http にデータベース ファイルの場所を定義するための数行:

    geoip2 /usr/share/GeoIP/GeoLite2-City.mmdb {
    auto_reload 5m;
    $geoip2_data_country_code country iso_code;
    }
      map $geoip2_data_country_code $allowed_country {
                    default yes;
                    CN no;
    }

    Nginx に基づく Web サイトへの特定の IP および外部 IP のアクセスを禁止する方法

    サーバー内の場所に条件を追加します。IP が外部 IP の場合は、次のリターン アクションを実行します。 Here I am 3 つのタイプが定義されており、そのうちの 2 つは注釈が付けられています。

    #アクセスされた IP が外部 IP の場合、404 が直接返されます:

    if ($allowed_country = yes) {
           # return https://www.baidu.com;
           # return /home/japan;
            return 404;
     }

    Nginx に基づく Web サイトへの特定の IP および外部 IP のアクセスを禁止する方法##変更が完了したら、設定ファイルを確認して nginx をリロードします。

    [root@fxkj ~]# /usr/local/nginx/sbin/nginx -t
    nginx: the configuration file /usr/local/nginx/conf/nginx.conf syntax is ok
    nginx: configuration file /usr/local/nginx/conf/nginx.conf test is successful
    [roo@fxkj ~]# /usr/local/nginx/sbin/nginx -s reload

    ⑦シミュレーションテスト検証

    海外ノードのサーバーを使用してWebサイトにアクセスします。ここでのIPは韓国からのものです:

    Nginx に基づく Web サイトへの特定の IP および外部 IP のアクセスを禁止する方法 Web サイトにアクセスすると、エラー 404 Not Found が表示されます:

    Nginx に基づく Web サイトへの特定の IP および外部 IP のアクセスを禁止する方法 nginx のアクセス ログを見てみましょう:

    “13.125.1.194 – – [14/Aug/2020:16:15:51 +0800] “GET /favicon.ico HTTP/1.1” 404 548 “https://www.fxkjnj.com/” “Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/84.0.4147.125 Safari/537.36”

    以上がNginx に基づく Web サイトへの特定の IP および外部 IP のアクセスを禁止する方法の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

    声明:
    この記事はyisu.comで複製されています。侵害がある場合は、admin@php.cn までご連絡ください。