Nginx
是一个高性能的HTTP和反向代理服务器,同时也是一个IMAP/POP3/SMTP代理服务器


web服务器常见的软件  

unix和linux平台(开源)  

  --Apache、Nginx、Lighttpd(python、shell、php等)  

  --Tmocat、IBM WebSphere、Jboss(专门服务与java)    

Windows平台    

  --微软公司的IIS(Internet Information Server)
useradd nginx(创建新的用户,如果不新建用户,

              有一个nobody用户,此用户用于开启服务时用,

              如果有人来***,即使被攻破,它也只能获得普通用户的权限,不会有太大的危险)
Nginx配置文件及目录

   --/usr/local/nginx/                     #安装目录

   --/usr/local/nginx/conf/nginx.conf        #主配置文件

   --/usr/local/nginx/html                 #网页目录

   --/usr/local/nginx/logs                 #日志文件

   --/usr/local/nginx/sbin/nginx            #启动脚本

   --/usr/local/nginx/sbin/nginx -s stop     #关闭服务

   --/usr/local/nginx/sbin/nginx -s reload   #重新加载

启动Nignx服务  

命令:sbin/nginx 选项 conf/nginx.conf   

常用选项:           

      -v:查看nginx版本          

     -V:查看编译参数         

      -t:测试默认配置文件       

      -c:指定配置文件

查看服务相关进程及端口信息:        

         命令:ps aux | grep nginx       

         命令:ps -elf | grep nginx      

         命令:netstat -autnp | grep nginx  
搭建Nginx服务器

在IP地址为192.168.4.5的主机上安装部署Nginx服务,并可以将Nginx服务器,要求编译时启用如下功能:
      SSL加密功能
      设置Nginx账户及组名称均为nginx
      Nginx服务器升级到更高版本。
然后客户端访问页面验证Nginx Web服务器:
      使用火狐浏览器访问
      使用curl访问
步骤
步骤一:构建Nginx服务器
1)使用源码包安装nginx软件包
[root@svr5 ~]# yum –y install gcc pcre-devel openssl-devel  //安装常见依赖包
[root@svr5 ~]# useradd –s /sbin/nologin nginx
[root@svr5 ~]# tar -xf nginx-1.8.0.tar.gz
[root@svr5 ~]# cd  nginx-1.8.0
[root@svr5 nginx-1.8.0]# ./configure   \
> --prefix=/usr/local/nginx   \                //指定安装路径
> --user=nginx   \                            //指定用户
> --group=nginx  \                            //指定组
> --with-http_ssl_module                        //开启SSL加密功能

[root@svr5 nginx-1.7.10]# make && make install    //编译并安装
2)nginx命令的用法
[root@svr5 ~]# /usr/local/nginx/sbin/nginx                    //启动服务
[root@svr5 ~]# /usr/local/nginx/sbin/nginx -s stop            //关闭服务
[root@svr5 ~]# /usr/local/nginx/sbin/nginx -s reload        //重新加载配置文件
[root@svr5 ~]# /usr/local/nginx/sbin/nginx –V                //查看软件信息
3)为Nginx Web服务器建立测试首页文件
[root@svr5 ~]#echo "welcome to nginx" >  /usr/local/nginx/html/index.html
步骤二:升级Nginx服务器
1)编译新版本nginx软件
[root@svr5 ~]# tar  -zxvf   nginx-1.9.0.tar.gz
[root@svr5 ~]# cd nginx-1.9.0
[root@svr5 nginx-1.9.0]# ./configure   \
> --prefix=/usr/local/nginx   \
> --user=nginx   \
> --group=nginx  \
> --with-http_ssl_module
[root@svr5 nginx-1.9.0]# make
2) 备份老的nginx主程序,并使用编译好的新版本nginx替换老版本
[root@svr5 nginx-1.9.0]# mv /usr/local/nginx/sbin/nginx  \
>/usr/local/nginx/sbin/nginxold
[root@svr5 nginx-1.9.0]# cp objs/nginx /usr/local/nginx/sbin/   //拷贝新版本
[root@svr5 nginx-1.9.0]# make upgrade                           //升级
[root@svr5 ~]# /usr/local/nginx/sbin/nginx –v                //查看版本
客户端访问测试
[root@client ~]# firefox http://192.168.4.5
[root@client ~]# curl http://192.168.4.


用户认证
调整Nginx服务端配置,实现以下目标:
    1,访问Web页面需要进行用户认证
    2,用户名为:tom,密码为:123456
步骤
步骤一:修改Nginx配置文件
1)修改/usr/local/nginx/conf/nginx.conf
[root@pc205 ~]# vim /usr/local/nginx/conf/nginx.conf
.. ..
server {
        listen       80;
        server_name  localhost;
        auth_basic "Input Password:";        //认证提示符
        auth_basic_user_file "/usr/local/nginx/pass";    //认证密码文件
        location / {
            root   html;
            index  index.html index.htm;
        }
  }
2)生成密码文件,创建用户及密码
使用htpasswd命令创建账户文件,需要确保系统中已经安装了httpd-tools
[root@svr5 ~]# yum -y install  httpd-tools
[root@svr5 ~]#htpasswd -cm /usr/local/nginx/pass tom        //创建密码文件
[root@svr5 ~]#htpasswd  -m /usr/local/nginx/pass jerry    //追加用户,不用-c
3)重启Nginx服务
[root@svr5 ~]# /usr/local/nginx/sbin/nginx –s reload        
//请先确保nginx是启动状态才可以执行命令成功,否则报错
步骤二:客户端测试
[root@client ~]# firefox http://192.168.4.5                 //输入密码后可以访问

基于域名的虚拟主机
配置基于域名的虚拟主机,实现以下目标:
1,实现两个基于域名的虚拟主机,域名分别为www.aa.com和www.bb.com
2,对域名为www.aa.com的站点进行用户认证,用户名称为tom,密码为123456
步骤
步骤一:修改配置文件
1)修改Nginx服务配置,添加相关虚拟主机配置如下
[root@svr5 ~]# vim /usr/local/nginx/conf/nginx.conf
.. ..
server {
       listen       80;                            //端口
       server_name  www.aa.com;                //域名
       auth_basic "Input Password:";               //认证提示符
       auth_basic_user_file "/usr/local/nginx/pass"; //认证密码文件
location / {
        root   html;                              //指定网站根路径
        index  index.html index.htm;
       }
}
… …
    server {
        listen  80;                                //端口
        server_name  www.bb.com;               //域名
location / {
       root   www;                             //指定网站根路径
       index  index.html index.htm;
}
}
2)创建账户及密码
[root@svr5 ~]# htpasswd –cm  /usr/local/nginx/pass  tom        //创建账户密码文件
3)创建网站根目录及对应首页文件
[root@svr5 ~]# mkdir /usr/local/nginx/www
[root@svr5 ~]# echo "www" > /usr/local/nginx/www/index.htm
4)重启nginx服务
[root@svr5 ~]# /usr/local/nginx/sbin/nginx –s reload


步骤二:客户端测试
1)修改客户端主机192.168.4.100的/etc/hosts文件,进行域名解析
[root@client ~]# vim /etc/hosts
192.168.4.5    www.aa.com www.bb.com
2)登录192.168.4.100客户端主机进行测试
注意:SSH –X远程连接调用虚拟机的firefox时,请先关闭真实机的firefox
[root@client ~]# firefox http://www.aa.com            //输入密码后可以访问
[root@client ~]# firefox http://www.bb.com            //直接访问


SSL虚拟主机
加密算法:
(1)对称加密
(2)非对称加密
(3)哈希值 md5sum +文件
配置基于加密网站的虚拟主机,实现以下目标:
1,域名为www.cc.com
2,该站点通过https访问
3,通过私钥、证书对该站点所有数据加密

源码安装Nginx时必须使用--with-http_ssl_module参数,
启用加密模块,对于需要进行SSL加密处理的站点添加ssl相关指令
(设置网站需要的私钥和证书)

步骤一:配置SSL虚拟主机
1)生成私钥与证书
[root@svr5 ~]# cd /usr/local/nginx/conf
[root@svr5 ~]# openssl genrsa -out cert.key(-out也可以为 > )           //生成私钥
[root@svr5 ~]# openssl req -new -x509 -key cert.key -out cert.pem      //生成证书
2)修改Nginx配置文件,设置加密网站的虚拟主机
[root@svr5 ~]# vim  /usr/local/nginx/conf/nginx.conf
… …    
server {
        listen       443 ssl;
        server_name  www.cc.com;
        ssl_certificate      cert.pem;
        ssl_certificate_key  cert.key;
        ssl_session_cache    shared:SSL:1m;
        ssl_session_timeout  5m;
        ssl_ciphers  HIGH:!aNULL:!MD5;
        ssl_prefer_server_ciphers  on;
        location / {
            root   html;
            index  index.html index.htm;
        }
    }
步骤二:客户端验证
1)修改客户端主机192.168.4.100的/etc/hosts文件,进行域名解析
[root@client ~]# vim /etc/hosts
192.168.4.5    www.cc.com  www.aa.com   www.bb.com
2)登录192.168.4.100客户端主机进行测试
[root@client ~]# firefox https://www.cc.com            //信任证书后可以访问

Nginx反向代理(调度器)
负载均衡;检查后台情况(web高可用);
ip_hash:相同客户端访问相同服务器;
使用Nginx实现Web反向代理功能,实现如下功能:
1,后端Web服务器两台,可以使用httpd实现
2,Nginx采用轮询的方式调用后端Web服务器
3,两台Web服务器的权重要求设置为不同的值
4,最大失败次数为1,失败超时时间为30秒
           weight:权重越高,请求量越多;        

           max_fails:最大失败次数;        

           fail_timeout:如果失败,10s内不访问此web(加down10s后不在询问);
步骤一:部署实施后端Web服务器
1)部署后端Web1服务器
[root@web1 ~]# yum  -y  install  httpd
[root@web1 ~]# echo "192.168.2.100" > /var/www/html/index.html
[root@web1 ~]# systemctl restart httpd
2)部署后端Web2服务器
[root@web2 ~]# yum  -y  install  httpd
[root@web2 ~]# echo "192.168.2.200" > /var/www/html/index.html
[root@web2 ~]# systemctl restart httpd
步骤二:配置Nginx服务器,添加服务器池,实现反向代理功能
1)修改/usr/local/nginx/conf/nginx.conf配置文件
[root@svr5 ~]# vim /usr/local/nginx/conf/nginx.conf
http {
.. ..
upstream web {       //该函数定义一个web集群
       server 192.168.2.100:80 weight=1 max_fails=2 fail_timeout=10;
       server 192.168.2.200:80 weight=2 max_fails=2 fail_timeout=10;
        }
.. ..
server {
        listen        80;
        server_name  www.t.com;

location / {
        proxy_pass http://web;      //调用集群
}
}
2)重启nginx服务
[root@svr5 ~]# /usr/local/nginx/sbin/nginx –s reload
3)使用浏览器访问代理服务器测试轮询效果
[root@client ~]# curl http://192.168.4.5    //使用该命令多次访问查看效果
4)设置相同客户端访问相同Web服务器
[root@svr5 ~]# vim /usr/local/nginx/conf/nginx.conf
http {
.. ..
upstream web {      
            ip_hash;
            server 192.168.2.100:80 weight=1 max_fails=2 fail_timeout=10;
            server 192.168.2.200:80 weight=2 max_fails=2 fail_timeout=10;
}
....
}

静态页面:请求一个页面,服务器直接执行 

动态页面:请求一个页面,服务器执行代码,返回 

实现动静分离:客户端发出请求给web server,
             FastCGI进行判断并选择连接到其中一个解释器,
             实现处理后返回结果,将输出和信息从同一连接返回到web server;
FastCGI :是一种常驻(long-live)型的CGI
将CGI解释器进程保持在内存中,进行维护与调度


制作LNMP动态页面

1,部署LNMP环境 所需软件:nginx、mariadb-server、mariadb、mariadb-devel、        

                          php、php-fpm、php-mysql

1)安装部署Nginx、mariadb、php、php-fpm

2)启动nginx、mariadb、fpm服务

3)测试LNMP是否工作正常

2,构建LNMP平台:
问题:

1)配置Fast-CGI支持PHP网页

2)创建PHP测试页面,测试使用PHP连接数据库的效果

方案:

1)创建并修改php-fpm配置文件,起服务

命令:vim /etc/php-fpm.d/www/conf

2)修改nginx配置文件并启动服务(去注释)

命令:vim /usr/local/nginx/conf/nginx.conf

location / {      

          root html;      

          index index.html index.htm;        

}

location ~ \.php$ {      #当用户访问php结尾的执行此程序 

      root html;     

      fastcgi_pass   127.0.0.1:9000; #把找到的页面给了9000(php-fpm IP与端口)

      fastcgi_index  index.php; 

#fastcgi_param SCRIPT_FILENAME  $document_root$fastcgi_script_name;     

      include fastcgi.conf;   

         }

命令:/usr/local/nginx/sbin/nginx -s reload

3),创建php测试页面1:

命令:vim /usr/local/nginx/html/test1.

php <?php

phpinfo();

?>
4)客户端使用浏览器访问服务器PHP首页文档
命令:firefox http://192.168.4.5/test1.ph
日志查看:tailf /usr/local/nginx/logs/error.log


地址重写

关于nginx服务器的地址重写,主要用到的配置参数是rewrite:

命令:rewrite 旧/正则/  新  [选项];

目标:

1)所有访问a.html的请求,重定向到b.html

2)所有访问192.168.4.5的请求重定向至www.tmooc.cn

3)所有访问192.168.4.5/下面子页面,重定向至www.tmooc.cn/下相同的页面

方案:

1)修改nginx配置文件(访问a.html重定向b.html)

命令:vim /usr/local/nginx/conf/nginx.conf

....server {            

           listen 80;            

           server_name localhost;

localtion / {             

          root html;             

          index index.html index.htm;             

          rewrite /a.html /b.html redirect;                 

}}                #加上该参数,地址栏会变为新的地址

2)重新加载配置文件:

命令:/usr/local/nginx/sbin/nginx  -s  reload

3)客户端测试:

命令:firefox http://192.168.4.5/a.html

4)修改配置文件(访问192.168.4.5的请求重定向至www.tmooc.cn)

命令:vim /usr/local/nginx/conf/nginx.conf

....server {          

           listen 80;          

           server_name localhost;          

           rewrite ^/ http://www.tmooc.cn/;

location / {           

          root html;          

          index index.html index.htm;             

}


5)重新加载配置文件:

命令:/usr/local/nginx/sbin/nginx  -s  reload

6)客户端测试: 

命令:firefox http://192.168.4.5

7)修改配置文件 (访问192.168.4.5/下面的子页面,重定向至www.tmooc.cn/下面的子页面)

命令:vim /usr/local/nginx/conf/nginx.conf

....... server {               

               listen 80;                

               server_name localhost;                

               rewrite ^/(.*) http://www.tmooc.cn/$1;

location / {            

               root html;             

               index index.html index.htm;

}

}

8)重新加载配置文件:

命令:/usr/local/nginx/sbin/nginx  -s  reload

9)客户端测试:

命令:firefox http://192.168.4.5 

10)修改配置文件:

(实现curl和火狐访问相同连接返回的页面不同,   

例:如果你是电脑,看到的页面就是宽屏幕;       

    如果你是手机,看到的页面就是窄屏幕;)
$http_user_agent 用户请求的包含用户的信息的变量

命令:vim /usr/local/nginx/conf/nginx.conf     

server{           

      listen 80;           

      server_name localhost;           

location / {                   

      root html;                         

      index index.html index.htm;

}                  

if ($http_user_agent ~* url ) {   ~正则匹配,*不区分大小写                            

     rewrite ^/(.*) /curl/$1 break;                           

}

}           

11)创建网页目录以及对应的页面文件:             

命令:echo "I am Normal page" > /usr/local/nginx/html/test.html             

命令:echo "I am is curl page" > /usr/local/nginx/html/curl/test.html              

伪装:curl -A firefox http://192.168.4.5/test.html   


旧地址,支持正则 

last      rewirte /a  /b  last;      不再读其他rewrite,匹配即停止;

break    rewrite /a  /b  break;     不再读其他语句,直接访问结束;

redirect                           让地址栏发生变化;(临时重定向)

permament                        让地址栏发生变化;(永久重定向)


Nginx常见问题处理

1,版本号的问题:(不显示版本号)    

命令:vim /usr/local/nginx/conf/nginx.conf         

http {                

    server_tokens off;     //不显示nginx版本号信息              

  .......                

}

2,并发量    

测试:(在proxy上)       

命令:ab -c 500 -n 500 http://192.168.4.5    OK!!!!       

命令:ab -c 1025 -n 1025 http://192.168.4.5 

      显示:too many open files   提示打开文件数量过多!!    

列出nginx正在运行的进程:ps aux | grep nginx    

方案:        

1),修改配置文件:           

命令:vim /usr/local/nginx/conf/nginx.conf                 

.....                

   worker_processes  1;    //与cpu核心数量相同                 

events {                

   worker_connections 65535;    //每个worker最大并发连接数

                  ......

}       

2),修改linux操作系统最大打开文件数;           

命令:ulimit -a            

命令:ulimit -Hn 100000    #硬限制,用户不可修改 n(最大文件数量)           

命令:ulimit -Sn 100000    #软限制,用户可以修改n(最大文件数量)  

验证:ss -ntup | grep nginx   #实时查看,可看到是谁在连接你           

命令:vim /etc/security/limits.conf  #永久生效   

3,头部信息过长:       

头部信息过长,会显示414(缓存不够!!!)        

网页没找到,会显示404       

命令:vim  /usr/local/nginx/conf/nginx.conf             

http {        

     server_tokens off;                    //不显示nginx版本号信息         

     client_header_buffer_size    1k;     //默认请求包头信息的缓存             

     large_client_header_buffers 4 4k; //大请求包头部信息的缓存个数与容量   

4,nginx压缩:(提升速度,节省流量)      

命令:vim /usr/local/nginx/conf/nginx.conf

http {      

     gzip on;                     #开启压缩(所有的浏览器都支持gzip解压)       

     gzip_min_length 1000;      #小文件不要压缩,最小1000字节;       

     gzip_comp_level 4;          #压缩的比例(1-9)       

     gzip_types text/plain         #对什么格式的文件压缩

....}

参考:/usr/local/nginx/conf/mime.types 将格式左边的写到gzip_types后
对mp4,mp3,jpg不能压缩,多媒体文件基本都是压缩格式

5,让用户的浏览器缓存数据;   

查看数据:about:cache     仅对多媒体文件要求用户缓存30天    

命令:vim /usr/local/nginx/conf/nginx.conf         

server {                

...          

location / {                 

          root html;                

          index index.html index.htm;

}          

location ~*\.(jpg|png|gif)$ {                 

          expires 30d;

}         

}

6,自定义默认报错页面     

命令:vim /usr/local/nginx/conf/nginx.conf          

error_page   404  /40x.html;      //自定义错误页面         

location = /40x.html {                      

                   root   html;      #出错返回首页       

   }              

charset utf-8;  #识别中文