美文网首页
Nginx编译

Nginx编译

作者: 北山学者 | 来源:发表于2018-05-02 22:54 被阅读0次

    一、常用编译选项说明

    nginx大部分常用模块,编译时./configure --help以--without开头的都默认安装。

    --prefix=PATH : 指定nginx的安装目录。默认 /usr/local/nginx
    --conf-path=PATH : 设置nginx.conf配置文件的路径。nginx允许使用不同的配置文件启动,通过命令行中的-c选项。默认为prefix/conf/nginx.conf
    --user=name: 设置nginx工作进程的用户。安装完成后,可以随时在nginx.conf配置文件更改user指令。默认的用户名是nobody。--group=name类似
    --with-pcre : 设置PCRE库的源码路径,如果已通过yum方式安装,使用--with-pcre自动找到库文件。使用--with-pcre=PATH时,需要从PCRE网站下载pcre库的源码(版本4.4 – 8.30)并解压,剩下的就交给Nginx的./configure和make来完成。perl正则表达式使用在location指令和 ngx_http_rewrite_module模块中。
    --with-zlib=PATH : 指定 zlib(版本1.1.3 – 1.2.5)的源码解压目录。在默认就启用的网络传输压缩模块ngx_http_gzip_module时需要使用zlib 。
    --with-http_ssl_module : 使用https协议模块。默认情况下,该模块没有被构建。前提是openssl与openssl-devel已安装
    --with-http_stub_status_module : 用来监控 Nginx 的当前状态
    --with-http_realip_module : 通过这个模块允许我们改变客户端请求头中客户端IP地址值(例如X-Real-IP 或 X-Forwarded-For),意义在于能够使得后台服务器记录原始客户端的IP地址
    --add-module=PATH : 添加第三方外部模块,如nginx-sticky-module-ng或缓存模块。每次添加新的模块都要重新编译(Tengine可以在新加入module时无需重新编译)

    编译示例:

    ./configure --prefix=/usr/local/nginx --sbin-path=/usr/local/nginx/sbin/nginx --conf-path=/usr/local/nginx/conf/nginx.conf --error-log-path=/var/log/nginx/error.log --http-log-path=/var/log/nginx/access.log --pid-path=/var/run/nginx/nginx.pid --lock-path=/var/lock/nginx.lock --user=nginx --group=nginx --with-http_ssl_module --with-http_stub_status_module --with-http_gzip_static_module --http-client-body-temp-path=/var/tmp/nginx/client/ --http-proxy-temp-path=/var/tmp/nginx/proxy/ --http-fastcgi-temp-path=/var/tmp/nginx/fcgi/ --http-uwsgi-temp-path=/var/tmp/nginx/uwsgi --http-scgi-temp-path=/var/tmp/nginx/scgi --with-pcre

    二、nginx四个主要目录

    1、conf:保存nginx所有的配置文件,其中nginx.conf是nginx服务器的最核心最主要的配置文件,其他的.conf则是用来配置nginx相关的功能的,例如fastcgi功能使用的是fastcgi.conf和fastcgi_params两个文件,配置文件一般都有个样板配置文件,是文件名.default结尾,使用的使用将其复制为并将default去掉即可。

    2、html目录中保存了nginx服务器的web文件,但是可以更改为其他目录保存web文件,另外还有一个50x的web文件是默认的错误页面提示页面。

    3、logs:用来保存nginx服务器的访问日志错误日志等日志,logs目录可以放在其他路径,比如/var/logs/nginx里面。

    4、sbin:保存nginx二进制启动脚本,可以接受不同的参数以实现不同的功能。

    三、nginx.conf配置文件说明

    Nginx配置文件主要分成四部分:main(全局设置)、server(主机设置)、upstream(上游服务器设置,主要为反向代理、负载均衡相关配置)和 location(URL匹配特定位置后的设置),每部分包含若干个指令。

    1、main部分设置的指令将影响其它所有部分的设置;
    2、server部分的指令主要用于指定虚拟主机域名、IP和端口;
    3、upstream的指令用于设置一系列的后端服务器,设置反向代理及后端服务器的负载均衡;
    4、location部分用于匹配网页位置(比如,根目录“/”,“/images”,等等)。

    location 模块正则匹配配置:

    在没有使用正则表达式的时候,nginx会先在server中的多个location选取匹配度最高的一个uri,uri是用户请求的字符串,即域名后面的web文件路径,然后使用该location模块中的正则url和字符串,如果匹配成功就结束搜索,并使用此location处理此请求。

    location 正则匹配的语法:

    =  #用于标准uri前,需要请求字串与uri完全匹配,如果匹配成功就停止向下匹配并立即处理请求。
    ~  #区分大小写
    ~*  #不区分大写
    !~  #区分大小写不匹配
    !~* #不区分大小写不匹配 
    ^  #匹配以什么开头
    $  #匹配以什么结尾
    \  #转义字符。可以转. * ?等
    *  #代表任意长度的任意字符
    
    -f和!-f #用来判断是否存在文件
    -d和!-d #用来判断是否存在目录
    -e和!-e #用来判断是否存在文件或目录
    -x和!-x #用来判断文件是否可执行
    

    他们之间的关系式:server继承main,location继承server;upstream既不会继承指令也不会被继承。它有自己的特殊指令,不需要在其他地方的应用。

    四、配置Nginx的负载均衡与分发策略

    Nginx 的 upstream目前支持的分配算法:
    1)、轮询 轮流处理请求(默认)
    每个请求按时间顺序逐一分配到不同的应用服务器,如果应用服务器down掉,自动剔除,剩下的继续轮询。

    2)、权重
    通过配置权重,指定轮询几率,权重和访问比率成正比,用于应用服务器性能不均的情况。

    3)、ip_哈希算法
    每个请求按访问ip的hash结果分配,这样每个访客固定访问一个应用服务器,可以解决session共享的问题。

    通过在upstream参数中添加的应用服务器IP后添加指定参数即可实现

    upstream tomcatserver1 {  
        server 192.168.72.49:8080 weight=3;  
        server 192.168.72.49:8081;  
        }   
      
     server {  
            listen       80;  
            server_name  8080.max.com;  
            #charset koi8-r;  
            #access_log  logs/host.access.log  main;  
            location / {  
                proxy_pass   http://tomcatserver1;  
                index  index.html index.htm;  
            }  
         }   
    

    通过以上配置,便可以实现,在访问8080.max.com这个网站时,由于配置了proxy_pass地址,所有请求都会先通过nginx反向代理服务器,在服务器将请求转发给目的主机时,读取upstream为 tomcatsever1的地址,读取分发策略,配置tomcat1权重为3,所以nginx会将大部分请求发送给49服务器上的tomcat1,也就是8080端口;较少部分给tomcat2来实现有条件的负载均衡,当然这个条件就是服务器1、2的硬件指数处理请求能力。

    参考

    1、Nginx 之一:编译安装nginx 1.8.1 及配置
    2、Nginx 之二: nginx.conf 配置及基本优化
    3、配置Nginx实现负载均衡
    4、Nginx反向代理以及负载均衡配置
    5、Nginx 服务器安装及配置文件详解
    6、nginx负载均衡简单配置
    7、Nginx负载均衡的详细配置及使用案例详解.

    相关文章

      网友评论

          本文标题:Nginx编译

          本文链接:https://www.haomeiwen.com/subject/rxlnlftx.html