nginx配置,同一个端口对应移动端与pc端

依靠设备浏览器区分:

1、传递请求头

最终目的是要使用UserAgent头识别用户的客户端,然后返回不同的内容给不同的UA用户。而CDN(内容分发网络)缓存并不会区分UA(UserAgent),只会区分URL(访问的地址),所以在访问同样的域名和端口时,缓存的内容是一样的。CDN支持对不同的UA来设置不同的缓存,根据vary头来控制,它的字段一般是头信息的字段。

CDN监测vary头的信息,如果内容不一致就缓存不同的内容,如果头信息一致才会缓存覆盖

vary头需要在源站添加,即在nginx中配置代理时进行添加,配置语句如下:

javascript 复制代码
add_header Vary "Accept-Encoding, User-Agent";

2、根据头信息区分跳转

已经携带了请求头,对头信息的终端类型进行判断即可,如果符合终端类型则跳转到手机页面,不符合则跳转到PC页面

javascript 复制代码
if ($http_user_agent ~* (mobile|nokia|iphone|ipad|android|samsung|htc|blackberry|iPhone|Android))  {
      root /xxxxxx;
}

要在同一个端口上区分移动端和PC端的请求,并对它们进行不同的配置,你可以在Nginx配置文件中使用ngx_http_mobile_detect_module模块或者通过检查User-Agent头来进行区分。以下是一个基本的配置示例:

javascript 复制代码
	upstream merchantsweb{
			 server 172.xx.x.xxx:8096 weight=20;
        }
    upstream merchantswebapp{
			 server 172.xx.x.xxx:8094 weight=20;
        } 
server {
      listen       80;
      server_name  www.xxxxxx.com;
      location / {
            add_header Vary "Accept-Encoding, User-Agent";
            #判断是否为手机端
            if ($http_user_agent ~* (mobile|nokia|iphone|ipad|android|samsung|htc|blackberry|iPhone|Android))  {
            	  #移动端对应文件
                  proxy_pass http://merchantswebapp;
            }
            #PC端对应文件
            proxy_pass http://merchantsweb;
            index  index.html index.htm;  
      }   
}
相关推荐
航Hang*3 分钟前
VMware vSphere 云平台运维与管理基础——第2章(扩展):VMware ESXi 5.5 安装、配置与运维
运维·服务器·github·系统安全·虚拟化
SPC的存折19 分钟前
MySQL 8组复制完全指南
linux·运维·服务器·数据库·mysql
运维行者_20 分钟前
OpManager MSP NetFlow Analyzer集成解决方案,应对多客户端网络流量监控挑战
大数据·运维·服务器·网络·数据库·自动化·运维开发
sszdzq37 分钟前
docker 安装 doris
运维·docker·容器
dashizhi20152 小时前
共享文件禁止拖动本地磁盘、共享文件禁止另存为、禁止打印共享文件、禁止复制共享文件的方法
运维·服务器·网络·安全·电脑
IMPYLH2 小时前
Linux 的 nproc 命令
linux·运维·服务器·bash
AC赳赳老秦3 小时前
OpenClaw email技能:批量发送邮件、自动回复,高效处理工作邮件
运维·人工智能·python·django·自动化·deepseek·openclaw
海的透彻3 小时前
docker容器进程探究
运维·docker·容器
大强同学3 小时前
Obsidian 日记:从模板到 Dataview 自动化
运维·自动化
陌陌卡上3 小时前
我在 Debian 11 上把 K8s 单机搭起来了,过程没你想的那么顺(/opt 目录版)
运维·k8s·系统·debian11