面试题总结
其它面试题(springboot、mybatis、并发、java中高级面试总结等)
具体流程
图片
修改之前
图片
配置
图片
再次访问
图片
反向代理2
1.目标
-
访问http://192.168.25.132:9001/edu/ 直接跳转到192.168.25.132:8080
-
访问http://192.168.25.132:9001/vod/ 直接跳转到192.168.25.132:8081
2.准备
配置两个tomcat,端口分别为8080和8081,都可以访问,端口修改配置文件即可。
图片
新建文件内容分别添加8080!!!和8081!!!
图片
图片
响应如下
图片
3.具体配置
图片
重新加载nginx
./nginx -s reload
访问
图片
图片
实现了同一个端口代理,通过edu和vod路径的切换显示不同的页面
4.2 反向代理小结
第一个例子:
浏览器访问www.123.com,由host文件解析出服务器ip地址
192.168.25.132 www.123.com
然后默认访问80端口,而通过nginx监听80端口代理到本地的8080端口上,从而实现了访问www.123.com,最终转发到tomcat 8080上去
第二个例子:
-
访问http://192.168.25.132:9001/edu/ 直接跳转到192.168.25.132:8080
-
访问http://192.168.25.132:9001/vod/ 直接跳转到192.168.25.132:8081
实际上就是通过nginx监听9001端口,然后通过正则表达式选择转发到8080还是8081的tomcat上去
4.3 负载均衡实战
1.修改nginx.conf
图片
图片
2.重启nginx
./nginx -s reload
3.在8081的tomcat的webapps文件夹下新建edu文件夹和a.html文件,填写内容为8081!!!!
4.在地址栏回车,就会分发到不同的tomcat服务器上
图片
图片
5.负载均衡方式
-
轮询(默认)
-
weight,代表权,权越高优先级越高
图片
- fair,按后端服务器的响应时间来分配请求,相应时间短的优先分配
图片
- ip_hash,每个请求按照访问ip的hash结果分配,这样每一个访客固定的访问一个后端服务器,可以解决session 的问题
图片
4.4 动静分离实战
什么是动静分离
把动态请求和静态请求分开,不是讲动态页面和静态页面物理分离,可以理解为nginx处理静态页面,tomcat处理动态页面
动静分离大致分为两种:
一、纯粹将静态文件独立成单独域名放在独立的服务器上,也是目前主流方案;
二、将动态跟静态文件混合在一起发布,通过nginx分开
动静分离图析
实战准备
准备静态文件
图片
图片
配置nginx
图片
5.nginx高可用
==========
如果nginx出现问题
图片
解决办法
图片
前期准备
-
两台nginx服务器
-
安装keepalived
-
虚拟ip
5.1安装keepalived
[root@192 usr]# yum install keepalived -y
[root@192 usr]# rpm -q -a keepalived
keepalived-1.3.5-16.el7.x86_64
修改配置文件
[root@192 keepalived]# cd /etc/keepalived
[root@192 keepalived]# vi keepalived.conf
分别将如下配置文件复制粘贴,覆盖掉keepalived.conf
虚拟ip为192.168.25.50
对应主机ip需要修改的是
smtp_server 192.168.25.147(主)smtp_server 192.168.25.147(备)
state MASTER(主) state BACKUP(备)
global_defs {
notification_email {
acassen@firewall.loc
failover@firewall.loc
sysadmin@firewall.loc
}
notification_email_from Alexandre.Cassen@firewall.loc
smtp_server 192.168.25.147
smtp_connect_timeout 30
router_id LVS_DEVEL # 访问的主机地址
}
vrrp_script chk_nginx {
script “/usr/local/src/nginx_check.sh” # 检测文件的地址
interval 2 # 检测脚本执行的间隔
weight 2 # 权重
}
vrrp_instance VI_1 {
state BACKUP # 主机MASTER、备机BACKUP
interface ens33 # 网卡
virtual_router_id 51 # 同一组需一致
priority 90 # 访问优先级,主机值较大,备机较小
advert_int 1
authentication {
auth_type PASS
auth_pass 1111
}
virtual_ipaddress {
192.168.25.50 # 虚拟ip
}
}
启动
[root@192 sbin]# systemctl start keepalived.service
图片
访问虚拟ip成功
图片
关闭主机147的nginx和keepalived,发现仍然可以访问
6.原理解析
======
图片
如下图,就是启动了一个master,一个worker,master是管理员,worker是具体工作的进程
图片
worker如何工作
架构学习资料
由于篇幅限制小编,pdf文档的详解资料太全面,细节内容实在太多啦,所以只把部分知识点截图出来粗略的介绍,每个小节点里面都有更细化的内容!
d8b264f627c8.png)
图片
worker如何工作
架构学习资料
[外链图片转存中…(img-UQizcl1s-1715004218153)]
[外链图片转存中…(img-6r2Lo7C4-1715004218153)]
[外链图片转存中…(img-WSUJHh9S-1715004218154)]
[外链图片转存中…(img-5qlbJXAS-1715004218154)]
[外链图片转存中…(img-lnP5Zh7g-1715004218154)]
由于篇幅限制小编,pdf文档的详解资料太全面,细节内容实在太多啦,所以只把部分知识点截图出来粗略的介绍,每个小节点里面都有更细化的内容!