从Windows下的Apache转移到Linux下的Nginx,发现有很多坑需要踩。
以下就做个简单的记录,方便后来者爬坑。
配置Nginx,一般会遇到以下几个坑:
- 配置nginx支持pathinfo模式
- - 优化URL,隐藏index.php
- - 同一服务器配置多站点
配置pathinfo模式
在server(也就是你的站点,一个server对应一个站点)中输入以下内容:
location ~ ^(.+\.php)(.*)$ {
root html/[站点目录]; #配置站点目录路径
fastcgi_split_path_info ^(.+\.php)(.*)$;
fastcgi_pass unix:/var/run/php-fpm/php-fpm.sock;
fastcgi_index index.php;
include fastcgi_params;
fastcgi_param SCRIPT_FILENAME $document_root/$fastcgi_script_name;
fastcgi_param PATH_INFO $fastcgi_script_name;
}
其中root html/[站点目录]这个一定要填写跟你server的站点目录路径,要不它默认为html,从而导致路径解析失败。会出现的现象就是,在之前配置的location中定义了root路径也无法生效,访问http://localhost会跳转到/usr/local/nginx/html/index.php[index.html],因为我的nginx是源码安装,所以路径可能不同,yum安装的话一般会在/usr/share/nginx/html/index.php[index.html].(PS:原默认关于fastcgi的配置可以注释掉)
隐藏index.php
隐藏index.php,大多数是采用Nginx的重写规则来进行的。
下面,就是博主的列出的一个参考:
location / {
root html/[站点目录];
index index.php;
if (!-e $request_filename) {
rewrite ^(.*)$ /index.php/$1;
}
}
这里的站点目录是你程序(框架)的index.php所在的目录。例如,CI框架的话,root html/ci,其中index.php位于html/ci/index.php.
本质上,隐藏index.php文件就是重写URL。具体详细用法可以参考Nginx重写模块的官方文档:Module ngx_http_rewrite_module
同一服务器多站点配置
一般一台服务器不会单一的运行一个站点,往往是运行多个站点的。
在Nginx配置多站点是非常简单,便捷的。正如,前面所说的,一个server对应一个站点。例如:
server {
listen 80;
server_name www.leslie.net.cn;
location / {
....
}
}
server {
listen 80;
server_name www.hellomyfrend.top;
location / {
....
}
}
这样,就配置了两个站点,分别为www.leslie.net.cn和www.hellomyfrend.top.
这里贴一份配置文件作为参考:
user nginx nginx;
worker_processes 2;
#error_log logs/error.log;
error_log logs/error.log notice;
#error_log logs/error.log info;
pid logs/nginx.pid;
events {
worker_connections 1024;
}
http {
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;
rewrite_log on;
sendfile on;
#tcp_nopush on;
#keepalive_timeout 0;
keepalive_timeout 65;
#gzip on;
server {
listen 80;
server_name pay.zf2.com;
location / {
root html/zf2/pay/public;
index index.php index.html index.htm;
if (!-e $request_filename){
rewrite ^/(.*)$ /index.php/$1;
}
}
location ~ ^(.+\.php)(.*)$ {
root html/zf2/pay/public;
fastcgi_split_path_info ^(.+\.php)(.*)$;
fastcgi_pass unix:/var/run/php-fpm/php-fpm.sock;
fastcgi_index index.php;
include fastcgi_params;
fastcgi_param SCRIPT_FILENAME $document_root/$fastcgi_script_name;
fastcgi_param PATH_INFO $fastcgi_script_name;
}
}
server {
listen 80;
server_name mp.zf2.com;
location / {
root html/zf2/server/public;
index index.php index.html index.htm;
if (!-e $request_filename){
rewrite ^(.*)$ /index.php/$1;
}
}
location ~ ^(.+\.php)(.*)$ {
root html/zf2/server/public;
fastcgi_split_path_info ^(.+\.php)(.*)$;
fastcgi_pass unix:/var/run/php-fpm/php-fpm.sock;
fastcgi_index index.php;
include fastcgi_params;
fastcgi_param SCRIPT_FILENAME $document_root/$fastcgi_script_name;
fastcgi_param PATH_INFO $fastcgi_script_name;
}
}
}
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。
免责声明:本站文章均来自网站采集或用户投稿,网站不提供任何软件下载或自行开发的软件! 如有用户或公司发现本站内容信息存在侵权行为,请邮件告知! 858582#qq.com
《魔兽世界》大逃杀!60人新游玩模式《强袭风暴》3月21日上线
暴雪近日发布了《魔兽世界》10.2.6 更新内容,新游玩模式《强袭风暴》即将于3月21 日在亚服上线,届时玩家将前往阿拉希高地展开一场 60 人大逃杀对战。
艾泽拉斯的冒险者已经征服了艾泽拉斯的大地及遥远的彼岸。他们在对抗世界上最致命的敌人时展现出过人的手腕,并且成功阻止终结宇宙等级的威胁。当他们在为即将于《魔兽世界》资料片《地心之战》中来袭的萨拉塔斯势力做战斗准备时,他们还需要在熟悉的阿拉希高地面对一个全新的敌人──那就是彼此。在《巨龙崛起》10.2.6 更新的《强袭风暴》中,玩家将会进入一个全新的海盗主题大逃杀式限时活动,其中包含极高的风险和史诗级的奖励。
《强袭风暴》不是普通的战场,作为一个独立于主游戏之外的活动,玩家可以用大逃杀的风格来体验《魔兽世界》,不分职业、不分装备(除了你在赛局中捡到的),光是技巧和战略的强弱之分就能决定出谁才是能坚持到最后的赢家。本次活动将会开放单人和双人模式,玩家在加入海盗主题的预赛大厅区域前,可以从强袭风暴角色画面新增好友。游玩游戏将可以累计名望轨迹,《巨龙崛起》和《魔兽世界:巫妖王之怒 经典版》的玩家都可以获得奖励。