Web服务器群集:Nginx网页及安全优化

这篇具有很好参考价值的文章主要介绍了Web服务器群集:Nginx网页及安全优化。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

目录

一、理论

1.Nginx网页优化

2.Nginx安全优化

3.Nginx日志分割

二、实验

1.网页压缩

2.网页缓存

3.连接超时设置

4.并发设置

5.隐藏版本信息

 6.脚本实现每月1号进行日志分割

7.防盗链

三、总结


一、理论

1.Nginx网页优化

(1)概述

在企业中,部署Nginx后只采用默认的配置参数,会引发网站很多问题,换言之默认配置是针对以前较低的服务器配置的,以前的配置已不适用当今的互联网时代。

为了适应企业需求,就需要考虑如何提升Nginx的性能与稳定性,这就是Nginx优化的内容。

优化内容:

表1 优化内容

分类 优化内容
网页优化 配置网页压缩功能
配置网页缓存
连接超时设置
并发设置
页面安全 配置隐藏版本号
日志分割 日志分割
防盗链 配置防盗链

(2)网页压缩

① gzip介绍

配置Nginx的网页压缩功能,是使用gzip压缩算法来对网页内容进行压缩后再传输到客户端浏览器。

作用:

降低了网络传输的字节数,加快网页加载的速度;
节省流量,改善用户的浏览体验;
gzip与搜索引擎的抓取工具具有更好的关系。

vim /usr/local/nginx/conf/nginx.conf
http {
...... 
   gzip on;							#取消注释,开启gzip压缩功能
   gzip_min_length 1k;      		#最小压缩文件大小
   gzip_buffers 4 64k;      		#压缩缓冲区,大小为4个64k缓冲区
   gzip_http_version 1.1;   		#压缩版本(默认1.1,前端如果是squid2.5请使用1.0)
   gzip_comp_level 6;       		#压缩比率
   gzip_vary on;					#支持前端缓存服务器存储压缩页面
   gzip_types text/plain text/javascript application/x-javascript text/css text/xml application/xml application/xml+rss image/jpg image/jpeg image/png image/gif application/x-httpd-php application/javascript application/json;		#压缩类型,表示哪些网页文档启用压缩功能
...... 
}

  ②   Nginx的压缩模块

Nginx的ngx_http_gzip_module压缩模块提供对文件内容压缩的功能
允许Nginx服务器将输出内容在发送客户端之前进行压缩,以节约网站带宽,提升用户的访问体验,默认已经安装
可在配置文件中加入相应的压缩功能参数对压缩性能进行优化。

(3)网页缓存

当Nginx将网页数据返回给客户端后,可设置缓存的时间,以方便在日后进行相同内容的请求时直接返回,避免重复请求,加快了访问速度。
注:一般针对静态网页设置,对动态网页不设置缓存时间。

vim /usr/local/nginx/conf/nginx.conf
http {
......
	server {
	...... 
		location / {
			root html;
			index index.html index.htm;
		}
		
		location ~ \.(gif|jpg|jepg|png|bmp|ico)$ { 		#加入新的 location,以图片作为缓存对象
			root html;
			expires 1d;									#指定缓存时间,1天
		}
......
	}
}

(4)连接超时设置

HTTP有一个KeepAlive模式,它告诉web服务器在处理完一个请求后保持这个TCP连接的打开状态。若接收到来自同一客户端的其它请求,服务端会利用这个未被关闭的连接,而不需要再建立一个连接。
KeepAlive 在一段时间内保持打开状态,它们会在这段时间内占用资源。占用过多就会影响性能。
在企业网站中,为了避免同一个客户长时间占用连接,造成资源浪费,可设置相应的连接超时参数,实现控制连接访问时间。可以修改配置文件 nginx.conf,设置 keepalive_timeout超时。
 

vim /usr/local/nginx/conf/nginx.conf
 http {
 ...... 
     keepalive_timeout 65 180;       //设置连接超时时间    
     client_header_timeout 80;
     client_body_timeout 80;
 ...... 
 }

(5)并发设置

在高并发场景,需要启动更多的Nginx进程以保证快速响应,以处理用户的请求,避免造成阻塞。

① 查看cpu的核心数:

查看cpu的核心数,根据核心数来设置工作进程数
cat /proc/cpuinfo |grep processor|wc -l
cat /proc/cpuinfo |grep -c processor
cat /proc/cpuinfo | grep -c "physical id"

② 修改工作进程核心数:

修改工作进程核心数 
vim /usr/local/nginx/conf/nginx.conf
worker_processes  1;        #修改为与CPU核数相同
worker_cpu_affinity 01 10;  #设置每个进程由不同cpu处理,进程数配为4时0001 0010 0100 1000

2.Nginx安全优化

(1)防盗链

防盗链是防止别人的网站代码里面盗用我们自己服务器上的图片,文件,视频等相关资源;

如果别人盗用网站的这些静态资源,明显的是会增大服务器的带宽压力;

作为网站的维护人员,要杜绝服务器的静态资源被其他网站盗用。

Nginx盗链的过程与apache一致,均是通过网页浏览,将网站图片重定向到自己的网站上。

vim /usr/local/nginx/conf/nginx.conf
http {
......
	server {
	......
		location ~* \.(jpg|gif|swf)$ {
			valid_referers none blocked *.david.com jack.com;
			if ( $invalid_referer ) {
				rewrite ^/ http://www.david.com/error.png;
				#return 403;
            }
        }
	......
	}
}

(2)隐藏版本信息

作用:一般情况下,软件的漏洞信息和特定的版本是相关的,因此,软件的版本号对攻击者来说是很有价值的,所以我们隐藏Nginx的版本号,减少受攻击风险,保护服务器安全运行

Nginx隐藏版本号的方法:
① 修改配置文件(隐藏版本号)

vim /usr/local/nginx/conf/nginx.conf
server_tokens off;
##若在http模块中加,为全局设置
##在server模块内加,为当前主机设置

② 修改源码法(修改版本号)

vim /opt/nginx-1.22.0/src/core/nginx.h
#define NGINX_VERSION "1.1.1" 					#修改版本号
#define NGINX_VER "IIS" NGINX_VERSION 			#修改服务器类型

cd /opt/nginx-1.22.0/
./configure --prefix=/usr/local/nginx --user=nginx --group=nginx --with-http_stub_status_module
make && make install

vim /usr/local/nginx/conf/nginx.conf
http {
    include       mime.types;
    default_type  application/octet-stream;
    server_tokens on;
	......
}

3.Nginx日志分割

Nginx与apache的不同之处,就是Nginx本身并未设计日志分割工具,所以需要运维人员进行脚本编写来实现日志分割。

日志分割脚本:

#!/bin/bash
day=$(date +%Y-%m-%d)
dir="/usr/local/nginx/logs/"
logs_file='/usr/local/nginx/logs/access.log'
logs_error='/usr/local/nginx/logs/error.log'
pid_file='/usr/local/nginx/logs/nginx.pid'
if [ ! -d $dir ]
   then mkdir $dir
   fi
mv ${logs_file} ${dir}/access${day}.log
mv ${logs_error} ${dir}/error${day}.log
kill -USR1 $(cat ${pid_file})
find $dir -mtime +30 -exec rm -rf {} \;

二、实验

1.网页压缩

(1)配置文件

Web服务器群集:Nginx网页及安全优化,Web服务器群集,服务器,数据库,运维

 加入压缩功能参数

Web服务器群集:Nginx网页及安全优化,Web服务器群集,服务器,数据库,运维

配置网页

Web服务器群集:Nginx网页及安全优化,Web服务器群集,服务器,数据库,运维

Web服务器群集:Nginx网页及安全优化,Web服务器群集,服务器,数据库,运维

 查看图片为已压缩

Web服务器群集:Nginx网页及安全优化,Web服务器群集,服务器,数据库,运维

2.网页缓存

(1)配置文件

Web服务器群集:Nginx网页及安全优化,Web服务器群集,服务器,数据库,运维

Web服务器群集:Nginx网页及安全优化,Web服务器群集,服务器,数据库,运维

  查看图片缓存失效时间为1天Web服务器群集:Nginx网页及安全优化,Web服务器群集,服务器,数据库,运维

3.连接超时设置

(1)配置文件

Web服务器群集:Nginx网页及安全优化,Web服务器群集,服务器,数据库,运维

 设置超时

Web服务器群集:Nginx网页及安全优化,Web服务器群集,服务器,数据库,运维

 查看连接已设超时Web服务器群集:Nginx网页及安全优化,Web服务器群集,服务器,数据库,运维

4.并发设置

(1)配置文件

Web服务器群集:Nginx网页及安全优化,Web服务器群集,服务器,数据库,运维

 查看CPU内核数:

Web服务器群集:Nginx网页及安全优化,Web服务器群集,服务器,数据库,运维

 修改工作进程核心数:

Web服务器群集:Nginx网页及安全优化,Web服务器群集,服务器,数据库,运维

5.隐藏版本信息

(1)修改配置文件(隐藏版本号)

 查询版本号 

Web服务器群集:Nginx网页及安全优化,Web服务器群集,服务器,数据库,运维

配置文件关闭版本

Web服务器群集:Nginx网页及安全优化,Web服务器群集,服务器,数据库,运维

关闭版本号

Web服务器群集:Nginx网页及安全优化,Web服务器群集,服务器,数据库,运维

查询

Web服务器群集:Nginx网页及安全优化,Web服务器群集,服务器,数据库,运维

 (2)修改源码法(修改版本号)

编辑文件

vim /opt/nginx-1.22.0/src/core/nginx.h

修改版本号及服务器类型

Web服务器群集:Nginx网页及安全优化,Web服务器群集,服务器,数据库,运维

指定安装路径

Web服务器群集:Nginx网页及安全优化,Web服务器群集,服务器,数据库,运维

完成

Web服务器群集:Nginx网页及安全优化,Web服务器群集,服务器,数据库,运维

  编译安装Web服务器群集:Nginx网页及安全优化,Web服务器群集,服务器,数据库,运维

 启用版本

Web服务器群集:Nginx网页及安全优化,Web服务器群集,服务器,数据库,运维

 查看版本

 Web服务器群集:Nginx网页及安全优化,Web服务器群集,服务器,数据库,运维

 6.脚本实现每月1号进行日志分割

 (1)编写日志分割脚本

cd /opt
vim nginxlog.sh

Web服务器群集:Nginx网页及安全优化,Web服务器群集,服务器,数据库,运维

 (2)赋权

Web服务器群集:Nginx网页及安全优化,Web服务器群集,服务器,数据库,运维

(3)执行脚本进行测试

Web服务器群集:Nginx网页及安全优化,Web服务器群集,服务器,数据库,运维

(4)查看日志

Web服务器群集:Nginx网页及安全优化,Web服务器群集,服务器,数据库,运维

(5)计划性任务

Web服务器群集:Nginx网页及安全优化,Web服务器群集,服务器,数据库,运维

7.防盗链

(1)web源主机(192.168.204.200)

配置文件

Web服务器群集:Nginx网页及安全优化,Web服务器群集,服务器,数据库,运维

Web服务器群集:Nginx网页及安全优化,Web服务器群集,服务器,数据库,运维

配置网页

Web服务器群集:Nginx网页及安全优化,Web服务器群集,服务器,数据库,运维

 Web服务器群集:Nginx网页及安全优化,Web服务器群集,服务器,数据库,运维  

配置主机与IP映射

Web服务器群集:Nginx网页及安全优化,Web服务器群集,服务器,数据库,运维

Web服务器群集:Nginx网页及安全优化,Web服务器群集,服务器,数据库,运维

 (2)盗链网址主机(192.168.204.150)

配置文件

Web服务器群集:Nginx网页及安全优化,Web服务器群集,服务器,数据库,运维

 Web服务器群集:Nginx网页及安全优化,Web服务器群集,服务器,数据库,运维

 配置网页

Web服务器群集:Nginx网页及安全优化,Web服务器群集,服务器,数据库,运维

Web服务器群集:Nginx网页及安全优化,Web服务器群集,服务器,数据库,运维

 Web服务器群集:Nginx网页及安全优化,Web服务器群集,服务器,数据库,运维

 (3)在web源主机查看浏览器

Web服务器群集:Nginx网页及安全优化,Web服务器群集,服务器,数据库,运维

(4)在盗图网站主机上进行浏览器验证

Web服务器群集:Nginx网页及安全优化,Web服务器群集,服务器,数据库,运维

三、总结

在企业信息化应用环境中,服务器的安全性和响应速度需要根据实际情况进行响应参数配置,以达到最优的用户体验,默认的 Nginx安装参数只能提供最基本的服务,还需要调和如网页缓存时间、连接超时、网页压缩等响应参数,才能发挥出服务器的最大作用。

Nginx网页及安全优化常用方法为网页压缩、网页缓存、连接超时设置、并发设置、防盗链、日志分割和隐藏版本信息。文章来源地址https://www.toymoban.com/news/detail-544349.html

到了这里,关于Web服务器群集:Nginx网页及安全优化的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • web服务器—nginx

    Nginx(“engine x”)是一款是由俄罗斯的程序设计师Igor Sysoev所开发高性能的 Web和 反向代理服务器,也是一个 IMAP/POP3/SMTP 代理服务器。和apache一样,都是web服务器软件,因为其性能优异,所以被广大运维喜欢。又因为nginx是一个轻量级的web服务器,相比apache来说 资源消耗更低 。

    2023年04月09日
    浏览(38)
  • 如何在虚拟专用服务器上配置 Nginx Web 服务器

    本文档涵盖的是不再受支持的 Ubuntu 版本。如果您目前正在运行 Ubuntu 12.04 服务器,我们强烈建议升级或迁移到受支持的 Ubuntu 版本: 升级到 Ubuntu 14.04 从 Ubuntu 14.04 升级到 Ubuntu 16.04 将服务器数据迁移到受支持的版本 原因: Ubuntu 12.04 已于 2017 年 4 月 28 日到达生命周期终点(

    2024年04月27日
    浏览(34)
  • apache的ab工具测试网页优化效果速度以及服务器承载

    今天为大家介绍一款apache自带的一种的测试网页优化效果速度以及服务器承载的工具——ab.exe。 window系统安装,通过官网下载apache zip安装包,解压后放在C(or)D盘根目录 下载网址:https://www.apachehaus.com/cgi-bin/download.plx 如下图位置点击下载zip包 大家在工作中或者开发中可以使

    2024年02月11日
    浏览(58)
  • Linux -- Web服务器 快速搭建静态网站,替换默认网页目录

    先简单写个 页面          我们给网页写了一行内容 作为 静态网页的内容 ( 当然了,写的相当简单,您先理解着看)         可以看到的是,我们将内容 定向到了一个文件里,         这个文件的路径 (  /var/www/html  )熟悉不熟悉???         ===            

    2023年04月19日
    浏览(48)
  • OPENWRT 使用nginx作为web服务器

    在op上大家使用nginx作为web服务器,主要是为了其强大的反向代理功能,但op上的nginx官方做了一定的修改,配置上稍显复杂,几篇文章也是比较老的,配置也是一头雾水,作业都不好抄,索性自己查了资料学了些nginx的内容,实现了如下的功能: ####默认你已经完成 域名申请,

    2024年02月04日
    浏览(31)
  • 【Web服务器】Nginx常见问题(二)

    优化内容 设置方式 隐藏版本号 server_tokens off; 设置运行用户/组 方法一:配置文件中修改 user 用户组 组名; 方法二:编译时直接设置 页面缓存时间 expires 时间; 连接保持超时 keepalive_timeout 服务器超时时间 [客户端超时时间] ; 设置工作进程数 worker_processes auto/同CPU数量 ; worker

    2024年02月08日
    浏览(34)
  • Web网页浏览器远程访问jupyter notebook服务器【内网穿透】

    Jupyter Notebook,它是一个交互式的数据科学和计算环境,支持多种编程语言,如Python、R、Julia等。它在数据科学、机器学习、深度学习、教育和文档编写等领域都有很广泛的应用。 重要的是,Jupyter Notebook可以在Web浏览器中使用,所以我们可以在服务器端开启服务,在外通过网

    2024年02月12日
    浏览(50)
  • 【在 Ubuntu 上配置 Nginx 作为 Web 服务器】

    在 Ubuntu 上配置 Nginx 作为 Web 服务器非常常见,以下是在 Ubuntu 上配置 Nginx 的基本步骤: 安装 Nginx : 打开终端,运行以下命令来安装 Nginx: 启动 Nginx : 安装完成后,Nginx 会自动启动。你可以使用以下命令来检查 Nginx 服务状态: 配置 Nginx : Nginx 的配置文件位于 /etc/nginx/

    2024年04月23日
    浏览(32)
  • haproxy服务器对nginx服务器web服务调度负载均衡、用nfs做共享目录(脚本部署)

    目录 一、准备 二、在作为haproxy的服务器上导入以下shell执行haproxy安装 三、由于nginx服务需要用的nfs共享目录,先部署nfs 四、nginx服务器1部署 五、nginx服务器2部署同上 六、测试 一、准备 四台服务器 系统 IP 搭建服务器 centos7 192.168.1.12 haproxy centos7 192.168.1.132 nfs(rpcbind) ce

    2024年02月09日
    浏览(39)
  • 使用HTTP/2在Linux上的Nginx服务器进行优化

    随着互联网的发展,HTTP/2协议逐渐成为主流。与传统的HTTP/1.1相比,HTTP/2提供了更高的传输效率和更好的安全性。在Linux上使用Nginx服务器进行优化,我们可以充分利用HTTP/2的优势,提高网站的性能和用户体验。 1. 安装Nginx并启用HTTP/2 首先,确保你的Nginx服务器已经安装并正常

    2024年02月01日
    浏览(52)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包