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