高性能WEB开发应用指南之一(高性能WEB开发之HTTP服务器)

                                                   

                        高性能WEB开发应用指南

本专题围绕如何高性能Web开发,从多个方面、多个角度进行了全面的阐述,涵盖了Web站点性能优化的几乎所有内容,包括数据的网络传输、服务器并发处理能力、动态网页缓存、动态网页静态化、应用层数据缓存、分布式缓存、Web服务器缓存、反向代理缓存、脚本解释速度、页面组件分离、浏览器本地缓存、浏览器并发请求、文件的分发、数据库I/O优化、数据库访问、数据库分布式设计、负载均衡、分布式文件系统、性能监控等。在这些内容中充分抓住本质并结合实践,通过通俗易懂的文字和生动有趣的配图,让读者充分并深入理解高性能架构的真相。

                                                     高性能WEB开发之HTTP服务器

第一篇:HTTP服务器

因tomcat处理静态资源的速度比较慢,所以首先想到的就是把所有静态资源(JS,CSS,image,swf)

提到单独的服务器,用更加快速的HTTP服务器,这里选择了nginx了,nginx相比apache,更加轻量级,

配置更加简单,而且nginx不仅仅是高性能的HTTP服务器,还是高性能的反向代理服务器。

目前很多大型网站都使用了nginx,新浪、网易、QQ等都使用了nginx,说明nginx的稳定性和性能还是非常不错的。

1. nginx 安装(linux)

http://nginx.org/en/download.html 下载最新稳定版本

根据自己需要的功能先下载对应模板,这里下载了下面几个模块:

openssl-0.9.8l,zlib-1.2.3,pcre-8.00

编译安装nginx:

 
   
  1. ./configure
  2. --without-http_rewrite_module
  3. --with-http_ssl_module
  4. --with-openssl=http://www.cnblogs.com/lib/openssl-0.9.8l
  5. --with-zlib=http://www.cnblogs.com/lib/zlib-1.2.3
  6. --with-pcre=http://www.cnblogs.com/lib/pcre-8.00
  7. --prefix=/usr/local/nginx
  8. make
  9. make install

2、nginx处理静态资源的配置

 
   
  1. #启动GZIP压缩CSS和JS
  2. gzip on;
  3. # 压缩级别 1-9,默认是1,级别越高压缩率越大,当然压缩时间也就越长
  4. gzip_comp_level 4;
  5. # 压缩类型
  6. gzip_types text/css application/x-javascript;
  7. # 定义静态资源访问的服务,对应的域名:res.abc.com
  8. server {
  9. listen 80;
  10. server_name res.abc.com;
  11. # 开启服务器读取文件的缓存,
  12. open_file_cache max=200 inactive=2h;
  13. open_file_cache_valid 3h;
  14. open_file_cache_errors off;
  15. charset utf-8;
  16. # 判断如果是图片或swf,客户端缓存5天
  17. location ~* ^.+.(ico|gif|bmp|jpg|jpeg|png|swf)$ {
  18. root /usr/local/resource/;
  19. access_log off;
  20. index index.html index.htm;
  21. expires 5d;
  22. }
  23. # 因JS,CSS改动比较频繁,客户端缓存8小时
  24. location ~* ^.+.(js|css)$ {
  25. root /usr/local/resource/;
  26. access_log off;
  27. index index.html index.htm;
  28. expires 8h;
  29. }
  30. # 其他静态资源
  31. location / {
  32. root /usr/local/resource;
  33. access_log off;
  34. expires 8h;
  35. }
  36. }

3、nginx 反向代理设置

 
   
  1. # 反向代理服务,绑定域名www.abc.com
  2. server {
  3. listen 80;
  4. server_name www.abc.com;
  5. charset utf-8;
  6. # BBS使用Discuz!
  7. # 因反向代理为了提高性能,一部分http头部信息不会转发给后台的服务器,
  8. # 使用proxy_pass_header 和 proxy_set_header 把有需要的http头部信息转发给后台服务器
  9. location ^~ /bbs/ {
  10. root html;
  11. access_log off;
  12. index index.php;
  13. # 转发host的信息,如果不设置host,在后台使用request.getServerName()取到的域名不是www.abc.com,而是127.0.0.1
  14. proxy_set_header Host $host;
  15. # 因Discuz! 为了安全,需要获取客户端User-Agent来判断每次POST数据是否跟第一次请求来自同1个浏览器,
  16. # 如果不转发User-Agent,Discuz! 提交数据就会报"您的请求来路不正确,无法提交"的错误
  17. proxy_pass_header User-Agent;
  18. proxy_pass http://127.0.0.1:8081;
  19. }
  20. # 其他请求转发给tomcat
  21. location / {
  22. root html;
  23. access_log off;
  24. index index.jsp;
  25. proxy_pass http://127.0.0.1:8080;
  26. }
  27. error_page 500 502 503 504 /50x.html;
  28. location = /50x.html {
  29. root html;
  30. }
  31. }

nginx详细配置参考:http://wiki.nginx.org/

PS:如果安装提示GCC not found,运行下面命令安装就可以(apt-get install build-essential),仅限debian

你可能感兴趣的:(HTTP服务器)