赞
踩
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)微服务网关入口:实现对服务转发,根据域名路由到真实的服务
server{
listen 80;
server_name localhost;
location /{
proxy_pass 代理的服务器IP+端口号;
index index.html index.htm;
}
}
# 定义上游服务器(需要被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)weight(权重):指定轮询的概率,weight和访问比率成正比,用于后端服务器性能不均的情况
(3)ip_hash:每个请求按访问的ip的hash值进行分配服务器,这样每一个用户固定的访问一个后端服务器,这样可以解决session的问题。
1. 分布式session一致性问题,可以使用spring-session框架或者token替代
2. 分布式日志收集问题,使用elk+kafka做日志收集
3. 分布式任务调度重复执行,采用分布式任务调度平台xxl-job
分布式事务和节点集群没有关系
软负载是基于服务器上安装的软件,比如nginx实现负载均衡 硬负载是基于固定的硬件实现负载均衡,比如F5
Copyright © 2003-2013 www.wpsshop.cn 版权所有,并保留所有权利。