apache如何设置缓存

基本介绍

 

    httpd是一个比较经典的web服务器,也就是静态资源服务器,主要用来服务于一些静态的文件,例如css,js,html等文件,所谓的静态文件,也就是不需要通过服务器进行运行的文件。

 

    在使用静态服务器的时候,大部分的图片或者js文件或者css文件的变化一般都是比较少的,从而我们可以设置缓存时间,从而实现用户访问的加速,从而提高用户体验

 

    由于httpd程序发展的时间过长,采用的是动态共享模块,从而在使用的时候,需要加载相关的模块来进行使用,在使用httpd进行缓存的时候,可以使用header模块或者是expires模块。

 

    在使用httpd的时候,生产环境一般使用的版本为2.2的版本,并且采用的mpm机制为worker模式,从而在进行编译的时候,指定worker模式。

 

 

编译httpd2.2

 

    在编译的时候,可能出现依赖包错误,从而首先需要安装相关的依赖包,pcre,zlib,openssl,arp,arp-util,第一个是perl的扩展正则表达式,第二个是提供压缩的,也就是gzip和deflate压缩,第三个和第四个主要是提供httpd的可移植的运行环境。

 

    当编译的时候,出现如下错误(不能使用外部的apr和apr-util,表示不能使用操作系统自带的rpm包,从而需要重新编译安装):

Configuring Apache Portable Runtime Utility library...

 

checking for APR-util... reconfig

configure: error: Cannot use an external APR with the bundled APR-util

 

    需要首先安装apr和apr-util,这两个包在httpd2.2的源码中是自带的,从而不需要专门下载,如下所示:

[root@mogilenode1 httpd-2.2.34]# cd srclib/

[root@mogilenode1 srclib]# cd apr

[root@mogilenode1 apr]# ./configure --prefix=/usr/local/apr2 (prefix表示安装路径)

[root@mogilenode1 apr]# make && make install

 

[root@mogilenode1 apr]# ls -l /usr/local/apr2/ (表示安装成功)

total 16

drwxr-xr-x 2 root root 4096 Sep  7 16:37 bin

drwxr-xr-x 2 root root 4096 Sep  7 16:37 build-1

drwxr-xr-x 3 root root 4096 Sep  7 16:37 include

drwxr-xr-x 3 root root 4096 Sep  7 16:37 lib

 

    安装apr-util如下:

 

[root@mogilenode1 srclib]# cd apr-util/

[root@mogilenode1 apr-util]# ./configure --prefix=/usr/local/apr-util2 --with-apr=/usr/local/apr2/ (apr-util依赖于apr,从而需要指定apr的安装路径)

[root@mogilenode1 apr-util]# make && make install

[root@mogilenode1 apr-util]# ls -l /usr/local/apr-util2/ (表示安装成功)

total 12

drwxr-xr-x 2 root root 4096 Sep  7 16:41 bin

drwxr-xr-x 3 root root 4096 Sep  7 16:41 include

drwxr-xr-x 4 root root 4096 Sep  7 16:41 lib

 

    进行安装httpd:

 

[root@mogilenode1 httpd-2.2.34]# ls -l include/ap_release.h (修改如下的内容,httpd的版本号,主要目的是为了防止根据相应的版本查找漏洞进行攻击

-rw-r--r-- 1 1001 1001 3074 Sep  7 08:08 include/ap_release.h

 40 #define AP_SERVER_BASEVENDOR "KEL"

 41 #define AP_SERVER_BASEPROJECT "KEL"

 42 #define AP_SERVER_BASEPRODUCT "KEL"

 43 

 44 #define AP_SERVER_MAJORVERSION_NUMBER 2

 45 #define AP_SERVER_MINORVERSION_NUMBER 2

 46 #define AP_SERVER_PATCHLEVEL_NUMBER   2

 47 #define AP_SERVER_DEVBUILD_BOOLEAN    0


    编译安装httpd:

[root@mogilenode1 httpd-2.2.34]# ./configure --prefix=/usr/local/apache2 --with-apr=/usr/local/apr2/ --with-apr-util=/usr/local/apr-util2/ --enable-ssl --enable-rewrite --enable-expires --enable-headers --enable-so --with-mpm=worker --enable-deflate(在其中prefix表示httpd的安装路径,然后是apr的路径和apr-util的路径,启用ssl,主要是可以使用https协议,开放443端口,启用重写功能,从而可以跳转,启用缓存控制,启用http头部信息,启用动态模块加载,指定mpm为worker模式,启用压缩功能)

[root@mogilenode1 httpd-2.2.34]# make && make install

[root@mogilenode1 bin]# /usr/local/apache2/bin/httpd (启动服务,表示apache安装成功)

httpd: Could not reliably determine the server's fully qualified domain name, using 192.168.249.236 for ServerName

[root@mogilenode1 bin]# ps -ef|grep httpd

root     29185     1  0 16:59 ?        00:00:00 /usr/local/apache2/bin/httpd

daemon   29186 29185  0 16:59 ?        00:00:00 /usr/local/apache2/bin/httpd

daemon   29187 29185  0 16:59 ?        00:00:00 /usr/local/apache2/bin/httpd

daemon   29188 29185  0 16:59 ?        00:00:00 /usr/local/apache2/bin/httpd

daemon   29189 29185  0 16:59 ?        00:00:00 /usr/local/apache2/bin/httpd

    

查看httpd的版本

 

    可以直接使用curl来进行查看httpd版本,如下所示:

 

    在其中使用了tengine的进行比较,可以看到在Tengine里面,不会显示服务器的具体版本信息,并且,在我们自己的编译之中,连openssl的版本都显示出来了,从而暴露了太多的信息,从而可以编辑配置文件,从而来隐藏版本,如下:

 

[root@mogilenode1 conf]# ls -l /usr/local/apache2/conf/httpd.conf (编辑httpd的主配置文件,在其中取消以下的注视,从而开启httpd长连接并且可以隐藏httpd版本)

-rw-r--r-- 1 root root 13913 Sep  7 17:06 /usr/local/apache2/conf/httpd.conf

 

413 # Various default settings

414 Include conf/extra/httpd-default.conf

 

[root@mogilenode1 conf]# ls -l /usr/local/apache2/conf/extra/httpd-default.conf 

-rw-r--r-- 1 root root 2344 Sep  7 16:56 /usr/local/apache2/conf/extra/httpd-default.conf

 55 ServerTokens Prod

 65 ServerSignature Off

    上面的两步,一个是为了加载httpd-default.conf配置文件,修改的55行修改为Prod,主要是在httpd的响应头中无法看到web服务器的版本信息,而65行,主要是当出现404等错误的时候,不会显示服务器的IP地址等信息。

    可以看到经过修改之后,响应的头部信息不会出现了服务器的具体信息,修改配置之后,需要重启httpd程序。

[root@mogilenode1 extra]# /usr/local/apache2/bin/httpd -k graceful (重新加载配置文件,不会中断httpd服务)

开启httpd缓存控制功能

 

    在没有开启缓存控制功能的时候,查看缓存控制策略如下所示:

    

    进行httpd的配置,使用expires模块,修改配置主配置文件httpd.conf,添加内容如下:

<IfModule mod_expires.c>

    ExpiresActive On

    ExpiresDefault "access plus 12 month"

    ExpiresByType text/html "access plus 3 month"

</IfModule>

    以上的表示,当存在缓存模块的时候,那么这段配置就会生效,第一行表示启用缓存控制,第二行表示默认情况下都缓存一年,第三行表示根据MIME格式进行划分,以上表示如果类型为html,那么就缓存三个月。再次查看头部信息如下:

 

    可以从上面看到已经设置了过期时间,而且是一年,也就是说使用的是默认设置,在http的头部信息Cache-Control和Expires字段中可以看到缓存的时间,在下面图中也可以看到缓存时间。

    

    使用headers来进行设置缓存控制时间,如下配置(表示在头部信息中直接添加一个首部控制信息):

<IfModule mod_headers.c>

    header set cache-control "max-age=36500"

</IfModule>


    查看结果如下:

 

 

   

使用缓存的优缺点

 

    在使用缓存的时候,优点就是主要是提高静态资源的访问速度,从而提高用户的性能,提高用户体验;减少在传输的时候占用的带宽,从而节省成本

 

    在使用缓存的时候,如果源文件的内容发生了改变,那么如何是好呢?一般的情况下可以使用修改文件的名称来更新缓存,另外也可以使用条件式请求首部,就是每次会向服务器发送一个请求,你修改了嘛?主要就是使用的etag这个扩展信息,每次进行比对。

 

    当你在进行测试的时候,你会发现,只要文件内容发生了改变,那么就会变成新的内容,为什么呢?。。。你猜!!!!

 

    最后抛出一个图,思索下,为啥!!!

 

 

公众号:

 

posted @ 2017-09-11 22:02  KEL  阅读(3338)  评论(0编辑  收藏  举报