Ngixn动静分离详细配置方法

Ngixn动静分离详细配置方法目录前言:准备工作一.静态主机配置二.动态主机配置三.动静分离配置四.配置文件目录结构五.测试前言:  为了加快网站的解析速度,可以把动态页面和静态页面由不同的服务器来解析,加快解析速度。降低原来单个服务器的压力。在动静分离的tomcat的时候比较明显,因为tomcat解析静态很慢,其实这些原理的话都很好理解,简单来说,使用正则表达式匹配过滤,然后交给不同的服务器。  静态页面一般直接由Nginx来处理,动态页面则是通过反向代理,代理到后端的Tomcat,然后在做负载均衡,是选择本地静态页面,还是后

大家好,又见面了,我是你们的朋友全栈君。

前言:

  为了加快网站的解析速度,可以把动态页面和静态页面由不同的服务器来解析,加快解析速度。降低原来单个服务器的压力。 在动静分离的tomcat的时候比较明显,因为tomcat解析静态很慢,其实这些原理的话都很好理解,简单来说,使用正则表达式匹配过滤,然后交给不同的服务器。
  静态页面一般直接由Nginx来处理,动态页面则是通过反向代理,代理到后端的Tomcat,然后在做负载均衡,是选择本地静态页面,还是后端Tomcat,这由负载均衡配置决定。
  动静分离是在负载均衡后做的,例如静态wbe有多台,动态web有多台,先动静分离,然后在各自集群里做负载均衡、权重等。
在这里插入图片描述


准备工作

系统:Centos7
Nginx版本: 1.18.0
地址:10.8.161.75
测试机系统:win10
地址:10.8.161.61(同一局域网)
Nginx代理主机端口:80
静态主机端口:91、92、93、94、95
动态主机端口:96、97


一.静态主机配置

  1. server1配置如下 , 其他四台配置类似
vim /etc/nginx/conf.d/server1.conf  # 在子配置文件中创建第一台配置
### 配置如下 ###
server { 
   
        listen       91;     #定义端口为 91 端口,其他四台静态主机更换端口
        server_name  10.8.161.75;
        location / { 
   
                  root   /var/www/nginx/server1;   # 指定网页目录,其他四台静态主机自定义更换
                  index  index.html index.htm;     # 指定访问的网页,其他四台静态主机自定义更换
                  limit_rate  2k;                                                                                                       
                 }
     }

  1. 创建server1网页 , 其他四台配置类似
   vim /var/www/nginx/server1/index.html   # 配置文件中指定的目录
   
   ### 内容如下 ###
   111111111111
   

二.动态主机配置

  1. 安装PHP7.1
### 添加PHP 7.1 yum源 ###
rpm -Uvh https://mirror.webtatic.com/yum/el7/epel-release.rpm
### 添加PHP 升级源 ###
rpm -Uvh https://mirror.webtatic.com/yum/el7/webtatic-release.rpm
### yum安装PHP和运行的环境 ###
yum install php71w-xsl php71w php71w-ldap php71w-cli php71w-common php71w-devel php71w-gd php71w-pdo php71w-mysql php71w-mbstring php71w-bcmath php71w-mcrypt -y

  1. 启动php服务,并设置开机自启
systemctl start php-fpm
systemctl enable php-fpm
  1. 创建动态主机配置,已php1为例,另一台配置类似
    ①主机配置文件
vim  /etc/nginx/conf.d/php.conf
server { 
   
        listen      96;
        server_name     localhost;
        location ~ \.php$ { 
   
                    root          /var/www/nginx/php;  #指定动态网站目录
                    fastcgi_pass   127.0.0.1:9000;    #指定访问地址
                    fastcgi_index  index.php;       #指定默认文件
                    fastcgi_param  SCRIPT_FILENAME  $document_root$fastcgi_script_name;  #站点根目录,取决于root配置项
                    include        fastcgi_params;  #包含nginx常量定义
                        }
}

②创建php1网页 , 另外一台配置类似

 vim /var/www/nginx/php/index.php   #根据动态主机1指定的配置文件指定的目录和主页创建
### 内容如下 ### 
phphphphphphphp

三.动静分离配置

upstream jing { 
                       #设置静态主机池
    # ip_hash; #负载均衡算法,不添加默认是轮询状态
        server 10.8.161.75:91;     #指定静态主机
        server 10.8.161.75:92;    
        server 10.8.161.75:93;
        server 10.8.161.75:94;
        server 10.8.161.75:95;
}
 
upstream dong { 
                     #设置动态主机池
    # ip_hash; #负载均衡算法,不添加默认是轮询状态 
        server 10.8.161.75:96;   #指定动态主机
        server 10.8.161.75:97;
}

server { 
                            #代理主机配置
        listen 80;               #开启80端口 ,检查其他80端口,不要与其冲突
        server_name localhost;   #指定本机
        #动态主机 
        location ~ \.(php|jsp)$ { 
                                        # 使用正则匹配网页后缀,如果是动态页面,跳转到动态主机池下去寻找主机 
               proxy_pass  http://dong;                               # 指定动态主机池
             # proxy_set_header Host $http_host; # 真实服务器的地址,可以是ip也可以是域名和url地址
             # proxy_set_header X-Real-IP $remote_addr; # 启用客户端真实地址(否则日志中显示的是代理在访问网站)
             # proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for; # 记录代理地址
             # proxy_connect_timeout 30; # 后端服务器连接的超时时间发起三次握手等候响应超时时间
             # proxy_send_timeout 60; # 后端服务器数据回传时间,就是在规定时间之内后端服务器必须传完所有的数据
             # proxy_read_timeout 60; # nginx接收upstream(上游/真实) server数据超时, 默认60s, 如果连续的60s内没有收到1个字节, 连接关闭。像长连接
                }
        #静态主机
          location  ~ .*\.(html|gif|jpg|png|bmp|swf|css|js)$  { 
          # 使用正则匹配网页后缀,如果是静态页面,跳转到静态主机池下去寻找主机 
               proxy_pass  http://jing;                               # 指定静态主机池
             # proxy_set_header Host $http_host; # 真实服务器的地址,可以是ip也可以是域名和url地址
             # proxy_set_header X-Real-IP $remote_addr; # 启用客户端真实地址(否则日志中显示的是代理在访问网站)
             # proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for; # 记录代理地址
             # proxy_connect_timeout 30; # 后端服务器连接的超时时间发起三次握手等候响应超时时间
             # proxy_send_timeout 60; # 后端服务器数据回传时间,就是在规定时间之内后端服务器必须传完所有的数据
             # proxy_read_timeout 60; # nginx接收upstream(上游/真实) server数据超时, 默认60s, 如果连续的60s内没有收到1个字节, 连接关闭。像长连接
        }
}



四.配置文件目录结构

  1. 所有配置文件目录结构
    在这里插入图片描述

  2. 所有网页目录结构
    在这里插入图片描述


五.测试

  1. 当访问静态页面时
    在这里插入图片描述

  2. 当访问动态页面时
    在这里插入图片描述

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。

发布者:全栈程序员-用户IM,转载请注明出处:https://javaforall.cn/136874.html原文链接:https://javaforall.cn

【正版授权,激活自己账号】: Jetbrains全家桶Ide使用,1年售后保障,每天仅需1毛

【官方授权 正版激活】: 官方授权 正版激活 支持Jetbrains家族下所有IDE 使用个人JB账号...

(0)
blank

相关推荐

  • 硬件工程师成长之路(9)——检测标准

    硬件工程师成长之路(9)——检测标准系列文章目录1.元件基础2.电路设计3.PCB设计4.元件焊接6.程序设计文章目录前言一、防爆认证前言送给大学毕业后找不到奋斗方向的你(每周不定时更新)嵌入式系统设计师考试一、防爆认证详细资料………………

  • 因果图-判定表法

    因果图-判定表法一、应用场合界面中有多个控件,控件之间存在组合和限制关系,不同输入条件组合会对应不同的输出结果,为了理清每种输入条件组合和输出结果之间的对应关系,可以使用因果图/判定表法。注意:因果图/判定表法适合测试组合数量较少的情况,如果组合数量较多时,适合使用正交排列法。(更高效)二、因果图法基础1、因果图法因:输入条件果:输出结果因果图法:用画图的方式表示输入条件(因)和输出结果(果)之间的关系。2、图形符号(了解)…

  • JavaScript(1)高阶函数filter、map、reduce「建议收藏」

    JavaScript(1)高阶函数filter、map、reduce「建议收藏」前言需求:有这样一个数组[10,20,110,200,60,30,40]1.筛选出数组中小于100的元素2.将筛选出的每个元素的值x23.完成第2步之后,将数组中的所有元素加起来

  • idea 设置黑色或白色背景以及图片背景

    idea 设置黑色或白色背景以及图片背景idea编辑软件在怎么设置黑色或者白色背景点击File–>setting(或者Ctrl+Alt+S)–>Editor–> Color scheme–>General 选择好风格之后,Apply–>OK 最后弹框中点击Yes即可。————————————————–…

  • 花一天时间做一个高质量飞机大战游戏,过万字Unity完整教程!漂亮学妹看了直呼666!

    花一天时间做一个高质量飞机大战游戏,过万字Unity完整教程!漂亮学妹看了直呼666!Unity制作飞机大战。本篇文章完整的介绍了使用Unity引擎制作一个飞机大战的小游戏,附带游戏过程,截图和讲解,最后附带工程源码,请品尝!

  • ARM Linux ELF加壳方案

    ARM Linux ELF加壳方案随着移动应用和IoT设备的普及,大量的硬件抛弃了传统的x86架构,选择使用能耗低、性价比高的ARM芯片,ARM指令级渐渐成为主流,但随之而来的,是愈发严峻的安全问题。早期的加壳产品主要利用压缩加密技术对文件进行整体性保护,但随着逆向技术的提升,整体性的文件保护方案已经被攻克,于是加壳产品引入虚拟机概念,可以实现函数级的代码控制流保护,加密的颗粒度更加细致,激活成功教程难度呈几何级增加。压缩加密技术原理类似桌面应用的「压缩壳」,将SO文件中的代码段压缩或加密,在入口函数中解密再执行。这种保护方式可

    2022年10月11日

发表回复

您的电子邮箱地址不会被公开。

关注全栈程序员社区公众号