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如何工作
小结
- worker数应该和CPU数相等
- 一个master多个worker可以使用热部署,同时worker是独立的,一个挂了不会影响其他的