हाल ही में, जब क्यूफू एक ग्राहक की वेबसाइट का रखरखाव कर रहा था, तो ग्राहक ने अनुरोध किया कि विदेशी आईपी से पहुंच को अवरुद्ध कर दिया जाए। लॉग के अनुसार, अधिकांश हमलावर आईपी विदेश से आए थे, और लक्षित उपयोगकर्ता घरेलू थे, इसलिए केवल घरेलू आईपी को ही पहुंच की अनुमति थी। वेबसाइट अधिकांश CC और DDoS हमलों को रोक सकती है। वास्तविक परीक्षण के बाद, यह पाया गया कि प्रभाव अभी भी अच्छा है, और दोबारा हमला करने की लागत बहुत बढ़ गई है।

हालाँकि, बाद में एक समस्या का पता चला। Cloudflare CDN का उपयोग करने के बाद, वेबसाइट द्वारा प्राप्त सभी IP पते Cloudflare के CDN नोड्स से प्राप्त नहीं किए जा सके, और रक्षा प्रभाव बहुत कम हो गया। सौभाग्य से, क्लाउडफ्लेयर ने  

X-Forwarded-For हेडर के साथ, यदि यह Nginx है तो आप ngx_http_realip_module मॉड्यूल का उपयोग कर सकते हैं, या उपयोगकर्ता का वास्तविक IP प्राप्त करने के लिए यदि यह Apache है तो mod_remoteip मॉड्यूल का उपयोग कर सकते हैं। यह आलेख साझा करेगा कि उपयोगकर्ता का वास्तविक आईपी पता प्राप्त करने के लिए ngx_http_realip_module मॉड्यूल और mod_remoteip मॉड्यूल को कैसे संकलित और सक्षम किया जाए।

सामान्यतया, सीडीएन विक्रेताओं ने एक्स-फॉरवर्डेड-फॉर और एक्स-रियल_आईपी जैसे मानक प्रोटोकॉल अपनाए हैं, इसलिए इस लेख में पेश की गई उपयोगकर्ता की वास्तविक आईपी प्राप्त करने की पहुंच मूल रूप से अन्य सीडीएन विक्रेताओं पर लागू होती है। सीडीएन त्वरण और सर्वर अनुकूलन और त्वरण विधियों पर अधिक जानकारी के लिए, यहां हैं:

  1. क्लाउडफ्लेयर पार्टनर एक्सेस प्रबंधन क्लाउडफ्लेयर सीडीएन-सक्षम रेलगन गतिशील त्वरण
  2. Youpaiyun CDN एक्सेलेरेशन एप्लिकेशन ट्यूटोरियल - वन-क्लिक मिररिंग, स्टेटिक डायनेमिक CDN और फ्री SSL
  3. वर्डप्रेस Nginx fastcgi_cache कैश एक्सेलेरेशन विधि को सक्षम करता है - Nginx कॉन्फ़िगरेशन उदाहरण

1. Nginx ngx_http_realip_module संकलित करता है

1.1  वनइंस्टैक संकलन

यदि आप वनस्टैक वन-क्लिक पैकेज का उपयोग कर रहे हैं, तो आप ngx_http_realip_module को संकलित करने के लिए निम्न कमांड का उपयोग कर सकते हैं:

#下编译安装nginx的时候,都编译安装的哪些模块
[root@wzfoume ~]# nginx -V 
nginx version: nginx/1.14.2
built by gcc 4.4.7 20120313 (Red Hat 4.4.7-23) (GCC) 
built with OpenSSL 1.1.1a  20 Nov 2018
TLS SNI support enabled
configure arguments: --prefix=/usr/local/nginx --user=www --group=www --with-http_stub_status_module --with-http_v2_module --with-http_ssl_module --with-http_gzip_static_module --with-http_realip_module --with-http_flv_module --with-http_mp4_module --with-openssl=../openssl-1.1.1a --with-pcre=../pcre-8.42 --with-pcre-jit --with-ld-opt=-ljemalloc

#进入到oneinstack的nginx安装目录下,如果没有请先解压
[root@wzfoume src]# cd /root/oneinstack/src
[root@wzfoume src]# tar xzf nginx-1.14.2.tar.gz
[root@wzfoume src]# cd /root/oneinstack/src/nginx-1.14.2
[root@wzfoume nginx-1.14.2]# ./configure --prefix=/usr/local/nginx --user=www --group=www --with-http_stub_status_module --with-http_v2_module --with-http_ssl_module --with-http_gzip_static_module --with-http_realip_module --with-http_flv_module --with-http_mp4_module --with-openssl=../openssl-1.1.1a --with-pcre=../pcre-8.42 --with-pcre-jit --with-ld-opt=-ljemalloc --with-http_realip_module

make

#如果出现错误,应该是依赖路径不对,请cd ..到上一个目录解压相应的软件
tar xzf pcre-8.42.tar.gz
tar xzf openssl-1.0.2q.tar.gz
tar xzf openssl-1.1.1a.tar.gz

#编译完成,备份原先配置,然后替换nginx二进制文件
mv /usr/local/nginx/sbin/nginx{,_`date +%F`}  #备份nginx
cp objs/nginx /usr/local/nginx/sbin

#查看是否已经把http_realip_module模块加入进去
nginx -V

1.2  एलएनएमपी संकलन

यदि आप एलएनएमपी वन-क्लिक पैकेज का उपयोग कर रहे हैं, तो एलएनएमपी इंस्टॉलेशन निर्देशिका में lnmp.conf ढूंढें और इसे संपादित करें, Nginx_Modules_Options में रीयलिप जोड़ें, सहेजें और ./upgrade.sh nginx निष्पादित करें बस Nginx को अपग्रेड करने के लिए। आदेश इस प्रकार है:

Nginx_Modules_Options='--with-http_realip_module'

1.3  बीटी पैगोडा पैनल

यदि आप बीटी पैगोडा पैनल का उपयोग कर रहे हैं, तो आप ngx_http_realip_module को संकलित करने के लिए निम्नलिखित कमांड का उपयोग कर सकते हैं:

#宝塔面板安装模块

#先查看一下本机的Nginx配置情况
[root@cs ~]# nginx -V
nginx version: nginx/1.14.2
built by gcc 4.8.5 20150623 (Red Hat 4.8.5-36) (GCC) 
built with OpenSSL 1.0.2l  25 May 2017
TLS SNI support enabled
configure arguments: --user=www --group=www --prefix=/www/server/nginx --with-openssl=/www/server/nginx/src/openssl --add-module=/www/server/nginx/src/ngx_devel_kit --add-module=/www/server/nginx/src/lua_nginx_module --add-module=/www/server/nginx/src/ngx_cache_purge --add-module=/www/server/nginx/src/nginx-sticky-module --add-module=/www/server/nginx/src/nginx-http-concat --with-http_stub_status_module --with-http_ssl_module --with-http_v2_module --with-http_image_filter_module --with-http_gzip_static_module --with-http_gunzip_module --with-stream --with-stream_ssl_module --with-ipv6 --with-http_sub_module --with-http_flv_module --with-http_addition_module --with-http_realip_module --with-http_mp4_module --with-ld-opt=-Wl,-E --with-pcre=pcre-8.40 --with-ld-opt=-ljemalloc
#开始下载Nginx,这里用的是1.15.1,你也可以下载其它的版本
wget http://nginx.org/download/nginx-1.15.1.tar.gz
tar -xzvf nginx-1.15.1.tar.gz
cd nginx-1.15.1
#下面的命令只是在上面的Nginx -v得到的配置详情后加上了--with-http_realip_module,目的是为了保持原来的配置不变同时又增加新的模块
./configure --user=www --group=www --prefix=/www/server/nginx --with-openssl=/www/server/nginx/src/openssl --add-module=/www/server/nginx/src/ngx_devel_kit --add-module=/www/server/nginx/src/lua_nginx_module --add-module=/www/server/nginx/src/ngx_cache_purge --add-module=/www/server/nginx/src/nginx-sticky-module --add-module=/www/server/nginx/src/nginx-http-concat --with-http_stub_status_module --with-http_ssl_module --with-http_v2_module --with-http_image_filter_module --with-http_gzip_static_module --with-http_gunzip_module --with-stream --with-stream_ssl_module --with-ipv6 --with-http_sub_module --with-http_flv_module --with-http_addition_module --with-http_realip_module --with-http_mp4_module --with-ld-opt=-Wl,-E --with-pcre=pcre-8.40 --with-ld-opt=-ljemalloc --with-http_realip_module
#只编译不安装
make

#先停用Nginx,然后替换新的Nginx并查看模块是否已经加载。命令如下:
mv /www/server/nginx/sbin/nginx /www/server/nginx/sbin/nginx-wzfou.backup
cp objs/nginx /www/server/nginx/sbin/nginx
nginx -V

#重启Nginx

2. Nginx सेटिंग्स set_real_ip_from

ngx_http_realip_module को संकलित करने के बाद, अब हमें केवल Nginx कॉन्फ़िगरेशन फ़ाइल में set_real_ip_from कोड जोड़ने की आवश्यकता है। उदाहरण इस प्रकार है:

set_real_ip_from 222.222.222.222;  #这里是需要填写具体的CDN服务器IP地址,可添加多个
set_real_ip_from 222.222.111.111; 
real_ip_header  X-Forwarded-For;
real_ip_recursive on;

यदि आप CloudFlare मुफ़्त CDN का उपयोग कर रहे हैं, तो कृपया अपनी Nginx कॉन्फ़िगरेशन फ़ाइल में निम्नलिखित कोड जोड़ें।

location / {
 set_real_ip_from 103.21.244.0/22;
 set_real_ip_from 103.22.200.0/22;
 set_real_ip_from 103.31.4.0/22;
 set_real_ip_from 104.16.0.0/12;
 set_real_ip_from 108.162.192.0/18;
 set_real_ip_from 131.0.72.0/22;
 set_real_ip_from 141.101.64.0/18;
 set_real_ip_from 162.158.0.0/15;
 set_real_ip_from 172.64.0.0/13;
 set_real_ip_from 173.245.48.0/20;
 set_real_ip_from 188.114.96.0/20;
 set_real_ip_from 190.93.240.0/20;
 set_real_ip_from 197.234.240.0/22;
 set_real_ip_from 198.41.128.0/17;
 set_real_ip_from 199.27.128.0/21;
 set_real_ip_from 2400:cb00::/32;
 set_real_ip_from 2606:4700::/32;
 set_real_ip_from 2803:f800::/32;
 set_real_ip_from 2405:b500::/32;
 set_real_ip_from 2405:8100::/32;
 set_real_ip_from 2c0f:f248::/32;
 set_real_ip_from 2a06:98c0::/29;
 # use any of the following two
 real_ip_header CF-Connecting-IP;
 #real_ip_header X-Forwarded-For;
 }

#不要忘记重启nginx
service nginx restart

सामान्यतया, CloudFlare का IP पता नहीं बदलेगा। आप इसे यहां पा सकते हैं: https://www.cloudflare.com/ips/, लेकिन केवल मामले में, wzfou.com एक IP पता सेट करने की अनुशंसा करता है जो CloudFlare को स्वचालित रूप से अपडेट करता है निर्धारित कार्य स्वचालित रूप से Nginx कॉन्फ़िगरेशन फ़ाइल में नवीनतम IP जोड़ता है। कोड नीचे के रूप में दिखाएं:

#在nginx配置目录创建cloudflare_ip.conf文件
touch /usr/local/nginx/conf/cloudflare_ip.conf

#修改原有的vhost配置,将原来第五步配置的信息改为
include cloudflare_ip.conf;

#创建自更新脚本update_cloudflare_ip.sh(假定该文件放在 /root 目录下),内容如下:

#!/bin/bash
echo "#Cloudflare" > /usr/local/nginx/conf/cloudflare_ip.conf;
for i in `curl https://www.cloudflare.com/ips-v4`; do
        echo "set_real_ip_from $i;" >> /usr/local/nginx/conf/cloudflare_ip.conf;
done
for i in `curl https://www.cloudflare.com/ips-v6`; do
        echo "set_real_ip_from $i;" >> /usr/local/nginx/conf/cloudflare_ip.conf;
done
echo "" >> /usr/local/nginx/conf/cloudflare_ip.conf;
echo "# use any of the following two" >> /usr/local/nginx/conf/cloudflare_ip.conf;
echo "real_ip_header CF-Connecting-IP;" >> /usr/local/nginx/conf/cloudflare_ip.conf;
echo "#real_ip_header X-Forwarded-For;" >> /usr/local/nginx/conf/cloudflare_ip.conf;


#配置crontab 每周一的上午5点更新
0 5 * * 1 /bin/bash /root/update_cloudflare_ip.sh

3. अपाचे कॉन्फ़िगरेशन mod_remoteip मॉड्यूल

3.1  अपाचे 2.4

अपाचे 2.4 के साथ आने वाले mod_remoteip मॉड्यूल को स्थापित करने की आवश्यकता नहीं है:

#启用模块

vim /usr/local/apache/conf/httpd.conf

Include conf/extra/httpd-remoteip.conf

#添加如下内容
vim /usr/local/apache/conf/extra/httpd-remoteip.conf

LoadModule remoteip_module modules/mod_remoteip.so
RemoteIPHeader X-Forwarded-For
RemoteIPInternalProxy 127.0.0.1/24
#CloudFlare IP Ranges
RemoteIPInternalProxy 103.21.244.0/22
RemoteIPInternalProxy 103.22.200.0/22
RemoteIPInternalProxy 103.31.4.0/22
RemoteIPInternalProxy 104.16.0.0/12
RemoteIPInternalProxy 108.162.192.0/18
RemoteIPInternalProxy 131.0.72.0/22
RemoteIPInternalProxy 141.101.64.0/18
RemoteIPInternalProxy 162.158.0.0/15
RemoteIPInternalProxy 172.64.0.0/13
RemoteIPInternalProxy 173.245.48.0/20
RemoteIPInternalProxy 188.114.96.0/20
RemoteIPInternalProxy 190.93.240.0/20
RemoteIPInternalProxy 197.234.240.0/22
RemoteIPInternalProxy 198.41.128.0/17 #你的CDN的IP,可以重复添加

#修改日志格式,在日志格式中加上%a,然后重启apache即可

LogFormat "%h %a %l %u %t "%r" %>s %b "%{Referer}i" "%{User-Agent}i"" combined
LogFormat "%h %a %l %u %t "%r" %>s %b" common
LogFormat "%h %l %u %t "%r" %>s %b "%{Referer}i" "%{User-Agent}i" %I %O" combined

3.2  अपाचे 2.2

अपाचे 2.2 को mod_remoteip मॉड्यूल स्थापित करने की आवश्यकता है। विधि इस प्रकार है:

wget https://github.com/ttkzw/mod_remoteip-httpd22/raw/master/mod_remoteip.c
/usr/local/apache/bin/apxs -i -c -n mod_remoteip.so mod_remoteip.c

#启用模块
vim /usr/local/apache/conf/httpd.conf

Include conf/extra/httpd-remoteip.conf

#添加如下内容,然后重启apache即可
vim /usr/local/apache/conf/extra/httpd-remoteip.conf

LoadModule remoteip_module modules/mod_remoteip.so
RemoteIPHeader X-Forwarded-For
RemoteIPInternalProxy 127.0.0.1 #你的CDN的IP,可以重复添加

4. वेबसाइट केवल क्लाउडफ्लेयर सीडीएन से आईपी एक्सेस की अनुमति देती है

ऊपर हमने ngx_http_realip_module और mod_remoteip मॉड्यूल स्थापित करके उपयोगकर्ता का वास्तविक आईपी पता प्राप्त किया है, लेकिन कभी-कभी हमें CC या DDoS हमलों को रोकने के लिए Cloudflare के सुरक्षा सुरक्षा फ़ंक्शन का उपयोग करने की आवश्यकता होती है, अर्थात, केवल Cloudflare CDN IP को हमारी पहुंच तक पहुंचने की अनुमति दें।

Nginx के कोड उदाहरण सीधे तौर पर IP एक्सेस को अस्वीकार करने और अनुमति देने के प्रकार इस प्रकार हैं:

location / {
    deny  192.168.1.1;
    allow 192.168.1.0/24;
    allow 10.1.1.0/16;
    allow 2001:0db8::/32;
    #Railgun IP
    deny  all;
}

यदि हम केवल Cloudflare CDN के IP को वेबसाइट तक पहुंचने की अनुमति देते हैं, तो हम सीधे Cloudflare CDN के IP को nginx कॉन्फ़िगरेशन में अनुमत सीमा में जोड़ सकते हैं।

#直接加入
# https://www.cloudflare.com/ips
# IPv4
allow 103.21.244.0/22;
allow 103.22.200.0/22;
allow 103.31.4.0/22;
allow 104.16.0.0/12;
allow 108.162.192.0/18;
allow 131.0.72.0/22;
allow 141.101.64.0/18;
allow 162.158.0.0/15;
allow 172.64.0.0/13;
allow 173.245.48.0/20;
allow 188.114.96.0/20;
allow 190.93.240.0/20;
allow 197.234.240.0/22;
allow 198.41.128.0/17;

# IPv6
allow 2400:cb00::/32;
allow 2405:8100::/32;
allow 2405:b500::/32;
allow 2606:4700::/32;
allow 2803:f800::/32;
allow 2c0f:f248::/32;
allow 2a06:98c0::/29;

क्लाउडफ्लेयर सीडीएन आईपी को स्वचालित रूप से अपडेट करें। क्लाउडफ़ेयर CDN IP को Nginx कॉन्फ़िगरेशन में मैन्युअल रूप से जोड़ना सरल और सुविधाजनक है, हालाँकि, एक बार Cloudflare CDN IP बदल जाने पर, आपको इसे मैन्युअल रूप से और स्वचालित रूप से अपडेट करने के लिए एक स्क्रिप्ट बनानी होगी इसे Nginx कॉन्फ़िगरेशन में जोड़ें, कोड इस प्रकार है:

touch /usr/local/nginx/conf/allow_ip.conf
#修改网站nginx配置,加入以下代码:
include /usr/local/nginx/conf/allow_ip.conf;

vim /data/script/allow_cf_ip.sh
#!/bin/bash
echo "#Cloudflare" > /usr/local/nginx/conf/allow_ip.conf;
for i in `curl https://www.cloudflare.com/ips-v4`; do
     echo "allow $i;" >> /usr/local/nginx/conf/allow_ip.conf;
done
for i in `curl https://www.cloudflare.com/ips-v6`; do
       echo "allow $i;" >> /usr/local/nginx/conf/allow_ip.conf;
done


#添加定时任务
0 5 * * 1 /bin/bash /data/script/allow_cf_ip.sh

5. सारांश

CDN त्वरण का उपयोग करने के बाद, हमारी वेबसाइट द्वारा प्राप्त उपयोगकर्ता IP CDN IP बन जाता है। यदि हम उपयोगकर्ता का वास्तविक IP प्राप्त करना चाहते हैं, तो हमें Nginx और Apache के मोड फ़ंक्शन का उपयोग करना होगा। बेशक, यदि आप वर्डप्रेस जैसे PHP का उपयोग कर रहे हैं, तो बस निम्नलिखित कोड को सीधे अपनी वर्डप्रेस कॉन्फ़िगरेशन फ़ाइल में जोड़ें।

if(isset($_SERVER['HTTP_X_FORWARDED_FOR']))
{
$list = explode(‘,’,$_SERVER['HTTP_X_FORWARDED_FOR']);
$_SERVER['REMOTE_ADDR'] = $list[0];
}

यहां एक विशेष अनुस्मारक यह है कि यदि आप क्लाउडफ्लेयर रेलगन डायनेमिक एक्सेलेरेशन को सक्षम करते हैं (माइनिंग स्टेशन का क्लाउडफ्लेयर पार्टनर एक्सेस प्रबंधन यह मुफ्त सेवा प्रदान करता है), तो रेलगन सर्वर आईपी को कॉन्फ़िगरेशन में जोड़ना याद रखें, क्योंकि रेलगन को सक्षम करने के बाद, वेबसाइट आईपी प्राप्त करेगी प्राप्त पते सभी रेलगन सर्वर से हैं।

उत्तर छोड़ दें