
Nginx安装
nginx官网:https://nginx.org/
安装准备:nginx依赖pcre库,要先安装pcre(nginx在rewrite时需要解析正则,PCRE是正则解析库)
yum install pcre pcre-devel
wget http://nginx.org/download/nginx-1.4.2.tar.gz
tar zxvf nginx-1.4.2.tar.gz
cd nginx-1.4.2
./configure --prefix=/usr/local/nginx
make && make install
Nginx说明
cd /usr/local/nginx 下主要信息:
--conf 配置文件
--html 网页文件
--logs 日志信息
--sbin 二进制程序
PathInfo模式:
默认nginx不支持path_info模式,apache自带path_info模式
nginx实现原理:
正则匹配.php后面的pathinfo部分
把pathinfo部分赋给PATH_INFO变量
# 典型配置
location ~ \.php$ {
root html;
fastcgi_pass 127.0.0.1:9000;
fastcgi_index index.php;
fastcgi_param SCRIPT_FILENAME $DOCUMENT_ROOT$fastcgi_script_name;
include fastcgi_params;
} # 修改第1,6行,支持pathinfo location ~ \.php(.*)$ { # 正则匹配.php后的pathinfo部分
root html;
fastcgi_pass 127.0.0.1:9000;
fastcgi_index index.php;
fastcgi_param SCRIPT_FILENAME $DOCUMENT_ROOT$fastcgi_script_name;
fastcgi_param PATH_INFO $1; # 把pathinfo部分赋给PATH_INFO变量 比如 index.php/user/login 中将 /user/login传给PATH_INFO变量
include fastcgi_params;
}
Url重写(rewrite)
php访问去掉index.php location / {
root 网站更目录路径;
index 首页
if ( !-e $uri ) { #访问不存在的时候
rewrite (.*)$ /index.php/$1;
}
} 注意:if后面一定需要加空格
regex 常用正则表达式说明
字符 |
描述 |
\ |
将后面接着的字符标记为一个特殊字符或一个原义字符或一个向后引用。如“\n”匹配一个换行符,而“\$”则匹配“$” |
^ |
匹配输入字符串的起始位置 |
$ |
匹配输入字符串的结束位置 |
* |
匹配前面的字符零次或多次。如“ol*”能匹配“o”及“ol”、“oll” |
+ |
匹配前面的字符一次或多次。如“ol+”能匹配“ol”及“oll”、“oll”,但不能匹配“o” |
? |
匹配前面的字符零次或一次,例如“do(es)?”能匹配“do”或者“does”,"?"等效于"{0,1}" |
. |
匹配除“\n”之外的任何单个字符,若要匹配包括“\n”在内的任意字符,请使用诸如“[.\n]”之类的模式。 |
(pattern) |
匹配括号内pattern并可以在后面获取对应的匹配,常用$0...$9属性获取小括号中的匹配内容,要匹配圆括号字符需要\(Content\) |
try_files(rewrite的简写模式吧)
案例:去掉index.php
location / {
root 项目根目录;
index 首页
try_files $uri /index.php?$uri; #尝试去访问$uri,如果访问不到则访问 /index.php?$uri
}
反向代理:
请求图片访问另一台服务器:
location ~ \.(jpeg|jpg|png|gif)$ {
proxy_pass http://ip:port
}
在浏览器中输入a.com能访问到内网机器192.168.138.38的3000端口,输入b.com能访问到内网机器192.168.138.40的80端口 目的:外网ip有限,有多个域名
server
{
listen 80;
server_name a.com;
location / {
proxy_redirect off;
proxy_set_header Host $host;
proxy_set_header X-Real-IP $remote_addr;
proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
proxy_pass http://192.168.138.38:3000;
}
access_log logs/a_com_access.log;
}
server
{
listen 80;
server_name b.com;
location / {
proxy_redirect off;
proxy_set_header Host $host;
proxy_set_header X-Real-IP $remote_addr;
proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
proxy_pass http://192.168.138.40:80;
}
access_log logs/b_com_access.log;
}
集群和负载均衡:
1、上游配置upstream
upstream servers {
server 192.168.138.2:8080 weight=1 max_fails=2 fail_timeout=30s;
server 192.168.138.3:8080 weight=1 max_fails=2 fail_timeout=30s;
#weight 表示权重 fail_timeout表示超时时间 max_fails表示最大次数
} 2、下游配置调用
location ~ \.(jepg|jpg|png|gif) {
proxy_paxx http://servers;#对应上游upstream中的名称
proxy_set_header X-Forwarded-For $remote_addr;#原始用户ip
}