对于大多数网站,都是由区分移动端页面,PC端页面,对于用户不同的客户端设备,返回不同的页网站页面。
因此,为了让用户有更好的访问体验,就需要在服务器后端设立不同的服务器来满足不同的客户端访问。
那么如何实现该方案呢
基于4层负载均衡的转发
四层转发就是IP+PORT的形式转发
在常规的4层负载均衡架构下,可以使用不同的域名来实现该需求,例如
人为分配,让移动端用户访问m.chaoge.com
PC端用户访问www.chaoge.com
通过不同的域名来引导用户访问指定的后端服务器
但是这样的形式,用户需要记住不同的域名,用户肯定是不乐意的,体验较差
基于7层的负载均衡
在7层负载均衡下就不需要人为拆分域名了,移动端、PC端只需要一个www.chaoge.com域名即可。
方法就是通过获取用户请求中的客户端信息(来自于哪个浏览器,手机、ipad等等客户端),是通过$http_user_agent获取,根据该变量获取到的用户客户端信息,再决定交给哪一个后端服务器去处理。
这是企业常用的解决方案。
补充:location修饰符解释
= 表示精确匹配。只有请求的url路径与后面的字符串完全相等时,才会命中。
~ 表示该规则是使用正则定义的,区分大小写。
~* 表示该规则是使用正则定义的,不区分大小写。
^~ 表示如果该符号后面的字符是最佳匹配,采用该规则,不再进行后续的查找。
#利用shell语句进行逻辑判断
location / {
#这里进行浏览器判断
if ($http_user_agent ~* "MSIE")
{
proxy_pass http://static_pools;
}
if ($http_user_agent ~* "Chrome")
{
proxy_pass http://upload_pools;
}
if ($http_user_agent ~* "Safari")
{
proxy_pass http://static_pools;
}
proxy_pass http://default_pools;
include proxy.conf;
}
Nginx实际配置
1.修改lb01的nginx.conf文件
[root@lb01 ~]# cat /opt/nginx/conf/nginx.conf
#user nobody;
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 {
worker_connections 1024;
}
http {
include mime.types;
default_type application/octet-stream;
# upstream my_pools {
# server 192.168.178.124 weight=1;
# server 192.168.178.125 weight=1;
#}
upstream static_pools {
server 192.168.178.124 weight=1;
}
upstream upload_pools {
server 192.168.178.125 weight=1;
}
upstream default_pools {
server 192.168.178.127 weight=1;
}
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;
sendfile on;
#tcp_nopush on;
#keepalive_timeout 0;
keepalive_timeout 65;
#gzip on;
server {
listen 80;
server_name www.chaoge.com;
default_type application/octet-stream;
#charset koi8-r;
#access_log logs/host.access.log main;
location / {
if ($http_user_agent ~* "MSIE")
{
proxy_pass http://static_pools;
}
if ($http_user_agent ~* "Chrome")
{
#proxy_pass http://upload_pools;
return 401;
}
if ($http_user_agent ~* "Safari")
{
#proxy_pass http://static_pools;
return 402;
}
proxy_pass http://default_pools;
include proxy.conf;
}
#error_page 404 /404.html;
# redirect server error pages to the static page /50x.html
#
error_page 500 502 503 504 /50x.html;
location = /50x.html {
root html;
}
}
}
2.检测nginx语法,重启nginx
[root@lb01 conf]# nginx -t
[root@lb01 conf]# nginx -s reload
3.查看实际转发效果
像谷歌浏览器、360浏览器之类的Chrome内核的浏览器,访问结果是401
像IE浏览器等其他内核,则匹配到了默认的http://default_pools