nginx安装配置|nginx负载均衡|nginx反向代理|gzip压缩|expires缓存

Nginx是一款轻量级的Web 服务器/反向代理服务器及电子邮件(IMAP/POP3)代理服务器,并在一个BSD-like 协议下发行。由俄罗斯的程序设计师Igor Sysoev所开发,供俄国大型的入口网站及搜索引擎Rambler(俄文:Рамблер)使用。其特点是占有内存少,并发能力强,事实上nginx的并发能力确实在同类型的网页服务器中表现较好

模块依赖性

gzip模块需要 zlib 库
rewrite模块需要 pcre 库
ssl 功能需要openssl库

安装PCRE库

wget ftp://ftp.csx.cam.ac.uk/pub/software/programming/pcre/pcre-8.35.tar.gz 
tar -zxvf pcre-8.35.tar.gz
cd pcre-8.35
./configure
make && make install

安装zlib库

wget http://zlib.net/zlib-1.2.8.tar.gz
tar -zxvf zlib-1.2.8.tar.gz
cd zlib-1.2.8
./configure
make && make install

安装ssl

自由选择是否需要编译

wget http://www.openssl.org/source/openssl-1.0.1g.tar.gz
tar -zxf openssl-1.0.1g.tar.gz
cd openssl-1.0.1g
./config
make && make install

安装nginx

cd nginx
./configure --prefix=/usr/local/nginx
make & make install

启动nginx

cd/usr/local/nginx
./sbin/nginx

配置nginx开机自动启动

打开/etc/rc.d/rc.local文件添加nginx文件路径

/usr/local/nginx/sbin/nginx

重启nginx

./sbin/nginx -s reload

查看访问日志

tail -10 logs/haowan.access.log

nginx设置定时分割日志文件

#!/bin/bash
LOGPATH=/usr/local/nginx/logs/haowan.access.log  // nginx日志原路径
BASEPATH=/date/$(date -d yesterday +%Y%m)  //切割后存放目录
mkdir -p $BASEPATH  //按月创建文件夹
bak=$BASEPATH/$(date -d yesterday +%d%H%M).haowan.access.log  //计算路径与日志命名
mv $LOGPATH $bak
touch $LOGPATH
kill -USR1 `cat /usr/local/nginx/logs/nginx.pid`
添加cut_logs.sh执行权限

chmod +x /usr/local/nginx/date/cut_logs.sh
设置cut_logs.sh启动时间,执行命令crontab -e进入编辑状态:

01 00 * * * /usr/local/nginx/date/runlog.sh
可以用以下方式来执行此脚本:

/etc/init.d/nginx start
 /etc/init.d/nginx stop
 /etc/init.d/nginx reload
 /etc/init.d/nginx restart

nginx rewrite重写

nginx通过ngx_http_rewrite_module模块支持url重写、支持if条件判断,但不支持else。该模块需要PCRE支持,应在编译nginx时指定PCRE源码目录

判断浏览器类型

 if ($http_user_agent ~* Mozilla){
        rewrite ^.*$ /ie.html;
        break;
      }
    # 404错误页面
    if (!-e $document_root$fastcgi_script_name){
        rewrite ^.*$ /404.html;
        break;
    }
    if ($http_user_agent ~* Mozilla){
        set $isit 1;
    }
    if ($fastcgi_script_name  ie.html){
        set $isie 0;
    }
    if($isie 1){
       rewrite ^.*$ /ie.html
    }

php与nginx整合

注意:编译的php要有如下功能:连接mysql,gd,ttf, 以fpm(fascgi)方式运行。

./configure \
   --prefix=/usr/local/fastphp\
   --with-mysql=/usr/local/mysql\
   --with-gd\
   --enable-gd-native-ttf\
   --enable-gd-jis-conv\
   --enable-fpm
  make && make install
复制php配置文件

cp php.ini-development /usr/local/fastphp/lib/php.ini
复制 php-fpm配置文件

cp etc/php-fpm.conf.default  etc/php-fpm.conf
启动php-fpm

./sbin/php-fpm

查看进程

ps aux | grep php

设置nginx.conf文件

php与nginx整合

location ~ \.php$ {
    root           html;
    fastcgi_pass   127.0.0.1:9000;
    fastcgi_index  index.php;
    fastcgi_param  SCRIPT_FILENAME  /usr/local/nginx/html/$fastcgi_script_name;
    include        fastcgi_params;
}

nginx gzip压缩提升网站速度

网页压缩是一项由 WEB 服务器和浏览器之间共同遵守的协议,也就是说 WEB 服务器和浏览器都必须支持该技术,所幸的是现在流行的浏览器都是支持的,包括 IE、FireFox、Opera 等;服务器有 Apache 和 IIS 等。双方的协商过程如下:首先浏览器请求某个 URL 地址,并在请求的头 (head) 中设置属性 accept-encoding 值为 gzip, deflate,表明浏览器支持 gzip 和 deflate 这两种压缩方式(事实上 deflate 也是使用 gzip 压缩协议。

gzip常用参数:

gzip on|off  #是否开启gzip
gzip_buffers 32 4k|16 8k  #缓冲
gzip_comp_level[1-9]  #推荐6压缩级别
gzip_disable  #正则匹配UA 什么样的Uri不进行gzip
gzip_min_length 200  #开始压缩的最小长度(再小就不要压缩了)
gzip_http_version1.0|1.1  #开始压缩的http协议版本
gzip_proxied  #设置请求代理服务器该如何缓存内容
gzip_types text/plain application/xml  #对哪些类型的文件用压缩如:text/xml/html/css
gzip_vary on|off  #是否传输gzip压缩标志
nginx gzip压缩设置

gzip on;
gzip_buffers 32 4k;
gzip_comp_level 6;
gzip_min_length 2000;
gzip_types text/css text/xml application/x-javascript;
nginx的expires缓存设置提高网站性能

Nginx设置expires设定页面缓存时间 不缓存或一直使用缓存 配置expires expires起到控制页面缓存的作用,合理的配置expires可以减少很多服务器的请求

 location ~* \.(jpg|jpeg|gif|png){
  root html;
  expires 1d;  # 缓存一天
 }

反向代理实现 nginx+apache动静分离

nginx反向代理的指令不需要新增额外的模块,默认自带proxy_pass指令,只需要修改配置文件就可以实现反向代理。支持两个用法 proxy与upstream,分别用来做反向代理和负载均衡

 #配置apache虚拟主机 
    <VirtualHost *:8080>
        ServerAdmin webmaster@dummy-host2.example.com
        DocumentRoot "/usr/local/nginx/html"
        ServerName "192.168.80.22"
        ErrorLog "logs/dummy-host2.example.com-error_log"
        CustomLog "logs/dummy-host2.example.com-access_log" common
    </VirtualHost>
#设置权限
 <Directory />
   Options FollowSymLinks
   AllowOverride None
   Order deny,allow
   Allow from all
 </Directory>
设置nginx配置文件 .php文件让apache来解析

 location ~ \.php$ {
    proxy_set_header X-Forwarded-For $remote_addr;
    proxy_pass   http://192.168.80.22:8080;
      
 }

nginx负载均衡配置

*nginx负载均衡主要是对七层网络通信模型中的第七层应用层上的http、https进行支持。同时nginx更新版本也在逐步对Websocket、SPDY等协议作出支持。
nginx是以反向代理的方式进行负载均衡的。反向代理(Reverse Proxy)方式是指以代理服务器来接受Internet上的连接请求,然后将请求转发给内部网络上的服务器,并将从服务器上得到的结果返回给Internet上请求连接的客户端,此时代理服务器对外就表现为一个服务器。*

配置两台虚拟机

  server{
     listen 81;
     server_name 127.0.0.1;
     root html;
     access_log logs/81-access.log main;
   }
   server{
       listen 82;
       server_name 127.0.0.1;
       root html;
       access_log logs/82-access.log main;
   }

把多台服务器用upstream指定绑定在一起并起个组名

upstream imgserver{
  server 127.0.0.1:81 weight=1 max_fails=2 fail_timeout=3;
  server 127.0.0.1:82 weight=1 max_fails=2 fail_timeout=3;
 }

然后用proxy_pass 指向imgserver

 location ~* \.(jpg|jpeg|gif|png){
    proxy_set_header X-Forwarded-For $remote_addr;
    proxy_pass http://imgserver;
 }
    原文作者:GalvinKang
    原文地址: https://segmentfault.com/a/1190000011489789
    本文转自网络文章,转载此文章仅为分享知识,如有侵权,请联系博主进行删除。
点赞