centos下安装nginx

加入全栈技术交流群(QQ群号:254842154)

Nginx ("engine x") 是一个高性能的 HTTP 和 反向代理 服务器,也是一个 IMAP/POP3/SMTP 代理服务器。 Nginx 是由 Igor Sysoev 为俄罗斯访问量第二的 Rambler.ru 站点开发的。其特点是占有内存少,并发能力强,事实上nginx的并发能力确实在同类型的网页服务器中表现较好,中国大陆使用nginx网站用户有:新浪、网易、腾讯等。在高连接并发的情况下,Nginx是Apache服务器不错的替代品。

1、安装

nginx官网下载。我找了一个稳定版本下载。

wget http://nginx.org/download/nginx-1.6.2.tar.gz
tar -zxvf nginx-1.6.2.tar.gz
cd nginx-1.6.2

还需要下载pcre、openssl、zlib,在这里给出下载地址,并解压,供编译时使用。注意,不需要编译他们,只要在nginx的编译参数中指定源码路径即可。

pcre: https://sourceforge.net/projects/pcre/files/

wget http://sourceforge.net/projects/pcre/files/pcre/8.32/pcre-8.32.tar.gz/download

openssl: http://www.openssl.org/

wget http://www.openssl.org/source/openssl-1.0.1k.tar.gz

zlib: http://zlib.net/

wget http://zlib.net/zlib-1.2.8.tar.gz

编译

./configure --prefix=/usr/local/nginx --sbin-path=/usr/local/nginx/nginx --conf-path=/usr/local/nginx/nginx.conf --pid-path=/usr/local/nginx/nginx.pid --with-http_ssl_module --with-pcre --with-openssl=/tmp/openssl-1.0.1k --with-zlib=/tmp/zlib-1.2.8 --with-pcre=/tmp/pcre-8.32

make
make install

2、配置

简单的配置。通常,不需要任何配置即可访问。具体的配置请自行网上查询。

cd /usr/local/nginx/conf
vim nginx.conf

测试nginx的配置文件是否正确

/usr/local/nginx/nginx  -t    

启动nginx(确保80端口没有被暂用,假如服务器上有apache,关闭之)

/usr/local/nginx/nginx 

看看是否启动成功(看看80端口是否在监听)

netstat -ano|grep 80

重启nginx

/usr/local/nginx/nginx -s reload

关闭nginx

/usr/local/nginx/nginx -s stop

查看nginx的两个主要线程

ps aux | grep nginx

3、使nginx支持php

假如php的版本小于5.3,需要单独安装php-fpm扩展。大于5.3的php集成了php-fpm,只需要在编译安装php时,通过 --enable-fpm --enable-fastcgi 这两个编译选项来安装扩展。假如编译安装时忘记了打开这两个编译选项,应该是可以单独安装的,但是我试过了不成功,可能是我的方法不对。于是只能重新编译php,幸好也没问题。重新编译前为了保险起见最好备份一下php.ini。

nginx是通过fast-cgi来解析php请求的,默认通过9000端口通信。

安装好php-fpm后,需要配置一下参数,比较多。配置文件在 /usr/local/php/etc/php-fpm.conf,不同安装目录可能不同。

pid = run/php-fpm.pid
#pid设置,默认在安装目录中的var/run/php-fpm.pid,建议开启

error_log = log/php-fpm.log
#错误日志,默认在安装目录中的var/log/php-fpm.log

log_level = notice
#错误级别. 可用级别为: alert(必须立即处理), error(错误情况), warning(警告情况), notice(一般重要信息), debug(调试信息). 默认: notice.

emergency_restart_threshold = 60
emergency_restart_interval = 60s
#表示在emergency_restart_interval所设值内出现SIGSEGV或者SIGBUS错误的php-cgi进程数如果超过 emergency_restart_threshold个,php-fpm就会优雅重启。这两个选项一般保持默认值。

process_control_timeout = 0
#设置子进程接受主进程复用信号的超时时间. 可用单位: s(秒), m(分), h(小时), 或者 d(天) 默认单位: s(秒). 默认值: 0.

daemonize = yes
#后台执行fpm,默认值为yes,如果为了调试可以改为no。在FPM中,可以使用不同的设置来运行多个进程池。 这些设置可以针对每个进程池单独设置。

listen = 127.0.0.1:9000
#fpm监听端口,即nginx中php处理的地址,一般默认值即可。可用格式为: 'ip:port', 'port', '/path/to/unix/socket'. 每个进程池都需要设置.

listen.backlog = -1
#backlog数,-1表示无限制,由操作系统决定,此行注释掉就行。backlog含义参考:http://www.3gyou.cc/?p=41

listen.allowed_clients = 127.0.0.1
#允许访问FastCGI进程的IP,设置any为不限制IP,如果要设置其他主机的nginx也能访问这台FPM进程,listen处要设置成本地可被访问的IP。默认值是any。每个地址是用逗号分隔. 如果没有设置或者为空,则允许任何服务器请求连接

listen.owner = www
listen.group = www
listen.mode = 0666
#unix socket设置选项,如果使用tcp方式访问,这里注释即可。

user = www
group = www
#启动进程的帐户和组

pm = dynamic #对于专用服务器,pm可以设置为static。
#如何控制子进程,选项有static和dynamic。如果选择static,则由pm.max_children指定固定的子进程数。如果选择dynamic,则由下开参数决定:
pm.max_children #,子进程最大数
pm.start_servers #,启动时的进程数
pm.min_spare_servers #,保证空闲进程数最小值,如果空闲进程小于此值,则创建新的子进程
pm.max_spare_servers #,保证空闲进程数最大值,如果空闲进程大于此值,此进行清理

pm.max_requests = 1000
#设置每个子进程重生之前服务的请求数. 对于可能存在内存泄漏的第三方模块来说是非常有用的. 如果设置为 '0' 则一直接受请求. 等同于 PHP_FCGI_MAX_REQUESTS 环境变量. 默认值: 0.

pm.status_path = /status
#FPM状态页面的网址. 如果没有设置, 则无法访问状态页面. 默认值: none. munin监控会使用到

ping.path = /ping
#FPM监控页面的ping网址. 如果没有设置, 则无法访问ping页面. 该页面用于外部检测FPM是否存活并且可以响应请求. 请注意必须以斜线开头 (/)。

ping.response = pong
#用于定义ping请求的返回相应. 返回为 HTTP 200 的 text/plain 格式文本. 默认值: pong.

request_terminate_timeout = 0
#设置单个请求的超时中止时间. 该选项可能会对php.ini设置中的'max_execution_time'因为某些特殊原因没有中止运行的脚本有用. 设置为 '0' 表示 'Off'.当经常出现502错误时可以尝试更改此选项。

request_slowlog_timeout = 10s
#当一个请求该设置的超时时间后,就会将对应的PHP调用堆栈信息完整写入到慢日志中. 设置为 '0' 表示 'Off'

slowlog = log/$pool.log.slow
#慢请求的记录日志,配合request_slowlog_timeout使用

rlimit_files = 1024
#设置文件打开描述符的rlimit限制. 默认值: 系统定义值默认可打开句柄是1024,可使用 ulimit -n查看,ulimit -n 2048修改。

rlimit_core = 0
#设置核心rlimit最大限制值. 可用值: 'unlimited' 、0或者正整数. 默认值: 系统定义值.

chroot =
#启动时的Chroot目录. 所定义的目录需要是绝对路径. 如果没有设置, 则chroot不被使用.

chdir =
#设置启动目录,启动时会自动Chdir到该目录. 所定义的目录需要是绝对路径. 默认值: 当前目录,或者/目录(chroot时)

catch_workers_output = yes
#重定向运行过程中的stdout和stderr到主要的错误日志文件中. 如果没有设置, stdout 和 stderr 将会根据FastCGI的规则被重定向到 /dev/null . 默认值: 空.

设置好后,测试一下配置文件

/usr/local/php/sbin/php-fpm

启动

/usr/local/php/sbin/php-fpm

看看是否启动成功了

ps aux | grep php-fpm

我的机器显示如下

[root@hellojammy html]# ps aux | grep php-fpm
root      1643  0.0  1.0 104272  5464 ?        Ss   22:49   0:00 php-fpm: master process (/usr/local/php/etc/php-fpm.conf)
nobody    1644  0.0  1.1 104272  6164 ?        S    22:49   0:00 php-fpm: pool www          
nobody    1645  0.0  1.2 104272  6600 ?        S    22:49   0:00 php-fpm: pool www          
root      1651  0.0  0.1   6384   684 pts/1    S+   22:53   0:00 grep php-fpm

或者查看9000端口是否已经正在被监听

netstat -lnp | grep :9000

我的机器上显示如下

tcp        0      0 127.0.0.1:9000              0.0.0.0:*                   LISTEN      1643/php-fpm 

再配置nginx的配置文件,使其php支持,

vim /usr/local/nginx/nginx.conf

配置

location ~ \.php$ {
        fastcgi_pass   127.0.0.1:9000;
        fastcgi_index  index.php;
        include        fastcgi.conf;
        }

需要在Server节点下指定网站根目录

root /usr/local/apache/htdocs

添加ghost站点,反向代理

    ####ghost博客配置####
server {
    listen       80;
    server_name  www.hello1010.com hello1010.com;
    access_log  logs/ghost.access.log;
    location / {
        root /usr/local/apache/htdocs/ghost;
        proxy_set_header   X-Real-IP $remote_addr;
        proxy_set_header   Host   $http_host;
        proxy_pass_header User-Agent; #获取客户端User-Agent来判断每次POST数据是否跟第一次请求来自同1个浏览器
        proxy_pass http://127.0.0.1:2386;
        proxy_redirect off;
    }
}

添加其他站点

    ####静态文件####
server {
    listen       80;
    server_name  static.hello1010.com;
    root /usr/local/nginx/html/static;       
}

最后别忘接了重启nginx。

标签: none

→ 如果你觉得作者的文章不错,一不小心帮到了你,欢迎打赏作者几包辣条的钱💰