Nginx 安装配置_runoob菜鸟教程


Nginx 安装配置

Nginx("engine x")是一款是由俄罗斯的程序设计师Igor Sysoev所开发高性能的 Web和 反向代理 服务器,也是一个 IMAP/POP3/SMTP 代理服务器。

在高连接并发的情况下,Nginx是Apache服务器不错的替代品。

Nginx 安装

系统平台:CentOS release 6.6 (Final) 64位。

一、安装编译工具及库文件

  1. yum -y install make zlib zlib-devel gcc-c++ libtool  openssl openssl-devel

二、首先要安装 PCRE

PCRE 作用是让 Nginx 支持 Rewrite 功能。

1、下载 PCRE 安装包,下载地址: http://downloads.sourceforge.net/project/pcre/pcre/8.35/pcre-8.35.tar.gz

  1. [root@bogon src]# cd /usr/local/src/
  2. [root@bogon src]# wget http://downloads.sourceforge.net/project/pcre/pcre/8.35/pcre-8.35.tar.gz

2、解压安装包:

  1. [root@bogon src]# tar zxvf pcre-8.35.tar.gz

3、进入安装包目录

  1. [root@bogon src]# cd pcre-8.35

4、编译安装

  1. [root@bogon pcre-8.35]# ./configure
  2. [root@bogon pcre-8.35]# make && make install

5、查看pcre版本

  1. [root@bogon pcre-8.35]# pcre-config --version
  1.  

安装 Nginx

1、下载 Nginx,下载地址:http://nginx.org/download/nginx-1.6.2.tar.gz

  1. [root@bogon src]# cd /usr/local/src/
  2. [root@bogon src]# wget http://nginx.org/download/nginx-1.6.2.tar.gz

2、解压安装包

  1. [root@bogon src]# tar zxvf nginx-1.6.2.tar.gz

3、进入安装包目录

  1. [root@bogon src]# cd nginx-1.6.2

4、编译安装

  1. [root@bogon nginx-1.6.2]# ./configure --prefix=/usr/local/webserver/nginx --with-http_stub_status_module --with-http_ssl_module --with-pcre=/usr/local/src/pcre-8.35
  2. [root@bogon nginx-1.6.2]# make
  3. [root@bogon nginx-1.6.2]# make install

5、查看nginx版本

  1. [root@bogon nginx-1.6.2]# /usr/local/webserver/nginx/sbin/nginx -v

到此,nginx安装完成。

Nginx 配置

创建 Nginx 运行使用的用户 www:

  1. [root@bogon conf]# /usr/sbin/groupadd www 
  2. [root@bogon conf]# /usr/sbin/useradd -g www www

配置nginx.conf ,将/usr/local/webserver/nginx/conf/nginx.conf替换为以下内容

  1. [root@bogon conf]# cat /usr/local/webserver/nginx/conf/nginx.conf
  2.  
  3. user www www;
  4. worker_processes 2; #设置值和CPU核心数一致
  5. error_log /usr/local/webserver/nginx/logs/nginx_error.log crit; #日志位置和日志级别
  6. pid /usr/local/webserver/nginx/nginx.pid;
  7. #Specifies the value for maximum file descriptors that can be opened by this process.
  8. worker_rlimit_nofile 65535;
  9. events
  10. {
  11. use epoll;
  12. worker_connections 65535;
  13. }
  14. http
  15. {
  16. include mime.types;
  17. default_type application/octet-stream;
  18. log_format main '$remote_addr - $remote_user [$time_local] "$request" '
  19. '$status $body_bytes_sent "$http_referer" '
  20. '"$http_user_agent" $http_x_forwarded_for';
  21.  
  22. #charset gb2312;
  23.  
  24. server_names_hash_bucket_size 128;
  25. client_header_buffer_size 32k;
  26. large_client_header_buffers 4 32k;
  27. client_max_body_size 8m;
  28.  
  29. sendfile on;
  30. tcp_nopush on;
  31. keepalive_timeout 60;
  32. tcp_nodelay on;
  33. fastcgi_connect_timeout 300;
  34. fastcgi_send_timeout 300;
  35. fastcgi_read_timeout 300;
  36. fastcgi_buffer_size 64k;
  37. fastcgi_buffers 4 64k;
  38. fastcgi_busy_buffers_size 128k;
  39. fastcgi_temp_file_write_size 128k;
  40. gzip on;
  41. gzip_min_length 1k;
  42. gzip_buffers 4 16k;
  43. gzip_http_version 1.0;
  44. gzip_comp_level 2;
  45. gzip_types text/plain application/x-javascript text/css application/xml;
  46. gzip_vary on;
  47.  
  48. #limit_zone crawler $binary_remote_addr 10m;
  49. #下面是server虚拟主机的配置
  50. server
  51. {
  52. listen 80;#监听端口
  53. server_name localhost;#域名
  54. index index.html index.htm index.php;
  55. root /usr/local/webserver/nginx/html;#站点目录
  56. location ~ .*\.(php|php5)?$
  57. {
  58. #fastcgi_pass unix:/tmp/php-cgi.sock;
  59. fastcgi_pass 127.0.0.1:9000;
  60. fastcgi_index index.php;
  61. include fastcgi.conf;
  62. }
  63. location ~ .*\.(gif|jpg|jpeg|png|bmp|swf|ico)$
  64. {
  65. expires 30d;
  66. # access_log off;
  67. }
  68. location ~ .*\.(js|css)?$
  69. {
  70. expires 15d;
  71. # access_log off;
  72. }
  73. access_log off;
  74. }
  75.  
  76. }

  

检查配置文件nginx.conf的正确性命令:

  1. [root@bogon conf]# /usr/local/webserver/nginx/sbin/nginx -t

启动 Nginx

Nginx 启动命令如下:

  1. [root@bogon conf]# /usr/local/webserver/nginx/sbin/nginx


访问站点

从浏览器访问我们配置的站点ip:


Nginx 其他命令

以下包含了 Nginx 常用的几个命令:

  1. /usr/local/webserver/nginx/sbin/nginx -s reload # 重新载入配置文件
  2. /usr/local/webserver/nginx/sbin/nginx -s reopen # 重启 Nginx
  3. /usr/local/webserver/nginx/sbin/nginx -s stop # 停止 Nginx

worker_processes 这个参数最好是设置成 auto 自动匹配进程数。

语法:

  1. worker_processes number | auto;

auto 在 nginx 1.3.8 和 1.2.5 之后的版本开始支持。

默认:

  1. worker_processes 1;

proxy_next_upstream 这个参数默认的是超时跟错误都会重发,对于一些请求时间过长的连接,最好只设置成错误重发,不然的话会造成二重数据。


nginx 启动时提示错误:

  1. # /usr/local/nginx/sbin/nginx -t
  2. /usr/local/nginx/sbin/nginx: error while loading shared libraries: libpcre.so.1: cannot open shared object file: No such file or directory

解决方法:

64 位系统:

  1. ln -s /usr/local/lib/libpcre.so.1 /lib64

32 位系统:

  1. ln -s /usr/local/lib/libpcre.so.1 /lib

/usr/local/lib/libpcre.so.1 为 prce 安装后的文件地址。

低版本 prce 对应的 libpcre.so.1 为 libpcre.so.0。


关于 uri 的截取

location 中的 root 和 alias

  • root 指令只是将搜索的根设置为 root 设定的目录,即不会截断 uri,而是使用原始 uri 跳转该目录下查找文件
  • aias 指令则会截断匹配的 uri,然后使用 alias 设定的路径加上剩余的 uri 作为子路径进行查找

示例 1:root

  1. #------------目录结构----------
  2. /www/x1/index.html
  3. /www/x2/index.html
  4.  
  5. #--------配置-----------------------
  6. index index.html index.php;
  7. location /x/ {
  8. root "/www/";
  9. }
  10.  
  11. #-------访问--------------
  12. curl http://localhost/x1/index.html
  13. curl http://localhost/x2/index.html

示例 2:alias

  1. #----------配置-----------------
  2. location /y/z/ {
  3. alias /www/x1/;
  4. }
  5.  
  6. #---------访问--------------
  7. curl http://localhost/y/z/index.html

location 中的 proxy_pass 的 uri

如果 proxy_pass 的 url 不带 uri

如果尾部是"/",则会截断匹配的uri

如果尾部不是"/",则不会截断匹配的uri

如果proxy_pass的url带uri,则会截断匹配的uri

示例:

  1. #-------servers配置--------------------
  2. location / {
  3. echo $uri    #回显请求的uri
  4. }
  5.  
  6. #--------proxy_pass配置---------------------
  7. location /t1/ { proxy_pass http://servers; }    #正常,不截断
  8. location /t2/ { proxy_pass http://servers/; }    #正常,截断
  9. location /t3 { proxy_pass http://servers; }    #正常,不截断
  10. location /t4 { proxy_pass http://servers/; }    #正常,截断
  11. location /t5/ { proxy_pass http://servers/test/; }    #正常,截断
  12. location /t6/ { proxy_pass http://servers/test; }    #缺"/",截断
  13. location /t7 { proxy_pass http://servers/test/; }    #含"//",截断
  14. location /t8 { proxy_pass http://servers/test; }    #正常,截断
  15. #---------访问----------------------
  16. for i in $(seq 6)
  17. do
  18. url=http://localhost/t$i/doc/index.html
  19. echo "-----------$url-----------"
  20. curl url
  21. done
  22.  
  23. #--------结果---------------------------
  24. ----------http://localhost:8080/t1/doc/index.html------------
  25. /t1/doc/index.html
  26.  
  27. ----------http://localhost:8080/t2/doc/index.html------------
  28. /doc/index.html
  29.  
  30. ----------http://localhost:8080/t3/doc/index.html------------
  31. /t3/doc/index.html
  32.  
  33. ----------http://localhost:8080/t4/doc/index.html------------
  34. /doc/index.html
  35.  
  36. ----------http://localhost:8080/t5/doc/index.html------------
  37. /test/doc/index.html
  38.  
  39. ----------http://localhost:8080/t6/doc/index.html------------
  40. /testdoc/index.html
  41.  
  42. ----------http://localhost:8080/t7/doc/index.html------------
  43. /test//doc/index.html
  44.  
  45. ----------http://localhost:8080/t8/doc/index.html------------
  46. /test/doc/index.html
  47.  

Nginx 配置文件结构

默认的 nginx 配置文件 nginx.conf 内容如下:

  1. #user nobody;
  2. worker_processes 1;
  3.  
  4. #error_log logs/error.log;
  5. #error_log logs/error.log notice;
  6. #error_log logs/error.log info;
  7.  
  8. #pid logs/nginx.pid;
  9.  
  10. events {
  11. worker_connections 1024;
  12. }
  13.  
  14. http {
  15. include mime.types;
  16. default_type application/octet-stream;
  17.  
  18. #log_format main '$remote_addr - $remote_user [$time_local] "$request" '
  19. # '$status $body_bytes_sent "$http_referer" '
  20. # '"$http_user_agent" "$http_x_forwarded_for"';
  21.  
  22. #access_log logs/access.log main;
  23.  
  24. sendfile on;
  25. #tcp_nopush on;
  26.  
  27. #keepalive_timeout 0;
  28. keepalive_timeout 65;
  29.  
  30. #gzip on;
  31.  
  32. server {
  33. listen 80;
  34. server_name localhost;
  35.  
  36. #charset koi8-r;
  37.  
  38. #access_log logs/host.access.log main;
  39.  
  40. location / {
  41. root html;
  42. index index.html index.htm;
  43. }
  44.  
  45. #error_page 404 /404.html;
  46.  
  47. # redirect server error pages to the static page /50x.html
  48. #
  49. error_page 500 502 503 504 /50x.html;
  50. location = /50x.html {
  51. root html;
  52. }
  53.  
  54. # proxy the PHP scripts to Apache listening on 127.0.0.1:80
  55. #
  56. #location ~ \.php$ {
  57. # proxy_pass http://127.0.0.1;
  58. #}
  59.  
  60. # pass the PHP scripts to FastCGI server listening on 127.0.0.1:9000
  61. #
  62. #location ~ \.php$ {
  63. # root html;
  64. # fastcgi_pass 127.0.0.1:9000;
  65. # fastcgi_index index.php;
  66. # fastcgi_param SCRIPT_FILENAME /scripts$fastcgi_script_name;
  67. # include fastcgi_params;
  68. #}
  69.  
  70. # deny access to .htaccess files, if Apache's document root
  71. # concurs with nginx's one
  72. #
  73. #location ~ /\.ht {
  74. # deny all;
  75. #}
  76. }
  77.  
  78. # another virtual host using mix of IP-, name-, and port-based configuration
  79. #
  80. #server {
  81. # listen 8000;
  82. # listen somename:8080;
  83. # server_name somename alias another.alias;
  84.  
  85. # location / {
  86. # root html;
  87. # index index.html index.htm;
  88. # }
  89. #}
  90.  
  91. # HTTPS server
  92. #
  93. #server {
  94. # listen 443 ssl;
  95. # server_name localhost;
  96.  
  97. # ssl_certificate cert.pem;
  98. # ssl_certificate_key cert.key;
  99.  
  100. # ssl_session_cache shared:SSL:1m;
  101. # ssl_session_timeout 5m;
  102.  
  103. # ssl_ciphers HIGH:!aNULL:!MD5;
  104. # ssl_prefer_server_ciphers on;
  105.  
  106. # location / {
  107. # root html;
  108. # index index.html index.htm;
  109. # }
  110. #}
  111.  
  112. }

nginx 文件结构

  1. ... #全局块
  2.  
  3. events { #events块
  4. ...
  5. }
  6.  
  7. http #http块
  8. {
  9. ... #http全局块
  10. server #server块
  11. {
  12. ... #server全局块
  13. location [PATTERN] #location块
  14. {
  15. ...
  16. }
  17. location [PATTERN]
  18. {
  19. ...
  20. }
  21. }
  22. server
  23. {
  24. ...
  25. }
  26. ... #http全局块
  27. }
  • 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.  
  22. upstream mysvr {
  23. server 127.0.0.1:7878;
  24. server 192.168.10.121:3333 backup; #热备
  25. }
  26. error_page 404 https://www.baidu.com; #错误页
  27. server {
  28. keepalive_requests 120; #单连接请求上限次数。
  29. listen 4545; #监听端口
  30. server_name 127.0.0.1; #监听地址
  31. location ~*^.+$ { #请求的url过滤,正则匹配,~为区分大小写,~*为不区分大小写。
  32. #root path; #根目录
  33. #index vv.txt; #设置默认页
  34. proxy_pass http://mysvr; #请求转向mysvr 定义的服务器列表
  35. deny 127.0.0.1; #拒绝的ip
  36. allow 172.18.5.54; #允许的ip
  37. }
  38. }
  39. }

上面是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、每个指令必须有分号结束。

  1.  
  1.  
  1.  
 

nginx安装配置_runoob_阅读笔记_20190917的更多相关文章

  1. Nginx安装配置与HelloWorld

    <深入理解Nginx>阅读与实践(一):Nginx安装配置与HelloWorld 最近在读陶辉的<深入理解Nginx:模块开发与架构解析>,一是想跟着大牛练练阅读和编写开源代码 ...

  2. Nginx 安装 配置 使用

    Nginx 安装 配置 使用 基本的HTTP服务器特性 处理静态文件,索引文件以及自动索引:打开文件描述符缓存(缓存元数据和文件描述符,下一次可以直接从内存找到数据或者文件的位置): 使用缓存加速反向 ...

  3. Nginx安装配置(转)

    Nginx 安装配置 Nginx("engine x")是一款是由俄罗斯的程序设计师Igor Sysoev所开发高性能的 Web和 反向代理 服务器,也是一个 IMAP/POP3/ ...

  4. Nginx安装配置PHP(FastCGI)环境的教程

    这篇是Nginx安装配置PHP(FastCGI)环境的教程.Nginx不支持对外部程序的直接调用或者解析,所有的外部程序(包括PHP)必须通过FastCGI接口来调用. 一.什么是 FastCGI F ...

  5. VMware Linux 下 Nginx 安装配置 - nginx.conf 配置 [负载两个 Tomcat] (三)

    首先启动Nginx 1. 相关浏览 两个 Tomcat 配置:  VMware Linux 下 Nginx 安装配置 - Tomcat 配置 (二) Nginx 安装配置启动: VMware Linu ...

  6. VMware Linux 下 Nginx 安装配置 - Tomcat 配置 (二)

    准备工作 相关浏览: VMware Linux 下 Nginx 安装配置 (一) 1. 选在 /usr/local/ 下创建 softs 文件夹,通过 ftp 命令 把 apache-tomcat-7 ...

  7. Hearbeat + Nginx 安装配置

    Hearbeat + Nginx 安装配置 实验环境 两台主机:Linux Centos 6.5 32位 主 服务端:Hearbeat + Nginx eth0:192.168.1.160(公网) e ...

  8. Nginx安装配置|Nginx反向代理|Nginx支持HTTPS|Nginx重定向

    Nginx安装配置 可以直接看到最下面的HTTPS. Nginx安装 我的系统如下: No LSB modules are available. Distributor ID: Ubuntu Desc ...

  9. puppet 3+Unicorn+Nginx安装配置

    puppet 3+Unicorn+Nginx安装配置 2014-08-15 10:58 酒瓶不倒 酒瓶不倒的博客 字号:T | T 一键收藏,随时查看,分享好友! Unicorn 效率要比 Webri ...

随机推荐

  1. 协议:FTP

    ylbtech-协议:FTP FTP(File Transfer Protocol,文件传输协议) 是 TCP/IP 协议组中的协议之一.FTP协议包括两个组成部分,其一为FTP服务器,其二为FTP客 ...

  2. windows 10中使用命令行关掉占用指定端口的程序

    通过netstat -ano与findstr命令结合查询到带有9080端口的监听信息,图中最后一列为监听程序的PID 通过tasklist命令与findstr命令结合查询到指定PID对应的应用程序 使 ...

  3. 阶段1 语言基础+高级_1-3-Java语言高级_06-File类与IO流_05 IO字符流_2_字符输入流读取字符数据

    读取的文件有中文也有英文 强转为char类型 缓冲读取多个字符 使用string的构造方法转换为字符输出

  4. nw打包vue项目exe更换图标

    web项目用nw打包好了之后发现没办法更换桌面显示图标问题,找了一下发现大多推荐Resource进行最后更换,试了第一次怎么也不管用,电脑重启了一下就行了...... 首先下载安装好了Resource ...

  5. css 实现渐变

    background:-ms-radial-gradient(circle,rgba(0, 0, 0, 0.2),rgba(0,0,0,0)); /* IE 10*/ background: -web ...

  6. git_03_git可视化工具github Desktop使用教程

    前言 github desktop是github的桌面客户端,支持Windows和Mac OS版本.使用简单,可以查看.切换和创建分支,以及提交.合并或部署代码. 下载 由于电脑限制,这里以mac o ...

  7. [开发技巧]·如何让离线安装Python包

    [开发技巧]·如何让离线安装Python包 1.问题描述 PyPI(Python Package Index)是python官方的第三方库的仓库,所有人都可以下载第三方库或上传自己开发的库到PyPI. ...

  8. 20191023 XXL-JOB

    概述 XXL-JOB是一个轻量级分布式任务调度平台,其核心设计目标是开发迅速.学习简单.轻量级.易扩展.现已开放源代码并接入多家公司线上产品线,开箱即用. 文档地址: 官方文档 文档写的很详细,参考着 ...

  9. docker搭建一个渗透测试环境 bwapp为例

    bwapp是一个渗透测试靶场,他其中中含有100多个Web漏洞  基本涵盖了所有主要的已知Web漏洞,包括OWASP Top 10的各种 首先要去搜索一下  看一下有哪些镜像可以下载    docke ...

  10. Tesseract5.0训练字库,提高OCR特殊场景识别率(一)

    0.目标 很多特殊场景,原生的字库识别率不高,这时候就需要根据需求自己训练字库生成traineddata文件. 一.前期准备工作 1.安装jdk   用于运行jTessBoxEditor 2.安装jT ...