Linux下部署Nginx
    DownloadUrl:http://nginx.org/en/download.html
    tar -zxvf nginx-1.13.1.tar.gz

    进入到nginx-1.13.1的目录,查看下面的文件

    发现nginx是通过源码包发布的,而nginx是c写的,因此需要安装c/c++的编译器

    yum install gcc

    安装nginx
    ./configure

    检测到最后,发现依赖的pcre library没有,下面我们来安装pcre

    https://ftp.pcre.org/pub/pcre/

    pcre 下载完毕之后也是要给tar.gz的文件,首先要对其进行解压

    tar -zxvf pcre-8.00.tar.gz

    解压完毕之后有如下文件,仍然是源码安装
    ./configure

    说我们g++ 找不到,我们来安装g++
    yum install gcc-c++

    回来继续安装pcre
    ./configure
    make install

    缺少zlib,我们需要再次安装zlib
    http://www.zlib.net/
    zlib同样是tar.gz来管理的,先解压

    发现zlib也是由源码包管理的,来安装zlib

    ./configure
    make install

    安装完毕,在来安装nginx

    ./configure
    make install

    这次终于安装成功。软件被安装到了

    /usr/local/nginx

    启动nginx

    ./usr/local/nginx/sbin/nginx

    访问nginx(ip地址为:192.168.100.100,端口号为:80)

    http://192.168.100.100:8080/

    nginx就安装成功了。

    停止nginx

    nginx -s stop

    重启nginx

    nginx -s reload

    nginx文件结构

    1. ... #全局块
    2. events { #events块
    3. ...
    4. }
    5. http #http块
    6. {
    7. ... #http全局块
    8. server #server块
    9. {
    10. ... #server全局块
    11. location [PATTERN] #location块
    12. {
    13. ...
    14. }
    15. location [PATTERN]
    16. {
    17. ...
    18. }
    19. }
    20. server
    21. {
    22. ...
    23. }
    24. ... #http全局块
    25. }

    1、全局块:配置影响nginx全局的指令。一般有运行nginx服务器的用户组,nginx进程pid存放路径,日志存放路径,配置文件引入,允许生成worker process数等。
    2、events块:配置影响nginx服务器或与用户的网络连接。有每个进程的最大连接数,选取哪种事件驱动模型处理连接请求,是否允许同时接受多个网路连接,开启多个网络连接序列化等。
    3、http块:可以嵌套多个server,配置代理,缓存,日志定义等绝大多数功能和第三方模块的配置。如文件引入,mime-type定义,日志自定义,是否使用sendfile传输文件,连接超时时间,单连接请求数等。
    4、server块:配置虚拟主机的相关参数,一个http中可以有多个server。
    5、location块:配置请求的路由,以及各种页面的处理情况。
    下面给大家上一个配置文件,作为理解,同时也配入我搭建的一台测试机中,给大家示例。

    1. ########### 每个指令必须有分号结束。#################
    2. #user administrator administrators; #配置用户或者组,默认为nobody nobody。
    3. #worker_processes 2; #允许生成的进程数,默认为1
    4. #pid /nginx/pid/nginx.pid; #指定nginx进程运行文件存放地址
    5. error_log log/error.log debug; #制定日志路径,级别。这个设置可以放入全局块,http块,server块,级别以此为:debug|info|notice|warn|error|crit|alert|emerg
    6. events {
    7. accept_mutex on; #设置网路连接序列化,防止惊群现象发生,默认为on
    8. multi_accept on; #设置一个进程是否同时接受多个网络连接,默认为off
    9. #use epoll; #事件驱动模型,select|poll|kqueue|epoll|resig|/dev/poll|eventport
    10. worker_connections 1024; #最大连接数,默认为512
    11. }
    12. http {
    13. include mime.types; #文件扩展名与文件类型映射表
    14. default_type application/octet-stream; #默认文件类型,默认为text/plain
    15. #access_log off; #取消服务日志
    16. log_format myFormat '$remote_addr–$remote_user [$time_local] $request $status $body_bytes_sent $http_referer $http_user_agent $http_x_forwarded_for'; #自定义格式
    17. access_log log/access.log myFormat; #combined为日志格式的默认值
    18. sendfile on; #允许sendfile方式传输文件,默认为off,可以在http块,server块,location块。
    19. sendfile_max_chunk 100k; #每个进程每次调用传输数量不能大于设定的值,默认为0,即不设上限。
    20. keepalive_timeout 65; #连接超时时间,默认为75s,可以在http,server,location块。
    21. upstream mysvr {
    22. server 127.0.0.1:7878;
    23. server 192.168.10.121:3333 backup; #热备
    24. }
    25. error_page 404 https://www.baidu.com; #错误页
    26. server {
    27. keepalive_requests 120; #单连接请求上限次数。
    28. listen 4545; #监听端口
    29. server_name 127.0.0.1; #监听地址
    30. location ~*^.+$ { #请求的url过滤,正则匹配,~为区分大小写,~*为不区分大小写。
    31. #root path; #根目录
    32. #index vv.txt; #设置默认页
    33. proxy_pass http://mysvr; #请求转向mysvr 定义的服务器列表
    34. deny 127.0.0.1; #拒绝的ip
    35. allow 172.18.5.54; #允许的ip
    36. }
    37. }
    38. }

    上面是nginx的基本配置,需要注意的有以下几点:
    1、1.$remote_addr 与$http_x_forwarded_for 用以记录客户端的ip地址; 2.$remote_user :用来记录客户端用户名称; 3.$time_local : 用来记录访问时间与时区;4.$request : 用来记录请求的url与http协议;
    5.$status : 用来记录请求状态;成功是200, 6.$body_bytes_s ent :记录发送给客户端文件主体内容大小;7.$http_referer :用来记录从那个页面链接访问过来的; 8.$http_user_agent :记录客户端浏览器的相关信息;
    2、惊群现象:一个网路连接到来,多个睡眠的进程被同事叫醒,但只有一个进程能获得链接,这样会影响系统性能。
    3、每个指令必须有分号结束。