Nginx多Server反向代理配置
来源:程序员人生 发布时间:2015-01-06 08:24:18 阅读次数:5503次
Nginx强大的正则表达式支持,可使server_name的配置变得很灵活,如果你要做多用户博客,那末每一个用户具有自己的2级域名也就很容易实现了。
下面我就来讲说server_name的使用吧:
server_name的匹配顺序
Nginx中的server_name指令主要用于配置基于名称虚拟主机,server_name指令在接到要求后的匹配顺序分别为:
1、准确的server_name匹配,例如:
server { listen 80; server_name ssdr.info www.ssdr.info; ... }
2、以*通配符开始的字符串:
server { listen 80; server_name *.ssdr.info; ... }
3、以*通配符结束的字符串:
server { listen 80; server_name www.*; ... }
4、匹配正则表达式:
server { listen 80; server_name ~^(?.+).howtocn.org$; ... }
Nginx将依照1,2,3,4的顺序对server name进行匹配,只有有1项匹配以后就会停止搜索,所以我们在使用这个指令的时候1定要分清楚它的匹配顺序(类似于location指令)。
server_name指令1项很实用的功能便是可以在使用正则表达式的捕获功能,这样可以尽可能精简配置文件,毕竟太长的配置文件平常保护也很不方便。下面是2个具体的利用:
在1个server块中配置多个站点:
server { listen 80; server_name ~^(www.)?(.+)$; index index.php index.html; root /data/wwwsite/$2; }
站点的主目录应当类似于这样的结构:
/data/wwwsite/ssdr.info /data/wwwsite/linuxtone.org /data/wwwsite/baidu.com /data/wwwsite/google.com
这样就能够只使用1个server块来完成多个站点的配置。
在1个server块中为1个站点配置多个2级域名 。
实际网站目录结构中我们通常会为站点的2级域名独立创建1个目录,一样我们可使用正则的捕获来实现在1个server块中配置多个2级域名:
server { listen 80; server_name ~^(.+)?.howtocn.org$; index index.html; if ($host = ssdr.info){ rewrite ^ http://www.ssdr.info permanent; } root /data/wwwsite/ssdr.info/$1/; }
站点的目录结构应当以下:
/data/wwwsite/ssdr.info/www/ /data/wwwsite/ssdr.info/nginx/
这样访问www.ssdr.info时root目录为/data/wwwsite/ssdr.info/www/,nginx.ssdr.info时为/data/wwwsite/ssdr.info/nginx/,以此类推。
后面if语句的作用是将ssdr.info的方位重定向到www.ssdr.info,这样既解决了网站的主目录访问,又可以增加seo中对www.ssdr.info的域名权重。
多个正则表达式
如果你在server_name中用了正则,而下面的location字段又使用了正则匹配,这样将没法使用$1,$2这样的援用,解决方法是通过set指令将其赋值给1个命名的变量:
server { listen 80; server_name ~^(.+)?.howtocn.org$; set $www_root $1; root /data/wwwsite/ssdr.info/$www_root/; location ~ .*.php?$ { fastcgi_pass 127.0.0.1:9000; fastcgi_index index.php; fastcgi_param SCRIPT_FILENAME /data/wwwsite/ssdr.info/$fastcgi_script_name; include fastcgi_params; } }
Nginx不同域名反向代理到另外一台服务器 proxy_pass和$host
想让1个VPS专门做另外一个VPS的前端,后端VPS每添加1个域名,前端VPS就要同时添加1个域名来反向代理,作为前真个VPS如果1个1个的添加后端VPS的域名,那末这个事情特别麻烦,能不能让其自动反向代理后端VPS呢,用到proxy_pass和$host就能够轻松实现。
以下例子为了省事,以lnmp为安装环境进行设置
修改前端VPS的nginx.conf文件,修改成以下内容:
server { listen 80; server_name $host; location / { proxy_pass http://www.31.gd/; proxy_set_header Host $host; proxy_redirect off; proxy_set_header X-Real-IP $remote_addr; proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for; proxy_connect_timeout 60; proxy_read_timeout 600; proxy_send_timeout 600; }
下面的1并修改吧。
location /.(php|php5)?$ { fastcgi_pass unix:/tmp/php-cgi.sock; fastcgi_index index.php; include fcgi.conf; } location /status { stub_status on;
access_log off; } location /.(gif|jpg|jpeg|png|bmp|swf)$ { expires 30d; } location /.(js|css)?$ { expires 12h; }
这样就能够实现了前端VPS可以反向代理任意域名到后端VPS,只要将域名解析到前端VPS,后端VPS进行域名绑定,那末就能够直接访问到了
1台nginx带多个域名多个tomcat情况的配置
多个域名,其中2个域名需支持泛域名解析:
1、www.abc.com
2、www.bcd.com
3、*.efg.com
4、*.hij.com
其中1,2,3为1台tomcat,4为独立tomcat。前端1台nginx,通过配置多个虚拟主机来实现该部署。
进入/etc/nginx/conf.d目录,所有虚拟主机的配置文件都在该目录下寄存,配置。
配置支持泛域名
# # A virtual host using mix of IP-, name-, and port-based configuration # server { listen 81; server_name *.efg.com; location / { proxy_pass http://localhost:8080; proxy_set_header Host $host; proxy_set_header X-Real-IP $remote_addr; proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for; } } # # A virtual host using mix of IP-, name-, and port-based configuration # server { listen 81; server_name *.hij.com; location / { proxy_pass http://localhost:8081; proxy_set_header Host $host; proxy_set_header X-Real-IP $remote_addr; proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for; } }
泛域名解析关键为红色部份,如果没有红色部份,后端8080及8081口对应的tomcat虚拟主机将没法取得域名信息,致使后端tomcat没法获得到对应的域名信息。
后端TOMCAT支持泛域名解析时,需要设置 host name 为 localhost 以支持泛域名指向。
Nginx 多域名配置
nginx绑定多个域名可又把多个域名规则写1个配置文件里,也可又分别建立多个域名配置文件,我1般为了管理方便,每一个域名建1个文件,有些同类域名也可又写在1个总的配置文件里。
1、每一个域名1个文件的写法
首先打开 nginx域名配置文件寄存目录:/usr/local/nginx/conf/servers ,如要绑定域名www.web126.com 则在此目录建1个文件:www.web126.com.conf 然后在此文件中写规则,如:
server { listen 80; server_name www.web126.com; #绑定域名 index index.htm index.html index.php; #默许文件 root /home/www/web126.com; #网站根目录 include location.conf; #调用其他规则,也可去除 }
然后重起nginx服务器,域名就绑定成功了。
Nginx服务器重起命令:/etc/init.d/nginx restart。
2、1个文件多个域名的写法
1个文件添加多个域名的规则也是1样,只要把上面单个域名重复写下来就ok了,如:
server { listen 80; server_name www.web126.com; #绑定域名 index index.htm index.html index.php; #默许文件 root /home/www/web126.com; #网站根目录 include location.conf; #调用其他规则,也可去除 } server { listen 80; server_name msn.web126.com; #绑定域名 index index.htm index.html index.php; #默许文件 root /home/www/msn.web126.com; #网站根目录 include location.conf; #调用其他规则,也可去除 }
3、不带www的域名加301跳转
如果不带www的域名要加301跳转,那也是和绑定域名1样,先绑定不带www的域名,只是不用写网站目录,而是进行301跳转,如:
server { listen 80; server_name web126.com; rewrite ^/(.*) http://www.web126.com/$1 permanent; }
4、添加404网页
添加404网页,都可又直接在里面添加,如:
server { listen 80; server_name www.web126.com; #绑定域名 index index.htm index.html index.php; #默许文件 root /home/www/web126.com; #网站根目录 include location.conf; #调用其他规则,也可去除 error_page 404 /404.html; }
最后还有1个方法需要注意,可能有需要制止IP直接访问80端口或制止非本站的域名绑定我们的IP,这样的话应当
以下处理,放到最前1个server上面便可:
server{ listen 80 default; server_name _; return 403; }
学会上面4种规则方法,基本就能够自己独立解决nginx 多域名配置问题了。
生活不易,码农辛苦
如果您觉得本网站对您的学习有所帮助,可以手机扫描二维码进行捐赠