当前位置:   article > 正文

Nginx反向代理与负载均衡_nginx 转发kafka

nginx 转发kafka

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;
    }
}
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
基于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;
    }
}
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
  • 14
  • 15
  • 16
  • 17
nginx的upstream目前支持四种方式的支配

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

负载均衡的架构思想

在这里插入图片描述

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

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

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

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

声明:本文内容由网友自发贡献,转载请注明出处:【wpsshop】
推荐阅读
相关标签
  

闽ICP备14008679号