当前位置: 首页 > news >正文

Apache网页优化

网页压缩与缓存

网页压缩

不需要成本的提升Apache本身的响应速度,仅会让服务器CPU占用率升高一到两个百分点或更少

1.gzip介绍

是一种流行的文件压缩算法。使用gzip压缩一个纯文本时,效果尤为明细。利用Apache中的gzip模块,可以使用gzip压缩算法对Apache服务器发布的网页的内容进行压缩后再传输到客户端浏览器,加快了网页加载到速度

2.HTTP压缩过程

Web服务器接受到HTTP请求后 ,检查浏览器是否支持HTTP压缩。如果浏览器支持HTTP压缩,Web服务器检查请求文件的后缀名。如果请求文件是HTML、CSS等静态文件,Web服务器到压缩缓冲目录中检查是否已存在请求文件的最新压缩文件,如果不存在,服务器返回未压缩的文件,在浏览器的压缩缓冲目录

3.apache的压缩模块

mod_deflate和mod_gzip

mod_deflate对服务器cpu占用较低,但压缩率比mod_zip高

mod_gzip对服务器cpu占用更高,但压缩率更高

网页压缩的实现过程

查看浏览器支持哪些压缩方式

此界面在浏览器中按f12来打开,Accept-Encoding表示支持的压缩方式

安装mod_deflate

首先检查是否已安装mod_deflate

apachectl -t -D DUMP_MODULES | grep deflate

下载并解压httpd的源码包,进入到其中的./modules/filter文件夹中,运行以下命令来进行安装

/usr/local/httpd/bin/apxs -i -c -a mod_deflate.c 
启用mod_deflate

需要去httpd的主配置文件中进行

[root@localhost ~]# vim /usr/local/httpd/conf/httpd.conf    
LoadModule deflate_module  modules/mod_deflate.so        //该行取消前面的注释
<IfModule mod_deflate.c> 
AddOutputFilterByType DEFLATE text/html text/plain text/css text/xml text/javascript text/jpg text/png #压缩的文件类型
DeflateCompressionLevel 9  //压缩级别
SetOutputFilter DEFLATE    //是否启用压缩
</IfModule>

更改完成后重启httpd服务

用浏览器来访问该网站的目录,若响应标头中有下图中的信息即为成功

网页缓存

步骤

全程在httpd的主文件中进行更改

在httpd.conf中查找expires,找到LoadModule expires_module modules/mod_expires.so,并取消注释,之后在这段代码后添加

<IfModule mod_expires.c>
ExpiresActive On
ExpiresDefault "access plus 60 seconds"
</IfModule>

然后重启服务,在浏览器中进行测试

如图中信息包含expires项 ,说明网页缓存配置成功

版本信息隐藏

软件的漏洞信息和特定版本是相关的,因此软件版本号一般是需要隐藏的,可以减少受攻击的风险,保护服务器的安全运行

首先在主配置文件中,取消该行注释

Include conf/extra/httpd-default.conf

然后进入到安装目录下的/conf/extra,编辑httpd-default.cof

# ServerTokens
# This directive configures what you return as the Server HTTP response
# Header. The default is 'Full' which sends information about the OS-Type
# and compiled in modules.
# Set to one of:  Full | OS | Minor | Minimal | Major | Prod            //修改显示级别可用的选项,从左到右显示的越来越少
# where Full conveys the most information, and Prod the least.
#
ServerTokens Full                                        

网页防盗链

防止其他网站直接使用我的网站上的的链接,来占用我服务器的资源

模拟防盗链

配置主机

首先要准备三台主机

 其中apache1为我的主机,apache2为盗链主机,win11主机则是模拟用户

修改apache2,和用户主机的hosts文件,在其中添加

192.168.10.101 www.benet.com
192.168.10.102 www.accp.com

在我的主机中编辑默认网页index.html

[root@apache1 ~]# vim /usr/local/httpd/htdocs/index.html
<html>
<body>
<h1>It work! </h1>
<img src="logo.jpg"/>
</body>
</html>

在盗链主机中编辑默认网页

[root@apache1 ~]# vim /usr/local/httpd/htdocs/index.html
<html>
<body>
<h1>It work! </h1>
<img src="www.benet.com/logo.jpg"/>        //直接引用我的主机的图片链接
</body>
</html>

 

防盗链

修改httpd的主配置文件 

找到LoadModule rewrite_module modules/mod_rewrite.so并取消注释

再找到<Directory "/usr/local/httpd/htdocs">,在其下添加如下内容

RewriteEngine On
RewriteCond %{HTTP_REFERER} !^http://benet.com/.*$ [NC] 
RewriteCond %{HTTP_REFERER} !^http://benet.com$ [NC] 
RewriteCond %{HTTP_REFERER} !^http://www.benet.com/.*$ [NC] 
RewriteCond %{HTTP_REFERER} !^http://www.benet.com/$ [NC]
RewriteRule .*\.(gif|jpg|swf)$ http://www.benet.com/error.png

重启httpd服务后再访问盗链主机就是这样的

相关文章:

  • 【尚庭公寓SpringBoot + Vue 项目实战】公寓管理(十一)
  • NumPy 切片和索引
  • Linux时间子系统1:gettimeofday和clock_gettime实现分析
  • 【Python】 Stacking: 强大的集成学习方法
  • React 中的事件处理
  • 如何确保数据跨域交换安全、合规、可追溯性?
  • java中Array(数组)、List(列表)、Set(集合)、Map(映射)、Queue(队列)详解
  • 【面试题】MySQL常见面试题总结
  • 深度学习第二章
  • Perplexity AI — 探索网络,发掘知识,沟通思想
  • 基于鲸鱼优化的DSN弱栅栏覆盖算法matlab仿真
  • MySQL之优化服务器设置(五)
  • 几何公差的设计和选用
  • k8s-kubernetes常用命令,服务部署,可视化控制台安装及token的生成
  • 【Android面试八股文】在Android中,出现ClassNotFound的有可能的原因是什么?
  • Apache Zeppelin在Apache Trafodion上的可视化
  • Apache的基本使用
  • Dubbo 整合 Pinpoint 做分布式服务请求跟踪
  • ES6核心特性
  • Laravel5.4 Queues队列学习
  • Less 日常用法
  • spring cloud gateway 源码解析(4)跨域问题处理
  • Spring Cloud(3) - 服务治理: Spring Cloud Eureka
  • webgl (原生)基础入门指南【一】
  • WordPress 获取当前文章下的所有附件/获取指定ID文章的附件(图片、文件、视频)...
  • zookeeper系列(七)实战分布式命名服务
  • 表单中readonly的input等标签,禁止光标进入(focus)的几种方式
  • 从@property说起(二)当我们写下@property (nonatomic, weak) id obj时,我们究竟写了什么...
  • 从零搭建Koa2 Server
  • 从零开始在ubuntu上搭建node开发环境
  • 关于 Cirru Editor 存储格式
  • 看图轻松理解数据结构与算法系列(基于数组的栈)
  • 扩展资源服务器解决oauth2 性能瓶颈
  • ​​​​​​​ubuntu16.04 fastreid训练过程
  • ​【C语言】长篇详解,字符系列篇3-----strstr,strtok,strerror字符串函数的使用【图文详解​】
  • ​Spring Boot 分片上传文件
  • ​渐进式Web应用PWA的未来
  • ​软考-高级-信息系统项目管理师教程 第四版【第23章-组织通用管理-思维导图】​
  • ​总结MySQL 的一些知识点:MySQL 选择数据库​
  • #微信小程序:微信小程序常见的配置传值
  • (2024,LoRA,全量微调,低秩,强正则化,缓解遗忘,多样性)LoRA 学习更少,遗忘更少
  • (pojstep1.3.1)1017(构造法模拟)
  • (附源码)spring boot北京冬奥会志愿者报名系统 毕业设计 150947
  • (附源码)springboot码头作业管理系统 毕业设计 341654
  • (附源码)ssm高校社团管理系统 毕业设计 234162
  • (四)TensorRT | 基于 GPU 端的 Python 推理
  • (一)eclipse Dynamic web project 工程目录以及文件路径问题
  • (一)基于IDEA的JAVA基础10
  • *Algs4-1.5.25随机网格的倍率测试-(未读懂题)
  • .bat批处理(四):路径相关%cd%和%~dp0的区别
  • .net 前台table如何加一列下拉框_如何用Word编辑参考文献
  • .py文件应该怎样打开?
  • @Resource和@Autowired的区别
  • [ 隧道技术 ] 反弹shell的集中常见方式(四)python反弹shell
  • [《百万宝贝》观后]To be or not to be?