中文字幕av专区_日韩电影在线播放_精品国产精品久久一区免费式_av在线免费观看网站

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

Nginx如何隱藏版本號

發布時間:2021-07-30 09:24:57 來源:億速云 閱讀:313 作者:小新 欄目:服務器

這篇文章將為大家詳細講解有關Nginx如何隱藏版本號,小編覺得挺實用的,因此分享給大家做個參考,希望大家閱讀完這篇文章后可以有所收獲。

Nginx隱藏版本號

在生產環境中,需要隱藏Nginx的版本號,以避免安全漏洞的泄露

查看方法

使用fiddler工具在Windows客戶端查看Nginx版本號
在centos系統中使用“curl -I 網址” 命令查看

Nginx隱藏版本號的方法

修改配置文件法
修改源碼法

一,安裝Nginx

1,在Linux上使用遠程共享獲取文件并掛載到mnt目錄下

[root@localhost ~]# smbclient -L //192.168.100.3/  ##遠程共享訪問
Enter SAMBA\root's password: 

                Sharename    Type   Comment
                ---------    ----   -------
                LNMP-C7     Disk    
[root@localhost ~]# mount.cifs //192.168.100.3/LNMP-C7 /mnt ##掛載到/mnt目錄下

2,解壓源碼包到/opt下,并查看

[root@localhost ~]# cd /mnt  ##切換到掛載點目錄
[root@localhost mnt]# ls
Discuz_X3.4_SC_UTF8.zip  nginx-1.12.2.tar.gz
mysql-boost-5.7.20.tar.gz php-7.1.20.tar.gz
[root@localhost mnt]# tar zxvf nginx-1.12.2.tar.gz -C /opt  ##解壓Nginx源碼包到/opt下
[root@localhost mnt]# cd /opt/  ##切換到解壓的目錄下
[root@localhost opt]# ls
nginx-1.12.2 rh

3,安裝編譯需要的環境組件包

[root@localhost opt]# yum -y install \
gcc \                    //c語言
gcc-c++ \            //c++語言
pcre-devel \           //pcre語言工具
zlib-devel            //數據壓縮用的函式庫

4,創建程序用戶nginx并編譯Nginx

[root@localhost opt]# useradd -M -s /sbin/nologin nginx ##創建程序用戶,安全不可登陸狀態
[root@localhost opt]# id nginx
uid=1001(nginx) gid=1001(nginx) 組=1001(nginx)
[root@localhost opt]# cd nginx-1.12.0/         ##切換到nginx目錄下
[root@localhost nginx-1.12.0]# ./configure \     ##配置nginx
> --prefix=/usr/local/nginx \    ##安裝路徑
> --user=nginx \             ##用戶名
> --group=nginx \            ##用戶組
> --with-http_stub_status_module   ##狀態統計模塊

5,編譯和安裝

[root@localhost nginx-1.12.0]# make   ##編譯
...
[root@localhost nginx-1.12.0]# make install  ##安裝
...
[root@localhost nginx]# ln -s /usr/local/nginx/sbin/nginx /usr/local/sbin/ 
##創建軟連接讓系統識別nginx啟動腳本

6,制作管理腳本,便于使用service管理使用

[root@localhost nginx]# cd /etc/init.d/  ##切換到啟動配置文件目錄
[root@localhost init.d]# ls
functions netconsole network README
[root@localhost init.d]# vim nginx     ##編輯啟動腳本文件

#!/bin/bash
# chkconfig: - 99 20                  ##注釋信息
# description: Nginx Service Control Script
PROG="/usr/local/nginx/sbin/nginx"      ##設置變量為nginx命令文件
PIDF="/usr/local/nginx/logs/nginx.pid"    ##設置變量PID文件 進程號為5346
case "$1" in 
        start)
                $PROG                   ##開啟服務
                ;;
        stop)
                kill -s QUIT $(cat $PIDF)      ##關閉服務
                ;;
        restart)                        ##重啟服務
                $0 stop
                $0 start
                ;;
        reload)                        ##重載服務
                kill -s HUP $(cat $PIDF)
                ;;
        *)                              ##錯誤輸入提示
                echo "Usage: $0 {start|stop|restart|reload}"
               exit 1
esac
exit 0
[root@localhost init.d]# chmod +x /etc/init.d/nginx  ##給啟動腳本執行權限
[root@localhost init.d]# chkconfig --add nginx     ##添加到service管理器中
[root@localhost init.d]# service nginx stop        ##就可以使用service控制nginx
[root@localhost init.d]# service nginx start

二,隱藏版本號

[root@localhost init.d]# curl -I http://192.168.13.140/  ##查看Nginx信息
HTTP/1.1 200 OK
Server: nginx/1.12.2  ##顯示版本號
Date: Tue, 12 Nov 2019 14:23:24 GMT
Content-Type: text/html
Content-Length: 612
Last-Modified: Tue, 12 Nov 2019 13:46:35 GMT
Connection: keep-alive
ETag: "5dcab7bb-264"
Accept-Ranges: bytes
[root@localhost init.d]# vim /usr/local/nginx/conf/nginx.conf ##修改配置文件

http {      ##在http下添加
    include    mime.types;
    default_type application/octet-stream;
    server_tokens off;  ##關閉版本號

[root@localhost init.d]# service nginx stop ##關閉服務
[root@localhost init.d]# service nginx start ##開啟服務
[root@localhost init.d]# curl -I http://192.168.13.140/ ##查看Nginx信息
HTTP/1.1 200 OK   
Server: nginx      ##版本號被隱藏
Date: Tue, 12 Nov 2019 14:22:00 GMT
Content-Type: text/html
Content-Length: 612
Last-Modified: Tue, 12 Nov 2019 13:46:35 GMT
Connection: keep-alive
ETag: "5dcab7bb-264"
Accept-Ranges: bytes

三,偽造版本號(需要重新編譯安裝,可以在編譯安裝之前操作)

1,開啟版本號

[root@localhost init.d]# vim /usr/local/nginx/conf/nginx.conf
http {
    include    mime.types;
    default_type application/octet-stream;
    server_tokens on;  ##開啟版本號

2,修改Nginx源碼包文件

[root@localhost init.d]# cd /opt/nginx-1.12.2/src/core/ ##切換到src源碼包目錄
[root@localhost core]# vim nginx.h ##修改文件

#define NGINX_VERSION   "1.1.1" ##此處版本號偽造成1.1.1

3,重新編譯安裝

[root@localhost core]# cd /opt/nginx-1.12.2/  ##切換目錄到Nginx下
[root@localhost nginx-1.12.2]# ./configure \   ##重新配置
> --prefix=/usr/local/nginx \
> --user=nginx \
> --group=nginx \
> --with-http_stub_status_module
[root@localhost nginx-1.12.0]# make   ##重新編譯
...
[root@localhost nginx-1.12.0]# make install  ##重新安裝
...

4,重啟Nginx服務,查看版本信息

[root@localhost nginx-1.12.2]# service nginx stop ##關閉
[root@localhost nginx-1.12.2]# service nginx start ##開啟
[root@localhost nginx-1.12.2]# curl -I http://192.168.13.140/  ##查看Nginx信息
HTTP/1.1 200 OK 
Server: nginx/1.1.1    ##此時的版本號就是偽造的版本號
Date: Tue, 12 Nov 2019 14:34:02 GMT
Content-Type: text/html
Content-Length: 612
Last-Modified: Tue, 12 Nov 2019 13:46:35 GMT
Connection: keep-alive
ETag: "5dcab7bb-264"
Accept-Ranges: bytes

Nginx網頁緩存時間

  • 當Nginx將網頁數據返回給客戶端后,可設置緩存時間,以方便在日后進行相同內容的請求時直接返回,避免重復請求,加快了訪問速度

  • 一般針對靜態網頁設置,對動態網頁不設置緩存時間

  • 可在Windows客戶端中使用fiddler查看網頁緩存時間

設置方法

可修改配置文件,在http段,或者server段,或者location段加入對特定內容的過期參數

實驗環境

一臺Nginx服務器
一臺測試機win10

一,將圖片復制到Nginx的站點目錄下

[root@localhost ~]# cd /mnt/  ##切換到掛載點
[root@localhost mnt]# ls
11.jpg          mysql-boost-5.7.20.tar.gz php-7.1.20.tar.gz
22.jpg          nginx-1.12.2.tar.gz
Discuz_X3.4_SC_UTF8.zip php-7.1.10.tar.bz2  
[root@localhost mnt]# cp 11.jpg /usr/local/nginx/html/  ##復制圖片到站點中
[root@localhost mnt]# cd /usr/local/nginx/html/  ##切換到站點下
[root@localhost html]# ls
11.jpg 50x.html index.html

二,修改網頁信息,將圖片加到index.html文件中

[root@localhost html]# vim index.html ##修改網頁信息

</head>
<body>
<h2>Welcome to nginx!</h2>
<img src="11.jpg"/> ##加入圖片到網頁中

三,修改配置文件信息

[root@localhost html]# vim /usr/local/nginx/conf/nginx.conf  ##修改配置文件

events {
    worker_connections 1024;
}
    user nginx nginx;   ##修改Nginx用戶和組

  # deny access to .htaccess files, if Apache's document root
  # concurs with nginx's one
  #
  location ~\.(gif|jepg|jpg|ico|bmp|png)$ {   ##支持圖片格式
    root html;   ##站點
    expires 1d;  ##緩存一天
    }
[root@localhost html]# service nginx stop  ##關閉開啟服務
[root@localhost html]# service nginx start

四,用fiddler查看緩存

Nginx如何隱藏版本號

Nginx如何隱藏版本號

Nginx的日志切割

隨著Nginx運行時間增加,日志也會增加。為了方便掌握Nginx運行狀態,需要時刻關注日志文件

太大的日志文件對監控是一個大災難

定期進行日志文件的切割

Nginx自身不具備日志分割處理的功能,但可以通過Nginx信號控制功能的腳本實現日志的自動切割,并通過Linux的計劃任務周期性的進行日志切割

1,編寫日志分割腳本文件

[root@localhost ~]# vim fenge.sh ##編寫腳本文件

#!/bin/bash
#Filename:fenge.sh
d=$(date -d "-1 day" "+%Y%m%d")    ##顯示一天前的時間
logs_path="/var/log/nginx"           ##分割日志的保存路徑
pid_path="/usr/local/nginx/logs/nginx.pid"  ##pid的路徑
[ -d $logs_path ] || mkdir -p $logs_path ##沒有目錄則創建目錄
mv /usr/local/nginx/logs/access.log ${logs_path}/test.com-access.log-$d
##原有日志文件生成到新路徑下
kill -USR1 $(cat $pid_path) ##結束重新生成新的pid文件
find $logs_path -mtime +30 | xargs rm -rf ##刪除30天前的日志文件

[root@localhost ~]# chmod +x fenge.sh ##給執行權限
[root@localhost ~]# ./fenge.sh   ##執行腳本文件

2,查看日志分割情況

[root@localhost ~]# cd /var/log/nginx/  ##切換到Nginx的日志目錄下
[root@localhost nginx]# ls
test.com-access.log-20191112
[root@localhost nginx]# date -s 2019-11-14 ##修改日期為明天的時間
2019年 11月 14日 星期四 00:00:00 CST
[root@localhost nginx]# cd ~
[root@localhost ~]# ./fenge.sh   ##重新執行腳本
[root@localhost ~]# cd /var/log/nginx/
[root@localhost nginx]# ls      ##查看日志分割日志文件
test.com-access.log-20191112 test.com-access.log-20191113

3,設置周期性計劃任務

[root@localhost nginx]# crontab -e  ##周期性計劃任務
0 1 * * * /opt/fenge.sh

關于“Nginx如何隱藏版本號”這篇文章就分享到這里了,希望以上內容可以對大家有一定的幫助,使各位可以學到更多知識,如果覺得文章不錯,請把它分享出去讓更多的人看到。

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

静宁县| 深水埗区| 通州区| 明光市| 红桥区| 定襄县| 明溪县| 惠来县| 浦城县| 尼勒克县| 盖州市| 斗六市| 吉水县| 丹巴县| 宜宾市| 康马县| 拜城县| 正定县| 肥西县| 广州市| 广汉市| 南丹县| 上蔡县| 扎兰屯市| 辽宁省| 文安县| 海盐县| 大厂| 金川县| 鄂州市| 孟津县| 友谊县| 图木舒克市| 开原市| 滨海县| 响水县| 治多县| 湘乡市| 柳林县| 当阳市| 富阳市|