核心做法:
涉及三类配置文件
1. 基础文件 conf/nginx.conf
# 说明:nginx默认会引用该文件,该文件会做最通用的参数设置
2. fastcgi参数文件 conf/fastcgi.conf
# 说明:fastcgi会设置所有站点通用参数
3. 站点文件 如:conf/vhost/a.com.conf 可以有多个,放在vhost文件夹下
彼此引用说明
在基础文件conf/nginx.conf中插入include *.conf 引用站点文件
站点文件中合适位置插入include fastcgi.conf 设置fastcgi,如果要覆盖参数,可以在引用再赋值一次即可
nginx配置文件里指令的继承关系:Nginx配置文件分为好多块,常见的从外到内依次是「http」、「server」、「location」等等,缺省的继承关系是从外到内,也就是说内层块会自动获取外层块的值作为缺省值
详细说明:
nginx.conf中设置基础参数,内容如下:
#用户及用户组设置
user www www;
worker_processes 1;
#错误级别的日志设置
error_log logs/error.log;
#其他级别的日志设置
#error_log logs/error.log notice;
#error_log logs/error.log info;
pid logs/nginx.pid;
events {
use epoll;
worker_connections 1024;
}
http {
#fastcgi_intercept_errors on;
#error_page 404 ;
include mime.types;
default_type application/octet-stream;
log_format main '$remote_addr - $remote_user [$time_local] "$request" '
'$status $body_bytes_sent "$http_referer" '
'"$http_user_agent" "$http_x_forwarded_for"';
#access_log logs/access.log main;
server_names_hash_bucket_size 128;
client_header_buffer_size 32k;
large_client_header_buffers 4 32k;
client_max_body_size 300m;
sendfile on;
tcp_nopush 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 128k;
#keepalive_timeout 0;
keepalive_timeout 60;
tcp_nodelay on;
server_tokens off;
gzip on;
gzip_min_length 1k;
gzip_buffers 4 16k;
gzip_http_version 1.1;
gzip_comp_level 2;
gzip_types text/plain application/x-javascript text/css application/xml;
gzip_vary on;
#未绑定域名返回404
server {
listen 80 default;
fastcgi_intercept_errors on;
error_page 404 /404.html;
location /404.html {
root /data/web/404;
internal;
}
}
#加载每个站点conf文件
include vhost/*.conf;
}
单个站点conf文件放在conf/vhost文件夹下,比如建立一个a.com.conf,内容见下方:
server {
#监听端口
listen 80;
#request大小
client_max_body_size 50M;
#绑定域名,用空格分开多个域名
server_name a.com www.a.com;
#不带www域名做301跳转
if ( $host != 'www.a.com' ) {
#return方法,效率更高
return 301 http://www.a.com$request_uri;
#rewrite写法
#rewrite ^/(.*)$ http://www.a.com/$1 permanent;
}
#默认首页
index index.php index.html index.htm;
#站点目录
set $root_path '/data/wwwroot/a.com/web/';
root $root_path;
#日志前缀设置
#set $log 'a.com'
#访问日志
#access_log logs/$log_access.log main;
#错误日志
#error_log logs/$log_error.log;
#伪静态
location / {
#ci框架
#try_files $uri $uri/ /index.php?$query_string;
#phalcon框架
#try_files $uri $uri/ /index.php?_url=$uri&$args;
}
#php文件采用fastcgi解析并设置参数
location ~ \.php {
fastcgi_index /index.php;
fastcgi_pass 127.0.0.1:9000;
#加载fastcgi.conf文件中的参数
include fastcgi.conf;
#设置有权限目录,fastcgi.conf中默认设置就是站点目录$document_root,如果要改变就需要重新赋值
#phalcon或laravel举例
#fastcgi_param PHP_ADMIN_VALUE "open_basedir=$document_root../:/data/tmp/php/upload/:/proc/";
}
#禁止下载伪静态文件
location ~ /\.ht {
deny all;
}
}
conf/fastcgi.conf内容:
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 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;
# 用一个文件或状态码(=404)作为最后一个参数,如果是最后一个参数是文件,那么这个文件必须存在
try_files $fastcgi_script_name = 404;
#可以自定义值,比如区分开发(dev)和生成环境(product),在php中用getenv('MY_ENV')或$_SERVER['MY_ENV']获取
fastcgi_param MY_ENV "product";
#防跨站设置
fastcgi_param PHP_ADMIN_VALUE "open_basedir=$document_root:/data/tmp/php/upload/:/proc/";
需要说明的:Nginx有两份fastcgi配置文件,分别是旧的「fastcgi_params」和新的「fastcgi.conf」,它们没有太大的差异,唯一的区别是后者比前者多了一行「SCRIPT_FILENAME」的定义,只需要引用一份新的配置文件fastcgi.conf即可
fastcgi_param SCRIPT_FILENAME $document_root$fastcgi_script_name;#脚本文件请求的路径
fastcgi_param QUERY_STRING $query_string; #请求的参数;如?app=123
fastcgi_param REQUEST_METHOD $request_method; #请求的动作(GET,POST)
fastcgi_param CONTENT_TYPE $content_type; #请求头中的Content-Type字段
fastcgi_param CONTENT_LENGTH $content_length; #请求头中的Content-length字段。
fastcgi_param SCRIPT_NAME $fastcgi_script_name; #脚本名称
fastcgi_param REQUEST_URI $request_uri; #请求的地址不带参数
fastcgi_param DOCUMENT_URI $document_uri; #与$uri相同。
fastcgi_param DOCUMENT_ROOT $document_root; #网站的根目录。在server配置中root指令中指定的值
fastcgi_param SERVER_PROTOCOL $server_protocol; #请求使用的协议,通常是HTTP/1.0或HTTP/1.1。
fastcgi_param GATEWAY_INTERFACE CGI/1.1;#cgi 版本
fastcgi_param SERVER_SOFTWARE nginx/$nginx_version;#nginx 版本号,可修改、隐藏
fastcgi_param REMOTE_ADDR $remote_addr; #客户端IP
fastcgi_param REMOTE_PORT $remote_port; #客户端端口
fastcgi_param SERVER_ADDR $server_addr; #服务器IP地址
fastcgi_param SERVER_PORT $server_port; #服务器端口
fastcgi_param SERVER_NAME $server_name; #服务器名,域名在server配置中指定的server_name
#fastcgi_param PATH_INFO $path_info;#可自定义变量
# PHP only, required if PHP was built with –enable-force-cgi-redirect
#fastcgi_param REDIRECT_STATUS 200;
在php可打印出上面的服务环境变量
如:echo $_SERVER['MY_ENV'] //只适配nginx,不适用cli模式,cli模式必须设置系统变量,mac下在~/.bash_profile
nginx内置变量
默认编码问题
注:php.5.6默认是utf-8,必须改成自动适配
# php.ini里面的配置
; default_charset = "UTF-8"
#不能注释,必须改成下面的形式,不然还是默认utf-8
default_charset = ""
关于伪静态
需要说明的是:rewrite regex replacement [flag]; regex指的是url中的字符串
location / {
rewrite ^/news-(\d+).html$ /news.php?cat_id=$1 last;
#将news.php?cat_id=110伪静态成news-110.html
}
nging支持PATH_INFO
支持ssi
在http{}或者server中的location / {}中添加如下代码即可:
ssi on;
ssi_silent_errors on;
ssi_types text/shtml;