设为首页 收藏本站
查看: 249|回复: 0

[经验分享] Apache2+Tomcat性能调整(三)

[复制链接]

尚未签到

发表于 2017-1-28 12:26:44 | 显示全部楼层 |阅读模式
  通过apache对页面进行压缩和页面缓存来提升性
  
网站的访问速度是由多个因素所共同决定的,这些因素例如应用程序的响应速度、网络带宽、服务器性能、与客户端之间的网络传输速度等等。其中最重要的一个因素是应用程序本身的响应速度,因此当你为网站性能所苦恼时,你第一个需要着手进行处理的便是尽可能的提升应用程序的执行速度,你可以使用缓存或者是优化代码的执行效率来提升应用程序的速度。
     但是,本文并不是介绍如何来提升应用程序的执行效率,在确保您的应用程序的性能已经达到足够好,同时服务器的性能也完全满足的情况下,不妨来试试网页压缩和页面缓存来进一步提升网页的浏览速度,而且非常重要的是,它完全不需要任何的成本,只不过是会让您的服务器CPU占用率稍微提升一两个百分点而已或者更少。
网页压缩是一项由 WEB 服务器和浏览器之间共同遵守的协议,也就是说 WEB 服务器和浏览器都必须支持该技术,所幸的是现在流行的浏览器都是支持的,包括 IE、FireFox、Opera 等;服务器有 Apache 和 IIS 等。双方的协商过程如下:
     首先浏览器请求某个 URL 地址,并在请求的头 (head) 中设置属性 accept-encoding 值为 gzip, deflate,表明浏览器支持 gzip 和 deflate 这两种压缩方式(事实上 deflate 也是使用 gzip 压缩协议,下面我们会介绍二者之间的区别); 
     WEB 服务器接收到请求后判断浏览器是否支持压缩,如果支持就传送压缩后的响应内容,否则传送不经过压缩的内容; 浏览器获取响应内容后,判断内容是否被压缩,如果是则解压缩,然后显示响应页面的内容。 
     在实际的应用中我们发现压缩的比率往往在 3 到 10 倍,也就是本来 50k 大小的页面,采用压缩后实际传输的内容大小只有 5 至 15k 大小,这可以大大节省服务器的网络带宽,同时如果应用程序的响应足够快时,网站的速度瓶颈就转到了网络的传输速度上,因此内容压缩后就可以大大的提升页面的浏览速度。
    页面缓存是将一部分经常不会改变和变动的文件或页面缓存,下次浏览器再次访问这些页面时,而不需要再次去调用这些和下载这次页面的文件或页面,而提高了用户的访问速度。
    现在言归正传来谈谈如何使用Apache来对页面进行压缩和页面缓存来提升性能.为了实现这些功能需要三个模块mod_deflate、mod_expires和mod_headers,关于这三个模块的介绍请参考apache文档,这里不再阐述。
要实现这些东西的配置先在httpd.conf文件下找到下面三个地方

  • #LoadModule deflate_module modules/mod_deflate.so      
  • #LoadModule expires_module modules/mod_expires.so      
  • #LoadModule headers_module modules/mod_headers.so  

同时去掉前面的“#”,这些模块功能已经开启了,下面我们在配置GZIP和Expires了。配置GZIP和Expires也很容易,我们只需要在httpd.conf 配置文件中启用并进行相关的配置即可,配置如下:
 
<IfModule mod_expires.c>       
ExpiresActive on      
ExpiresDefault "now plus 1 day"     
ExpiresByType image/x-icon "access plus 10 year"     
ExpiresByType image/gif "access plus 1 month"     
ExpiresByType image/jpeg "access plus 1 month"     
ExpiresByType text/css "now plus 1 month"     
ExpiresByType text/javascript "now plus 1 month"     
ExpiresByType application/x-javascript "now plus 1 month"     
ExpiresByType text/html "now plus 5 minutes"     
ExpiresByType text/plain "now plus 1 month"     
ExpiresByType image/js "access plus 1 month"     
ExpiresByType application/x-shockwave-flash "access plus 1 week"     
<FilesMatch "\.(gif|jpe?g|png)$">      
    Header set Cache-Control "max-age=604800"     
    Header unset ETag      
</FilesMatch>      
</IfModule>      
FileETag none      
<ifmodule mod_deflate.c>      
DeflateCompressionLevel 9     
AddOutputFilterByType DEFLATE text/html text/plain text/xml application/x-httpd-jsp      
AddOutputFilter DEFLATE js css      
</ifmodule>      
<Location "/">      
SetOutputFilter DEFLATE      
BrowserMatch ^Mozilla/4 gzip-only-text/html      
BrowserMatch ^Mozilla/4\.0[678] no-gzip      
BrowserMatch \bMSIE !no-gzip !gzip-only-text/html      
SetEnvIfNoCase Request_URI \.(?:gif|jpe?g|png)$ no-gzip dont-vary      
Header append Vary User-Agent env=!dont-vary      
</Location>    
   
通过上述配置你就成功通过apache对页面进行压缩和页面缓存来提升性能。
其他相关参考页面:
http://lamp.linux.gov.cn/Apache/ApacheMenu/mod/core.html
http://blog.csdn.net/joliny/archive/2008/02/27/2124344.aspx
http://1229363.blog.163.com/blog/static/19743427200772372018878/

运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-334490-1-1.html 上篇帖子: Tomcat JVM优化一例 下篇帖子: jconsole监控tomcat 配置
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表