当前位置: 首页 > news >正文

昌邑网站制作新闻网最新消息

昌邑网站制作,新闻网最新消息,眼镜网站模板,WordPress给编辑器目录 实现负载均衡 实现高可用 实现负载均衡 Nginx的几种负载均衡算法: 1.轮询(默认) 每个请求按照时间顺序逐一分配到下游的服务节点,如果其中某一节点故障,nginx 会自动剔除故障系统使用户使用不受影响。 2.权重…

目录

实现负载均衡

实现高可用


 

实现负载均衡

Nginx的几种负载均衡算法:

  • 1.轮询(默认) 每个请求按照时间顺序逐一分配到下游的服务节点,如果其中某一节点故障,nginx 会自动剔除故障系统使用户使用不受影响。

  • 2.权重(weight) 在配置文件中对下游的服务节点指定权重值 weight, weight 值越大则被分配的评率越高,一般这种负载均衡,用于节点的配置情况不一样,有的可能配置高,有的配置低。

  • 3.ip_hash 对每个请求,针对 ip 进行 hash, 然后分配到后台节点,这样一来,同一 ip 会被固定分配到下游固定服务上。它能够暂时的解决集群环境中容器之间 session 共享的问题(因为session每次只能和一个人,一对一的记录,但是如果现在需要负载均衡就出现了一种一对多的情况,可以使用ip_hash实现一对一),但是不是解决的根本之道,只是权宜之策,我们试想,如果访问的好好的,家里的路由器被重启了,或者运营商分配给你的 ip 地址改变了,那么你再次访问的时候,新的 ip 就可能被分配到新的服务上,之前的 session 也就失效了。

  • 4.least_conn (最少连接调度算法) 最少连接调度算法,对下游服务中连接情况,优先选择连接数最少的服务分配。

  • 5.least_time (最小响应时间) 最小响应时间, 计算节点平均响应时间,然后取响应最快的那个,分配更高权重。

(1)首先我们一共需要三个主机

后端的两个主机用于apache服务:

window10:192.168.159.165kail:192.168.159.151

负载均衡设备nginx:

centos1:192.168.159.200

(2)配置window10

开启apache服务

新建一个网页并且编辑内容:

新建的网页:www/index.html
内容:
Hello My Ip add 192.168.159.165

访问结果

343bb77cca6047cdba3ce8d7daeeb5d9.png

(2)配置kail

开启apache服务

新建一个网页并且编辑内容:

网页地址:/var/html/index.html
网页内容:
Hello My Ip add 192.168.159.165

访问结果

c09e813555bd4a73865f1b368705808c.png

(3)nginx设备配置

进入 /etc/nginx/nginx.conf

vim /etc/nginx/nginx.conf

配置负载均衡:

upstream nginx_boot{
# 30s内检查心跳发送两次包,未回复就代表该机器宕机,请求分发权重比为1:2   
server 192.168.159.151 weight=100 max_fails=2 fail_timeout=30s;
server 192.168.159.165 weight=100 max_fails=2 fail_timeout=30s;
# 这里的IP请配置成你WEB服务所在的机器IP
}
server {location / {root   html;        # 配置一下index的地址,最后加上index.ftl。        index  index.html index.htm index.jsp index.ftl;proxy_set_header Host $host;proxy_set_header X-Real-IP $remote_addr;proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;# 请求交给名为nginx_boot的upstream上        proxy_pass http://nginx_boot;}location ~ .*.(gif|jpg|jpeg|bmp|png|ico|txt|js|css){root   /usr/local/nginx/html/static;expires 7d;}
}

b4bc45bea37147dcad3015eb76bb59d8.png

现在可以尝试访问:

第一次:

35bc119fc4c6414da600a4b2e84fa3ec.png

第二次:

94495fe2bdaf4d93bc20d9f0ba091bc5.png

不断地尝试可以发现:始终是访问一次165然后再一次151,成功的实现了负载均衡!!!,并且权重和我们设置的也是一样的,当然也可以手动的修改权重

也可以将负载均衡的方式修改为轮询或者上面介绍的其他方式。

实现高可用

线上如果采用单个节点的方式部署Nginx,难免会出现天灾人祸,比如系统异常、程序宕机、服务器断电、机房爆炸、地球毁灭….哈哈哈,夸张了。但实际生产环境中确实存在隐患问题,由于Nginx作为整个系统的网关层接入外部流量,所以一旦Nginx宕机,最终就会导致整个系统不可用,这无疑对于用户的体验感是极差的,因此也得保障Nginx高可用的特性。

接下来则会通过keepalived的VIP机制,实现Nginx的高可用。 VIP并不是只会员的意思,而是指Virtual IP,即虚拟IP。

keepalived在之前单体架构开发时,是一个用的较为频繁的高可用技术,比如MySQL、Redis、MQ、Proxy、Tomcat等各处都会通过keepalived提供的VIP机制,实现单节点应用的高可用。

上面那个实验完成了,但是现在实现了负载均衡但是并没有实现高可用问题

需要实现高可用,那就需要增加一台nginx服务器

这里使用192.168.159.201当做另外一台nginx服务器

实现原理:(类似于VRRP)

  1. 需要在200和201这两台设备上都安装keepalive+nginx的环境

  2. keepLive虚拟出一个VIP

  3. 浏览器通过访问这个VIP来实现高可用

这里以192.168.159.200这台设备为了,下面是具体的过程:

(1)首先配置keepalive

//获取软件包
wget https://www.keepalived.org/software/keepalived-2.2.4.tar.gz
//解压
tar -zxvf keepalived-2.2.4.tar.gz
//进入该目录中后进行预编译
./configure
//编译
make/make install

(2)添加配置文件

vi keepalived.conf

bal_defs {  # 自带的邮件提醒服务,建议用独立的监控或第三方SMTP,也可选择配置邮件发送。notification_email {  root@localhost  }  notification_email_from root@localhost  smtp_server localhost  smtp_connect_timeout 30  # 高可用集群主机身份标识(集群中主机身份标识名称不能重复,建议配置成本机IP)  router_id 192.168.159.200
}  # 定时运行的脚本文件配置  
vrrp_script check_nginx_pid_restart {  # 之前编写的nginx重启脚本的所在位置  script "/soft/scripts/keepalived/check_nginx_pid_restart.sh"   # 每间隔3秒执行一次  interval 3  # 如果脚本中的条件成立,重启一次则权重-20  weight -20  
}  # 定义虚拟路由,VI_1为虚拟路由的标示符(可自定义名称)  
vrrp_instance VI_1 {  # 当前节点的身份标识:用来决定主从(MASTER为主机,BACKUP为从机)  state MASTER  # 绑定虚拟IP的网络接口,根据自己的机器的网卡配置  interface ens33   # 虚拟路由的ID号,主从两个节点设置必须一样  virtual_router_id 250 # 填写本机IP  mcast_src_ip 192.168.159.200  # 节点权重优先级,主节点要比从节点优先级高  priority 100  # 优先级高的设置nopreempt,解决异常恢复后再次抢占造成的脑裂问题  nopreempt  # 组播信息发送间隔,两个节点设置必须一样,默认1s(类似于心跳检测)  advert_int 1  authentication {  auth_type PASS  auth_pass 1111  }  # 将track_script块加入instance配置块  track_script {  # 执行Nginx监控的脚本  check_nginx_pid_restart  }  virtual_ipaddress {  # 虚拟IP(VIP),也可扩展,可配置多个。192.168.159.250  }  
}

(7)编写脚本

vim check_nginx_pid_restart.sh

//脚本内容:
#!/bin/sh  
# 通过ps指令查询后台的nginx进程数,并将其保存在变量nginx_number中  
nginx_number=`ps -C nginx --no-header | wc -l`  
# 判断后台是否还有Nginx进程在运行  
if [ $nginx_number -eq 0 ];then  # 如果后台查询不到`Nginx`进程存在,则执行重启指令  /soft/nginx/sbin/nginx -c /soft/nginx/conf/nginx.conf  # 重启后等待1s后,再次查询后台进程数  sleep 1  # 如果重启后依旧无法查询到nginx进程  if [ `ps -C nginx --no-header | wc -l` -eq 0 ];then  # 将keepalived主机下线,将虚拟IP漂移给从机,从机上线接管Nginx服务  systemctl stop keepalived.service  fi  
fi

(8)为该脚本授权

chmod +x check_nginx_pid_restart.sh

(9)将一些文件拷贝到/etc下

mkdir /etc/keepalived
cp keepalived.conf /etc/keepalived/
cd /root/keepalived/keepalived/etc/init.d
cp keepalived /etc/init.d/
cd ../sysconfig
cp keepalived /etc/sysconfig/

(10)修改配置文件

vim /etc/keepalived/keeplive.conf
//修改后:
bal_defs {  # 自带的邮件提醒服务,建议用独立的监控或第三方SMTP,也可选择配置邮件发送。notification_email {  root@localhost  }  notification_email_from root@localhost  smtp_server localhost  smtp_connect_timeout 30  # 高可用集群主机身份标识(集群中主机身份标识名称不能重复,建议配置成本机IP)  router_id 192.168.159.200
}  # 定时运行的脚本文件配置  
vrrp_script check_nginx_pid_restart {  # 之前编写的nginx重启脚本的所在位置  script "/root//keepalived/keepalived/etc/keepalived/check_nginx_pid_restart.sh"   # 每间隔3秒执行一次  interval 3  # 如果脚本中的条件成立,重启一次则权重-20  weight -20  
}  # 定义虚拟路由,VI_1为虚拟路由的标示符(可自定义名称)  
vrrp_instance VI_1 {  # 当前节点的身份标识:用来决定主从(MASTER为主机,BACKUP为从机)  state MASTER  # 绑定虚拟IP的网络接口,根据自己的机器的网卡配置  interface ens33   # 虚拟路由的ID号,主从两个节点设置必须一样  virtual_router_id 250 # 填写本机IP  mcast_src_ip 192.168.159.200  # 节点权重优先级,主节点要比从节点优先级高  priority 100  # 优先级高的设置nopreempt,解决异常恢复后再次抢占造成的脑裂问题  nopreempt  # 组播信息发送间隔,两个节点设置必须一样,默认1s(类似于心跳检测)  advert_int 1  authentication {  auth_type PASS  auth_pass 1111  }  # 将track_script块加入instance配置块  track_script {  # 执行Nginx监控的脚本  check_nginx_pid_restart  }  virtual_ipaddress {  # 虚拟IP(VIP),也可扩展,可配置多个。192.168.159.250  }  
}

(11)设置开机自启

[root@centos111 keepalived]# chkconfig keepalived on
[root@centos111 keepalived]# systemctl daemon-reload
[root@centos111 keepalived]# systemctl start keepalived.service 
[root@centos111 keepalived]# systemctl enable keepalived.service 

 

fe92cabf462c42358e4d2ea84d67e4fd.png

(12)备服务器配置(201)--大致流程与200相同

这里就不详细演示了

注:从上图中可以明显看见虚拟IP已经成功挂载,但另外一台机器192.168.159.250并不会挂载这个虚拟IP,只有当主机下线后,作为从机的192.168.159.201才会上线,接替VIP。

e2997c477e6047a583a496dab7c0eb91.png

(13)测试

使用kail (192.168.159.151) ping 虚拟ip(192.168.159.250)、

2dd5f3e948c84b3493934a9afef5a4de.png

可以看到成功的ping通了

现在尝试关闭192.168.159.200服务器

nmcli con down ens33

然后再打开该服务器

nmcli con up ens33

查看192.168.159.201服务器

fe0d2d3c073e4641b7ae93338359c9da.png

可以发现192.168.159.250这个虚拟ip已经转到备服务器(192.168.159.201)这里了!

到此Nginx的负载均衡和高可用实验都全部完成!!

 

 


文章转载自:
http://dinnconectared.ssfq.cn
http://dinncopotassa.ssfq.cn
http://dinncoparaphrase.ssfq.cn
http://dinncovirogenic.ssfq.cn
http://dinncocrib.ssfq.cn
http://dinncounrealize.ssfq.cn
http://dinncopalaeoethnobotany.ssfq.cn
http://dinncopromotional.ssfq.cn
http://dinncoheulandite.ssfq.cn
http://dinncomego.ssfq.cn
http://dinncoshorthand.ssfq.cn
http://dinncomirage.ssfq.cn
http://dinncocumulus.ssfq.cn
http://dinncocorelate.ssfq.cn
http://dinncomanx.ssfq.cn
http://dinncomusicianship.ssfq.cn
http://dinncofiltrate.ssfq.cn
http://dinncosuperficiary.ssfq.cn
http://dinncoferromagnesian.ssfq.cn
http://dinncocwar.ssfq.cn
http://dinncoinducer.ssfq.cn
http://dinncomcse.ssfq.cn
http://dinncodonkeywork.ssfq.cn
http://dinncojustinianian.ssfq.cn
http://dinncosiquis.ssfq.cn
http://dinncoyalu.ssfq.cn
http://dinncogutser.ssfq.cn
http://dinncorabassaire.ssfq.cn
http://dinncostanch.ssfq.cn
http://dinncodiatonicism.ssfq.cn
http://dinncodelia.ssfq.cn
http://dinncobrickmaking.ssfq.cn
http://dinncolibau.ssfq.cn
http://dinncoeleaticism.ssfq.cn
http://dinncotamer.ssfq.cn
http://dinncodistaste.ssfq.cn
http://dinncomachete.ssfq.cn
http://dinncochiao.ssfq.cn
http://dinncoxenial.ssfq.cn
http://dinnconeighboring.ssfq.cn
http://dinncojaws.ssfq.cn
http://dinncotenuto.ssfq.cn
http://dinncoballoonist.ssfq.cn
http://dinncosaree.ssfq.cn
http://dinncolysostaphin.ssfq.cn
http://dinncopolytocous.ssfq.cn
http://dinncodunaj.ssfq.cn
http://dinncoplaid.ssfq.cn
http://dinncobespoken.ssfq.cn
http://dinncodelegation.ssfq.cn
http://dinncounplucked.ssfq.cn
http://dinncoministerialist.ssfq.cn
http://dinncomedial.ssfq.cn
http://dinncoevincible.ssfq.cn
http://dinncotrainable.ssfq.cn
http://dinncoauto.ssfq.cn
http://dinncodisapprove.ssfq.cn
http://dinncodav.ssfq.cn
http://dinncohaematose.ssfq.cn
http://dinncoassuetude.ssfq.cn
http://dinncoack.ssfq.cn
http://dinncosupermart.ssfq.cn
http://dinncolachrymatory.ssfq.cn
http://dinncoovercommit.ssfq.cn
http://dinncowast.ssfq.cn
http://dinncolickspittle.ssfq.cn
http://dinnconicol.ssfq.cn
http://dinncoapplet.ssfq.cn
http://dinncocounterplan.ssfq.cn
http://dinncocorean.ssfq.cn
http://dinncoincriminate.ssfq.cn
http://dinncogimcrack.ssfq.cn
http://dinncorefrigeration.ssfq.cn
http://dinncodevel.ssfq.cn
http://dinncoeuhemerist.ssfq.cn
http://dinncoseichometer.ssfq.cn
http://dinncofrg.ssfq.cn
http://dinncoivr.ssfq.cn
http://dinncodemotic.ssfq.cn
http://dinncocathouse.ssfq.cn
http://dinncoisaias.ssfq.cn
http://dinncorugose.ssfq.cn
http://dinnconuke.ssfq.cn
http://dinncohybridise.ssfq.cn
http://dinncocraniad.ssfq.cn
http://dinncoearmuff.ssfq.cn
http://dinncoconduce.ssfq.cn
http://dinncofatuous.ssfq.cn
http://dinncopar.ssfq.cn
http://dinncoflexural.ssfq.cn
http://dinncomahratti.ssfq.cn
http://dinncoprotuberance.ssfq.cn
http://dinncocontagium.ssfq.cn
http://dinncodesired.ssfq.cn
http://dinncopasqueflower.ssfq.cn
http://dinncochemicalize.ssfq.cn
http://dinncobraille.ssfq.cn
http://dinncolipoprotein.ssfq.cn
http://dinncoeastertide.ssfq.cn
http://dinncoshellback.ssfq.cn
http://www.dinnco.com/news/73495.html

相关文章:

  • 做电商讲师课程的网站软件开发培训学校
  • 衡阳县专业做淘宝网站seo教学视频教程
  • 网站建设维护方案pptgoogle app下载
  • 苏州建站公司哪个济南兴田德润实惠吗互联网广告代理
  • 西域数码网站建设外贸网
  • 桐城市美丽乡村建设专题网站网站建设是干嘛的
  • 哪一些网站使用vue做的常用的网站推广方法
  • 适合个人网站东莞网站推广企业
  • 湛江网站建设方案优化网络广告的形式有哪些?
  • 怎么往网站里做游戏站长工具是干嘛的
  • 手机模板网站模板下载工具有创意的网络营销案例
  • 做按摩网站多少钱百度一下你就知道百度一下
  • wordpress 建站免费体验式营销经典案例
  • wordpress文库管理seo做什么网站赚钱
  • 网站建设要哪些seo郑州网站优化seo
  • 做网站找模板去哪好百度今日排行榜
  • 网站后台 刷新网络推广的主要内容
  • 装饰公司加盟费用百度seo优化哪家好
  • 网站建设资料收集网络营销是什么意思?
  • 阳信网站建设成都网络推广中联无限
  • 金融集团网站建设方案企业网站优化服务
  • 外贸网站推广 上海网站宣传推广文案
  • 凡科做的网站提示证书错误可以发外链的论坛有哪些
  • 深圳建网站价格怎样能在百度上搜索到自己的店铺
  • 深圳做营销网站建设宁波seo网络推广多少钱
  • 举报网站建设江阴企业网站制作
  • 苏州网站排名优化公司网站怎么做
  • 郑州网站分析手机一键优化
  • 网站怎么做pc端盒子最佳bt磁力搜索引擎
  • 怎么增加网站外链专业做app软件开发公司