目录
3.用一般匹配转发.php 、.js为后缀的动态请求到后端服务器(数据库)
location 匹配
location匹配的就是后面的uri
location匹配的分类和优先级
1.精确匹配
location = / 对字符串进行完整匹配,必须完全符合
2.正则匹配
location ^~前缀匹配,以什么为开头
~* \.jsp 以jsp为结尾
~ 区分大小写的匹配
~* 不区分大小写的匹配
!~ 区分大小写的取反
!~* 不区分大小写的取反
3.一般匹配
location / 字符串
优先级:精确匹配 > 正则匹配 > 一般匹配
优先级细分
location = 必须是完整路径(完全相同)
location ^~
location ~ location ~*
location /部分起始位置
location /
实际网站中的使用规则
1.用精确匹配来实现网站的首页
访问网站的首页 (= /)
location = / {
root html;
index index.html index.htm index.php;
}
2.用正则匹配来实现静态请求的页面和图片
匹配静态页面
location ^~ /static/ {
root /web/static/;
index index.html index.html;
}
访问图片或者指定的后缀名
location ~* \.(jpg.gif | png | jpeg | css | php)$ {
root /web/picturs/;
index index.html index.htm;
}
3.用一般匹配转发.php 、.js为后缀的动态请求到后端服务器(数据库)
转发后端请求和负载均衡
location / {
proxy_pass
}
rewrite 重定向
rewrite就是把当前访问的页面跳转到其他页面。
rewrite的工作方式:通过nginx的全局变量或者自定义变量,结合正则表达式和标志位实现URL的重定向
nginx的变量
$uri 客户端请求的uri的地址
$host 请求的主机名
$http_user_agent 客户端请求的浏览器和操作系统
$http_referer 请求头的referer信息,表示当前页面来源的url
$remote_addr 客户端的ip地址
$remote_port 客户端的端口号
$server_addr 服务端的ip地址
$server_port 服务端的端口号
$request_method 获取客户端请求的方法
$scheme 请求的协议,要么是http那么是https
x_forwarded_for 用来获取请求头当中客户端的真是ip地址,使用代理服务器添加,在代理服务器当中指示客户端的ip地址
X-Real-IP 客户端真实的ip地址
在nginx.conf添加
proxy_set_header X-Real-IP $remote_addr;
加上这个字段,客户端的真实ip地址就会传递给后端服务器
变量的使用
结果
标志位
flag
1.permanent 永久重定向 ,返回码是301,在浏览器地址栏会显示跳转后的URL地址
2.redirect 临时重定向,返回码是302,在浏览器地址栏会显示跳转后的URL地址
3.break 永久重定向,返回码是301,但是它匹配到规则之后不会再向下匹配其他规则,URL也不会发生变化
4.last 重定向,但是会继续向下匹配其他的location规则
实验
访问test1会跳转到xy102
rewrite的执行顺序
1.server模块的rewrite优先级最高
2.匹配location的规则
3.执行选定的location规则
rewrite的语法
rewrite 正则表达式 跳转后的内容 标志位;
500报错日志:
rewrite or internal redirection cycle while processing
在重定向的过程中,使用last方式进行重定向,但是没有结束语,陷入死循环,nginx会自动循环10次,fast匹配最多只能执行10次,超过10次没有结束,就会停止,然后报错500。
解决方法:添加break
常用实验
基于域名进行跳转
(老的不用了,但是依然能够访问,统统跳转到新的域名)
^/(.*)$ 以什么为开头以什么为结尾,就是获取全部内容
做映射
结果:访问www.xy102.com 会跳转到www.cj.com
基于客户端的ip进行跳转
(公司有新业务上线,属于测试阶段,其他的ip只能显示维护中,只有192.168.233.10能正常访问)
结果