nginx 经过 location 的规则匹配将 php 转发给 php-fpm 处理后获取结果真后返回给客户端,转发模式能够经过 unix sock 或 tcp socket 方式。百度了好多文章我是没遇到一个能完整的并且正确的把 nginx 和 php 结合的配置讲述的较为正确的,这里总结了下最基本的 nginx + php 的模式配置,以及隐藏 index.php 和 开启 pathinfo 模式的方法。javascript
我的以为是能够复制粘贴配置你的生产环境的,总结了不少好的博文的要点,好比隐藏 index.php 的 location 规则用的是 try_files 而不是烂大街的 if (! -e $uri) {},http 服务器级配置文件 和 虚拟主机配置文件也很好的分割开了,方便维护。php
nginx 配置分两大层,基础的全局 http 配置 和 与主机相对应的 server 配置。css
nginx.confhtml
# nginx main configure user www www; worker_processes auto; error_log /var/log/error.log crit; pid /var/nginx.pid; #Specifies the value for maximum file descriptors that can be opened by this process. worker_rlimit_nofile 2048; events { use epoll; worker_connections 2048; multi_accept on; } http { include mime.types; default_type application/octet-stream; server_names_hash_bucket_size 128; client_header_buffer_size 32k; large_client_header_buffers 4 32k; client_max_body_size 50m; sendfile on; tcp_nopush on; keepalive_timeout 60; tcp_nodelay on; fastcgi_connect_timeout 300; fastcgi_send_timeout 300; fastcgi_read_timeout 300; fastcgi_buffer_size 64k; fastcgi_buffers 4 64k; fastcgi_busy_buffers_size 128k; fastcgi_temp_file_write_size 256k; gzip on; gzip_min_length 1k; gzip_buffers 4 16k; gzip_http_version 1.1; gzip_comp_level 2; gzip_types text/plain application/javascript application/x-javascript text/javascript text/css application/xml application/xml+rss; gzip_vary on; gzip_proxied expired no-cache no-store private auth; gzip_disable "MSIE [1-6]\."; #limit_conn_zone $binary_remote_addr zone=perip:10m; ##If enable limit_conn_zone,add "limit_conn perip 10;" to server section. server_tokens off; access_log off; # http 配置 include vhost/*.conf; }
nginx http 的主配置文件,这里面包含了用户组,日志,处理类型,压缩传输,并发数等参数配置。咱们并无在这里配置 server,而是将全部的 server 放置到 vhost 文件中,清晰的管理咱们的 server 虚拟主机配置。咱们能够将不一样 server 服务器单独配置为 conf 文件。java
好比咱们配置一虚拟主机 default node
vhost/default.confnginx
这里面参数配置包括:隐藏 index.php,开启php处理或开启php pathinfo模式,单独处理静态资源centos
注意:bash
若是你想开启 pathinfo 模式只须要将 enable-php.conf 改成 enable-php-pathinfo.conf 便可,两者选其一服务器
server { listen 80; #listen [::]:80; server_name www.default.com; index index.html index.htm index.php; root /var/www/default; #error_page 404 /404.html; #hide index.php location / { # yii2 框架的 /site/index?name=sallency&age=25 模式的 rewrite 方法 try_files $uri $uri/ /index.php$is_args$args; # tp 框架的 /site/index/name/sallency/age/25 模式的 rewrite 方法 try_files $uri $uri/ /index.php/$uri; # 虽然 if 不规范但 rewrite 仍是很方便的 能够兼容 yii2 和 tp 的 pathinfo 模式 if (!-e $request_filename){ rewrite ^/(.*)$ /index.php/$1 last; break; } } #handler php request include enable-php.conf; #php with pathinfo #include enable-php-pathinfo.conf; #handler static resource location ~ .*\.(gif|jpg|jpeg|png|bmp|swf)$ { expires 30d; } location ~ .*\.(js|css)?$ { expires 12h; } #forbidden access . type location ~ /\. { deny all; } access_log /var/log/nginx/default_access.log }
enable-php.conf
开启此配置即可以让 nginx 处理 php 文件,须要注意的是 fastcig_pass 的模式有两种:
unix socket:不走网卡 效率高但不稳定
tcp socket:127.0.0.1:9000 相比 unix socket 会慢一点点,但稳定性高出不少
此处的模式和配置选择应与 php-fpm.conf 中的 listen 参数保持一致:
listen = /tmp/php-cgi.sock
listen = 127.0.0.1:9000
location ~ [^/]\.php(/|$) { try_files $uri =404; #listen unix socket #fastcgi_pass unix:/tmp/php-cgi.sock; #listen tcp socket fastcgi_pass 127.0.0.1:9000; fastcgi_index index.php; include fastcgi.conf; }
enable-php-pathinfo.conf
此配置文件为 enable-php.conf 的加强版-- 开启 pathinfo 模式,流行的 php 框架都支持此模式
location ~ [^/]\.php(/|$) { #listen unix socket #fastcgi_pass unix:/tmp/php-cgi.sock; #listen tcp socket fastcgi_pass 127.0.0.1:9000; fastcgi_index index.php; include fastcgi.conf; #pathinfo fastcgi_split_path_info ^(.+?\.php)(/.*)$; set $path_info $fastcgi_path_info; fastcgi_param PATH_INFO $path_info; try_files $fastcgi_script_name =404; }
fastcgi.conf
这个配置文件实际上是 nginx 自带的,我贴一下
fastcgi_param SCRIPT_FILENAME $document_root$fastcgi_script_name; fastcgi_param QUERY_STRING $query_string; fastcgi_param REQUEST_METHOD $request_method; fastcgi_param CONTENT_TYPE $content_type; fastcgi_param CONTENT_LENGTH $content_length; fastcgi_param SCRIPT_NAME $fastcgi_script_name; fastcgi_param REQUEST_URI $request_uri; fastcgi_param DOCUMENT_URI $document_uri; fastcgi_param DOCUMENT_ROOT $document_root; fastcgi_param SERVER_PROTOCOL $server_protocol; fastcgi_param REQUEST_SCHEME $scheme; fastcgi_param HTTPS $https if_not_empty; fastcgi_param GATEWAY_INTERFACE CGI/1.1; fastcgi_param SERVER_SOFTWARE nginx/$nginx_version; fastcgi_param REMOTE_ADDR $remote_addr; fastcgi_param REMOTE_PORT $remote_port; fastcgi_param SERVER_ADDR $server_addr; fastcgi_param SERVER_PORT $server_port; fastcgi_param SERVER_NAME $server_name; # PHP only, required if PHP was built with --enable-force-cgi-redirect fastcgi_param REDIRECT_STATUS 200;
配置完成,注意由于全部的配置文件都是由 nginx.conf 这个主配置文件做为入口进行加载的,因此活动目录始终是在 nginx.conf 所在的目录,因此配置文件中的 include 的当前路径是 nginx.conf 所在的目录,配置完成后重启 nginx service 的同时记得重启 php-fpm 服务
相关文章: