【Nginx 开发】反向代理配置,负载均衡配置,动静分离配置

2024-05-05 06:52

本文主要是介绍【Nginx 开发】反向代理配置,负载均衡配置,动静分离配置,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

nginx 配置

  • 反向代理
  • 配置负载均衡
  • 配置动静分离

反向代理

我们根据实例进行讲解,效果是通过在浏览器访问www.hlh.com,跳转到Linux系统的tomcat主页面中

第一步:在windows系统的host文件进行域名和ip对应关系的配置
在host文件中添加自己的地址映射
192.168.175.111 www.hlh.com

第二步:在nginx进行请求转发的配置(反向代理的配置)

    server {listen       80;server_name  192.168.75.135;#charset koi8-r;#access_log  logs/host.access.log  main;location / {root   html;proxy_pass http://127.0.0.1:8080;index  index.html index.htm;}

我们还可以及进行通过不同的访问路径进入到不同的tomcat服务器中
例如:访问http://127.0.0.1:9001/edu/,直接跳转到,127.0.0.1:8081
访问 http://127.0.0.1:9001/vod/,直接跳转到127.0.0.1:8082
仍然在配置文件中进行配置:

server{listen 9001;server_name localhost;location ~ /edu/ {proxy_pass http://localhost:8001;}location ~ /vod/ {proxy_pass http://localhost:8002; }
}
  • location后的符号表达
    =:用于不含正则表达式的url前,要求请求字符串与url严格匹配,如果匹配成功,就挺停止继续向下的搜索并立即处理该请求
    ~:用于表示url包含正则表达式,并且区分大小写
    ~*:用于表示url包含正则表达式,并且不区分大小写
    ^~:用于不含正则表达式的url前,要求Nginx 服务器找到表示url和请求字符串匹配度最高的location后,立即使用此location处理请求,而不再使用location块中的正则url和请求字符串做匹配

配置负载均衡

访问同一个地址分配到不同的tomcat端口

http{upstream myserver{server 192.168.75.135:8080;server 192.168.75.135:8081 ;}server{location /{proxy_pass http://myserver;}}
}
  • 复杂均衡的分配方式
  1. 轮询:每个请求按时间顺序逐一分配到不同的后端服务器,如果后端服务器down掉,能够自动剔除
  2. weight:代表权,默认为1,权重越高被分配的客户端越多
http{upstream myserver{server 192.168.75.135:8080 weight=1;server 192.168.75.135:8081 weight=1;}server{location /{proxy_pass http://myserver;}}
}
  1. ip_hash:每个请求按访问ip的hash结果分配,这样每个访客固定访问一个后端服务器,可以解决session问题
http{upstream myserver{ip_hashserver 192.168.75.135:8080;server 192.168.75.135:8081;}server{location /{proxy_pass http://myserver;}}
}
  1. fair(第三方):按照服务器的响应时间来分配,访问时间短的先行进行分配
http{upstream myserver{server 192.168.75.135:8080;server 192.168.75.135:8081;fair;}server{location /{proxy_pass http://myserver;}}
}

配置动静分离

动静分离目前的两种方式:

  1. 把静态文件独立成单独的域名,放在独立的服务器上(目前的主流)
  2. 动态跟静态文件混合在一起发布,通过nginx来分开

举例访问/www/image时访问nginx本地的静态资源

http{server{location /www/{root /data/;index index.html}location /image/{root /data/;autoindex on;}}
}

root 跟的是在nginx中静态资源所在的目录
autoindex on:表示展示的时候列出目录中所有的文件

这篇关于【Nginx 开发】反向代理配置,负载均衡配置,动静分离配置的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/961056

相关文章

Linux 安装、配置Tomcat 的HTTPS

Linux 安装 、配置Tomcat的HTTPS 安装Tomcat 这里选择的是 tomcat 10.X ,需要Java 11及更高版本 Binary Distributions ->Core->选择 tar.gz包 下载、上传到内网服务器 /opt 目录tar -xzf 解压将解压的根目录改名为 tomat-10 并移动到 /opt 下, 形成个人习惯的路径 /opt/tomcat-10

uniapp接入微信小程序原生代码配置方案(优化版)

uniapp项目需要把微信小程序原生语法的功能代码嵌套过来,无需把原生代码转换为uniapp,可以配置拷贝的方式集成过来 1、拷贝代码包到src目录 2、vue.config.js中配置原生代码包直接拷贝到编译目录中 3、pages.json中配置分包目录,原生入口组件的路径 4、manifest.json中配置分包,使用原生组件 5、需要把原生代码包里的页面修改成组件的方

IDEA配置Tomcat远程调试

因为不想把本地的Tomcat配置改乱或者多人开发项目想测试,本文主要是记录一下,IDEA使用Tomcat远程调试的配置过程,免得一段时间不去配置到时候忘记(毕竟这次是因为忘了,所以才打算记录的…) 首先在catalina.sh添加以下内容 JAVA_OPTS="-Dcom.sun.management.jmxremote=-Dcom.sun.management.jmxremote.port

Eclipse+ADT与Android Studio开发的区别

下文的EA指Eclipse+ADT,AS就是指Android Studio。 就编写界面布局来说AS可以边开发边预览(所见即所得,以及多个屏幕预览),这个优势比较大。AS运行时占的内存比EA的要小。AS创建项目时要创建gradle项目框架,so,创建项目时AS比较慢。android studio基于gradle构建项目,你无法同时集中管理和维护多个项目的源码,而eclipse ADT可以同时打开

人工智能机器学习算法总结神经网络算法(前向及反向传播)

1.定义,意义和优缺点 定义: 神经网络算法是一种模仿人类大脑神经元之间连接方式的机器学习算法。通过多层神经元的组合和激活函数的非线性转换,神经网络能够学习数据的特征和模式,实现对复杂数据的建模和预测。(我们可以借助人类的神经元模型来更好的帮助我们理解该算法的本质,不过这里需要说明的是,虽然名字是神经网络,并且结构等等也是借鉴了神经网络,但其原型以及算法本质上还和生物层面的神经网络运行原理存在

Python应用开发——30天学习Streamlit Python包进行APP的构建(9)

st.area_chart 显示区域图。 这是围绕 st.altair_chart 的语法糖。主要区别在于该命令使用数据自身的列和指数来计算图表的 Altair 规格。因此,在许多 "只需绘制此图 "的情况下,该命令更易于使用,但可定制性较差。 如果 st.area_chart 无法正确猜测数据规格,请尝试使用 st.altair_chart 指定所需的图表。 Function signa

Steam邮件推送内容有哪些?配置教程详解!

Steam邮件推送功能是否安全?如何个性化邮件推送内容? Steam作为全球最大的数字游戏分发平台之一,不仅提供了海量的游戏资源,还通过邮件推送为用户提供最新的游戏信息、促销活动和个性化推荐。AokSend将详细介绍Steam邮件推送的主要内容。 Steam邮件推送:促销优惠 每当平台举办大型促销活动,如夏季促销、冬季促销、黑色星期五等,用户都会收到邮件通知。这些邮件详细列出了打折游戏、

微信小程序开发必知必会:文件结构和基本配置

一、微信小程序基本文件结构 1.  project.config.json:项目的基本配置文件,包括项目名称、appid、项目目录、页面文件夹等。     {"setting": {"urlCheck": false,"es6": true,"postcss": true,"nodeModulesPath": "D:\\\\node_modules"},"appid": "wxd678e

【杂记-浅谈DHCP动态主机配置协议】

DHCP动态主机配置协议 一、DHCP概述1、定义2、作用3、报文类型 二、DHCP的工作原理三、DHCP服务器的配置和管理 一、DHCP概述 1、定义 DHCP,Dynamic Host Configuration Protocol,动态主机配置协议,是一种网络协议,主要用于在IP网络中自动分配和管理IP地址以及其他网络配置参数。 2、作用 DHCP允许计算机和其他设备通

Pycharm配置conda环境(解决新版本无法识别可执行文件问题)

引言: 很多小伙伴在下载最新版本的pycharm或者更新到最新版本后为项目配置conda环境的时候,发现文件夹目录中无法显示可执行文件(一般为python.exe),以下就是本人遇到该问题后试验和解决该问题的一些方法和思路。 一般遇到该问题的人群有两种,一种是刚入门对pycharm进行conda环境配置的小白(例如我),不熟悉相关环境配置的操作和过程,还有一种是入坑pycharm有段时间的老手