Nginx反向代理与负载均衡

1、正向代理
隐藏用户行为
2、反向代理
隐藏真实的服务器
3、DNS域名解析的过程
(1)先从本地的host文件中使用域名获取对应的ip地址(C:\Windows\System32\drivers\etc)
(2)如果本地的host文件中没有的话,就去运行商获取IP地址
4、Nginx实际应用场景
(1)反向代理:客户端使用Nginx转到真实的服务器访问,从而保证真实服务安全性
(2)负载均衡:减轻高并发的情况下对服务器造成的压力
(3)静态服务器:比tomcat性能高很多,可以存放静态资源
(4)保护网站:Nginx+lua实现对请求的限流、熔断、防止dos攻击
(5)微服务网关入口:实现对服务转发,根据域名路由到真实的服务

基于Nginx实现反向代理(使用proxy_pass)
server{
    listen 80;
    server_name localhost;
    location /{
        proxy_pass 代理的服务器IP+端口号;
        index index.html index.htm;
    }
}
基于Nginx实现负载均衡(使用upstream)
# 定义上游服务器(需要被Nginx真实代理访问的服务器)
upstream backServer{
    server 127.0.0.1:8080;
    server 127.0.0.1:8081;
    # 默认是轮询
    # server 127.0.0.1:8080 weight=2;# 权重
}
server{
    listen 80;
    # url地址栏中的地址
    server_name www.mayikt.com;
    location / {
        # 指定上游服务器
        proxy_pass http://backServer;
        index index.html index.htm;
    }
}
nginx的upstream目前支持四种方式的支配

(1)轮询(默认):每个请求按照时间的顺序,逐一的分配到不同的后端服务器,如果后端的服务器挂掉,能自动的提出。
(2)weight(权重):指定轮询的概率,weight和访问比率成正比,用于后端服务器性能不均的情况
(3)ip_hash:每个请求按访问的ip的hash值进行分配服务器,这样每一个用户固定的访问一个后端服务器,这样可以解决session的问题。

负载均衡的架构思想

在这里插入图片描述

服务器集群中会有那些问题
1. 分布式session一致性问题,可以使用spring-session框架或者token替代
2. 分布式日志收集问题,使用elk+kafka做日志收集
3. 分布式任务调度重复执行,采用分布式任务调度平台xxl-job

分布式事务和节点集群没有关系

软负载与硬负载之间的区别

软负载是基于服务器上安装的软件,比如nginx实现负载均衡 硬负载是基于固定的硬件实现负载均衡,比如F5

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值