Apache的配置与应用(优化)

目录

1、构建虚拟Web主机

2、httpd服务支持的虚拟主机类型包括以下三种:

1、基于端口的虚拟主机(此为编译安装)

2、基于IP(在域名基础上)

 3、基于端口(基于上层IP和域名)

4、构建Web虚拟目录与用户授权限制

 3、Apache网页与安全优化

(1)网页压缩

(2)网页缓存

 (3)Apache 防盗链


1、构建虚拟Web主机

虚拟Web主机指的是在同一台服务器中运行多个Web站点,其中每一个站点实际上并不独立占用整个服务器,因此被称为“虚拟”Web 主机。通过虚拟 Web 主机服务可以充分利用服务器的硬件资源,从而大大降低网站构建及运行成本。

使用httpd服务可以非常方便地构建虚拟主机服务器,只需要运行一个httpd服务就能够同时支撑大量的Web站点。Apache虚拟主机相当于一个在同一台服务器中却相互独立的站点,从而实现一台主机对外提供多个 web 服务,每个虚拟主机之间是独立的,互不影响的。

2、httpd服务支持的虚拟主机类型包括以下三种:

1.基于域名:为每个虚拟主机使用不同的域名,但是其对应的 IP 地址是相同的。例如,www.benet.com 和 www.accp.com 站点的 IP 地址都是 192.168.80.10。这是使用最为普遍的虚拟 Web 主机类型。

2.基于IP地址:为每个虚拟主机使用不同的域名,且各自对应的IP地址也不相同。这种方式需要为服务器配备多个网络接口,因此应用并不是非常广泛。

3.基于端口:这种方式并不使用域名、IP地址来区分不同的站点内容,而是使用了不同的TCP端口号,因此用户在浏览不同的虚拟站点时需要同时指定端口号才能访问。

1、基于端口的虚拟主机(此为编译安装)

在/etc/hosts 文件中临时配置域名与IP地址的映射关系

echo "192.168.100.80 www.benet.com" >> /etc/hosts

echo "192.168.100.80 www.accp.com" >> /etc/hosts

查看是否添加

Apache的配置与应用(优化)_第1张图片

为虚拟主机准备网页文档

[root@192 ~]# mkdir -p /usr/local/httpd/htdocs/benet

[root@192 ~]# mkdir -p /usr/local/httpd/htdocs/accp

[root@192 ~]# echo "

www.benet.com

" > /usr/local/httpd/htdocs/benet/index.html

[root@192 ~]# echo "

www.accp.com

" > /usr/local/httpd/htdocs/accp/index.html

 

 查看会有httpd.Vhosts.conf并进入

 备份

 将httpd-vhosts.onf配置文件件改成

htdoces去掉e 

Apache的配置与应用(优化)_第2张图片

加载独立的配置文件

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

Apache的配置与应用(优化)_第3张图片

 输入ip地址 或者域名

Apache的配置与应用(优化)_第4张图片

2、基于IP(在域名基础上)

进入/usr/local/httpd/conf/extra/httpd-vhosts.conf下更改配置

Apache的配置与应用(优化)_第5张图片

 添加一个网卡

Apache的配置与应用(优化)_第6张图片

 [root@192 extra]# vim /usr/local/httpd/conf/httpd.conf  添加监听地址

 在53行插入

Apache的配置与应用(优化)_第7张图片

 输入ip地址会显示除相应的域名

Apache的配置与应用(优化)_第8张图片

 3、基于端口(基于上层IP和域名)

进入/usr/local/httpd/conf/extra/httpd-vhosts.conf下添加

Apache的配置与应用(优化)_第9张图片

重新启动服务 需要等待

否则会报错

在网站中输入

192.168.182.40:8081

Apache的配置与应用(优化)_第10张图片

4、构建Web虚拟目录与用户授权限制

 在创建一个ruocheng用户

Apache的配置与应用(优化)_第11张图片

 访问授权 进入

添加末行

Alias /test /usr/local/httpd/htdocs/test

        AuthName "Hello!"

        AuthType Basic

        AuthUserFile /usr/local/httpd/conf/user

        Require valid-user

   #authgroupfile /usr/local/httpd/conf/group

   #Require user zhangsan

   #Require group zhangsan              

 Apache的配置与应用(优化)_第12张图片

 保存退出后

最后将ip地址输入到浏览器当中

Apache的配置与应用(优化)_第13张图片

 3、Apache网页与安全优化

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

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

(1)网页压缩

1.检查是否安装 mod_deflate 模块
apachectl -t -D DUMP_MODULES | grep "deflate"

2.如果没有安装mod_deflate 模块,重新编译安装 Apache 添加 mod_deflate 模块
systemctl stop httpd.service
cd /usr/local/httpd/conf
mv httpd.conf httpd.conf.bak

yum -y install gcc gcc-c++ pcre pcre-devel zlib-devel

Apache的配置与应用(优化)_第14张图片

cd /opt/httpd-2.4.29/  (一般情况下 放在opt下 我放在了指定位置)
./configure \
--prefix=/usr/local/httpd \
--enable-so \
--enable-rewrite \
--enable-charset-lite \
--enable-cgi \
--enable-deflate                #加入mod_deflate 模块

Apache的配置与应用(优化)_第15张图片

 make && make instalApache的配置与应用(优化)_第16张图片

 3.配置 mod_deflate 模块启用
vim /usr/local/httpd/conf/httpd.conf
--52行--修改
Listen 192.198.80.10:80
--105行--取消注释
LoadModule deflate_module modules/mod_deflate.so        #开启mod_deflate 模块
--197行--取消注释,修改
ServerName www.kgc.com:80
--末行添加--

AddOutputFilterByType DEFLATE text/html text/plain text/css text/xml text/javascript text/jpg text/png    #代表对什么样的内容启用gzip压缩
DeflateCompressionLevel 9            #代表压缩级别,范围为1~9
SetOutputFilter DEFLATE                #代表启用deflate 模块对本站点的输出进行gzip压缩

Apache的配置与应用(优化)_第17张图片

Apache的配置与应用(优化)_第18张图片

 末行添加

4.检查安装情况,启动服务
apachectl -t            #验证配置文件的配置是否正确
apachectl -t -D DUMP_MODULES | grep "deflate"        #检查 mod_deflate 模块是否已安装
  deflate_module (shared)                            #已安装的正确结果

Apache的配置与应用(优化)_第19张图片

 systemctl start httpd.service重启服务

5.测试 mod_deflate 压缩是否生效
cd /usr/local/httpd/htdocs
先将game.jpg文件传到/usr/local/httpd/htdocs目录下
vim index.html

It works!It works!It works!It works!It works!It works!It works!It works!It !It works!It works!It works!It works!



 Apache的配置与应用(优化)_第20张图片

 最后再网页中打开 我是将图片直接拽入 更改文件名  可直接显示

Apache的配置与应用(优化)_第21张图片

(2)网页缓存

1.检查是否安装 mod_expires 模块
apachectl -t -D DUMP_MODULES | grep "expires"

2.如果没有安装mod_expires 模块,重新编译安装 Apache 添加 mod_expires模块
systemctl stop httpd.service
cd /usr/local/httpd/conf
mv httpd.conf httpd.conf.bak1

yum -y install gcc gcc-c++ pcre pcre-devel zlib-devel

 cd /opt/httpd-2.4.29/
./configure \
--prefix=/usr/local/httpd \
--enable-so \
--enable-rewrite \
--enable-charset-lite \
--enable-cgi \
--enable-deflate \
--enable-expires            #加入mod_expires 模块

make && make install

Apache的配置与应用(优化)_第22张图片

3.配置 mod_expires 模块启用
vim /usr/local/httpd/conf/httpd.conf
--52行--修改
Listen 192.198.80.10:80
--111行--取消注释
LoadModule expires_module modules/mod_expires.so        #开启mod_expires 模块
--199行--取消注释,修改
ServerName www.kgc.com:80
--末行添加--

  ExpiresActive On                                #打开网页缓存功能
  ExpiresDefault "access plus 60 seconds"        #设置缓存60秒

 

 

 末行添加

 Apache的配置与应用(优化)_第23张图片

4.检查安装情况,启动服务
apachectl -t            #验证配置文件的配置是否正确
apachectl -t -D DUMP_MODULES | grep "expires"        #检查 mod_deflate 模块是否已安装
  deflate_module (shared)                            #已安装的正确结果

systemctl start httpd.service

Apache的配置与应用(优化)_第24张图片

 5.测试缓存是否生效
cat /usr/local/httpd/htdocs/index.html

 6、进入网站 F5进行刷新 再按F12进行查看

Apache的配置与应用(优化)_第25张图片 

 (3)Apache 防盗链

1.检查是否安装 mod_rewrite 模块
apachectl -t -D DUMP_MODULES | grep "rewrite"

2.如果没有安装mod_rewrite 模块,重新编译安装 Apache 添加 mod_rewrite模块
systemctl stop httpd.service
cd /usr/local/httpd/conf
mv httpd.conf httpd.conf.bak2

yum -y install gcc gcc-c++ pcre pcre-devel zlib-devel
cd /opt/httpd-2.4.29/
./configure \
--prefix=/usr/local/httpd \
--enable-so \
--enable-rewrite \					#加入mod_rewrite 模块
--enable-charset-lite \
--enable-cgi \
--enable-deflate \
--enable-expires

make && make install

3.配置 mod_rewrite 模块启用
vim /usr/local/httpd/conf/httpd.conf
--157行--取消注释
LoadModule rewrite_module modules/mod_rewrite.so
--224行--''




  Options Indexes FollowSymLinks
  AllowOverride None
  Require all granted

  RewriteEngine On 													#打开 rewrite 功能,加入 mode_rewrite 模块内容
  RewriteCond %{HTTP_REFERER} !^http://kgc.com/.*$ [NC]				#设置匹配规则
  RewriteCond %{HTTP_REFERER} !^http://kgc.com$ [NC]
  RewriteCond %{HTTP_REFERER} !^http://www.kgc.com/.*$ [NC]
  RewriteCond %{HTTP_REFERER} !^http://www.kgc.com/$ [NC]
  RewriteRule .*\.(gif|jpg|swf)$ http://www.kgc.com/error.png		#设置跳转动作

----------------------------------------------------------------------------------------------------------
RewriteCond %{HTTP_REFERER} !^http://www.kgc.com/.*$ [NC]  的字段含义:
“%{HTTP_REFERER}” :存放一个链接的 URL,表示从哪个链接访问所需的网页。
“!^” :表示不以后面的字符串开头。
“http://www.kgc.com” :是本网站的路径,按整个字符串匹配。
“.*$” :表示以任意字符结尾。
“[NC]” :表示不区分大小写字母。

RewriteRule .*\.(gif|jpg|swf)$ http://www.kgc.com/error.png  的字段含义:
“.” :表示匹配一个字符。
“*” :表示匹配 0 到多个字符,与“.”合起来的意思是匹配 0 到多次前面的任意字符,如果是 1 到多次匹配可以用“+”表示。
“\.” :在这里的“\”是转义符,“\.”就代表符号“.”的意思。因为“.”在指令中是属于规则字符,有相应的含义, 如果需要匹配,需要在前面加个转义符“\”,其它规则字符如果需要匹配,也做同样处理。
“(gif|jpg|swf)” :表示匹配“gif”、“jpg”、“swf”任意一个,“$”表示结束。最后的规则是以“.gif”、“.jpg”、“.swf”结尾, 前面是1到多个字符的字符串,也就是匹配图片类型的文件。
“http://www.kgc.com/error.png” :表示转发到这个路径 。

整个配置的含义是 使用本网站以外的网站域名 访问本站的图片文件时,显示 error.png 这个图片。
----------------------------------------------------------------------------------------------------------

4.网页准备
Web源主机配置:
cd /usr/local/httpd/htdocs
将game.jpg、error.png文件传到/usr/local/httpd/htdocs目录下
vim index.html

this is kgc.com!

echo "192.168.80.10 www.kgc.com" >> /etc/hosts echo "192.168.80.12 www.benet.com" >> /etc/hosts 盗链网站主机: cd /usr/local/httpd/htdocs #yum安装的httpd服务的默认路径为/var/www/html/ vim index.html

this is benet.com!

echo "192.168.80.10 www.kgc.com" >> /etc/hosts echo "192.168.80.12 www.benet.com" >> /etc/hosts 5.在盗图网站主机上进行浏览器验证 http://www.benet.com

你可能感兴趣的:(apache,服务器,tomcat)