范文健康探索娱乐情感热点
投稿投诉
热点动态
科技财经
情感日志
励志美文
娱乐时尚
游戏搞笑
探索旅游
历史星座
健康养生
美丽育儿
范文作文
教案论文
国学影视

LVSKeepalivedNginx安装及配置

  LVS + Keepalived + Nginx安装及配置1、概述
  上篇文章《架构设计:负载均衡层设计方案(6)——Nginx + Keepalived构建高可用的负载层》我们讲解了Nginx的故障切换,并且承诺各位读者会尽快讲解 LVS + Keepalived + Nginx的安装和配置。在中间由于工作的原因,我又插写了三篇关于zookeeper的原理使用的文章。今天这边文章我们回归主题,为各位读者讲解 LVS + Keepalived + Nginx的安装及配置。 2、安装计划和准备工作
  下图,我们表示了本篇文章要搭建的整个集成架构的抽象结构:
  我们采用两个LVS节点(141和142),但是一个时间工作的只有一个LVS节点,另一个始终处于热备standby状态,由keepalived监控这两个节点的工作状态并完成切换。
  在LVS节点下,我们采用LVS-DR工作模式挂载了两个Nginx节点(131、132)。并最终将外网请求交由这两个节点进行处理。 注意:在实际工作中,Nginx下面一般就是访问静态资源、动态资源的配置了。 2-1、准备两个keepalived节点
  首先我们在将要安装LVS的两个节点上,先安装keepalived,并保证这两个keepalived节点能够正常工作(监控批次的状态)。当然,您也可以先准备LVS,在准备keepalived。
  我想准备keepalived节点,大家应该轻车熟路了吧,在《架构设计:负载均衡层设计方案(6)——Nginx + Keepalived构建高可用的负载层》这篇文章中详细介绍了keepalived的最简配置方式。为了大家阅读方便,我们在这里再进行依次简要说明。准备keepalived的整个过程包括: 安装必要的支撑组件,源码安装keepalived 将keepalived注册成节点的服务,以便保证keepalived在节点启动时就开始工作 更改keepalived的配置文件,让其可以正常工作 验证准备工作
  =============安装keepalived [root@lvs1 ~]# yum install -y zlib zlib-devel gcc gcc-c++ openssl openssl-devel openssh [root@lvs1 ~]# tar -zxvf keepalived-1.2.17.tar.gz [root@lvs1 ~]# cd keepalived-1.2.17 [root@lvs1 ~]# ./configure --perfix=/usr/keepalived-1.2.17 [root@lvs1 ~]# make & make install
  =============将keepalived注册成服务(如果您使用的默认路径安装,就不需要cp命令了) [root@lvs1 ~]# cp /usr/keepalived-1.2.17/etc/sysconfig/keepalived  /etc/sysconfig/keepalived  [root@lvs1 ~]# cp /usr/keepalived-1.2.17/sbin/keepalived /usr/sbin/keepalived [root@lvs1 ~]# cp /usr/keepalived-1.2.17/etc/rc.d/init.d/keepalived  /etc/rc.d/init.d/keepalived [root@lvs1 ~]# mkdir /etc/keepalived [root@lvs1 ~]# cp /usr/keepalived-1.2.17/etc/keepalived/keepalived.conf /etc/keepalived/keepalived.conf [root@lvs1 ~]# 可以做成服务了(不要拷贝,没用的) [root@lvs1 ~]# chkconfig keepalived on
  这里我们先设置浮动ip
  设置VIP的信息
  ifconfig eth0:0 192.168.220.140 broadcast 192.168.220.140 netmask 255.255.255.255 up
  route add -host 192.168.220.140 dev eth0:0
  做成服务后,先不要急着启动,因为配置文件还没有改好。
  ========配置keepalived(配置文件在:/etc/keepalived/keepalived.conf) ! Configuration File for keepalived  global_defs {    #notification_email {    #  acassen@firewall.loc    #  failover@firewall.loc    #  sysadmin@firewall.loc    #}    #notification_email_from Alexandre.Cassen@firewall.loc    #smtp_server 192.168.200.1    #smtp_connect_timeout 30    router_id LVS_DEVEL }  vrrp_instance VI_1 {     #141节点设置为MASTER,142或者还有其他的节点设置为BACKUP     #还记得我们前面文章讲到的无抢占设置吗?这里也可以用哦。     state MASTER     #网络适配器名称     interface eth0     virtual_router_id 51     #所有的SLAVE节点的优先级都要比这个设置值低     priority 120     advert_int 1     #真实ip,142要改成相应的lvs节点真实ip     mcast_src_ip=192.168.220.141     authentication {         auth_type PASS         auth_pass 1111     }     #虚拟/浮动IP     virtual_ipaddress {         192.168.220.140     } }
  以上配置还是最简单的keepalived配置,因为我们还没有加上配合LVS使用的虚拟ip监测设置和下层真实ip监测的设置。最简配置主要是为了保证keepalived节点是工作正常的。
  将以上的配置分别对应到LVS的两个节点(注意要改动的地方哦)
  ==========进行keepalived工作状态的检查: [root@lvs1 ~]# /etc/init.d/keepalived start
  现在设置为MASTER的keepalived节点(或者在非抢占模式下,优先级最高的那个节点),已经绑定了140这个虚拟ip了: [root@lvs2 ~]# ip addr 1: lo:  mtu 16436 qdisc noqueue state UNKNOWN      link/loopback 00:00:00:00:00:00 brd 00:00:00:00:00:00     inet 127.0.0.1/8 scope host lo     inet6 ::1/128 scope host         valid_lft forever preferred_lft forever 2: eth0:  mtu 1500 qdisc pfifo_fast state UP qlen 1000     link/ether 00:0c:29:39:75:9f brd ff:ff:ff:ff:ff:ff     inet 192.168.220.141/24 brd 192.168.220.255 scope global eth0     inet 192.168.220.140/32 scope global eth0     inet6 fe80::20c:29ff:fe39:759f/64 scope link         valid_lft forever preferred_lft forever
  当然您也可以通过 /var/log/message的日志进行keepalived是否正常工作的验证。 2-2、继续两个keepalived节点上准备LVS
  准备lvs的工作就太简单了,因为centos6.4、6.5、6.6都已经集成了LVS的核心,我们只需要安装LVS的管理工具就行了:
  (1)如果要源码安装的话:
  这里源码安装ipvsadm
  yum install kernel-devel -y
  yum -y install popt popt-devel libnl libnl-devel popt-static(我尝试过要是不安装的话就会报错)
  ln -s /usr/src/kernels/2.6.32-642.4.2.el6.x86_64/ /usr/src/linux
  wget http://www.linuxvirtualserver.org/software/kernel-2.6/ipvsadm-1.26.tar.gz
  tar xf ipvsadm-1.25.tar.gz
  cd ipvsadm-1.25
  make && make install
  然后我们检测一下
  ipvsadm 是否有内容输出
  (2)如果yum安装的话
  两个LVS节点都执行: yum -y install ipvsadm
  还记得lvs管理工具怎么使用吗?请参见我介绍LVS单节点安装的博文:《架构设计:负载均衡层设计方案(5)——LVS单节点安装》。这里为了方便阅读,给出主要参数的含义列表: -A –add-service 在内核的虚拟服务器表中添加一条新的虚拟服务器记录。也就是增加一台新的虚拟服务器。 -E –edit-service 编辑内核虚拟服务器表中的一条虚拟服务器记录。 -D –delete-service 删除内核虚拟服务器表中的一条虚拟服务器记录。 -C –clear 清除内核虚拟服务器表中的所有记录。 -R –restore 恢复虚拟服务器规则 -S –save 保存虚拟服务器规则,输出为-R 选项可读的格式 -a –add-server 在内核虚拟服务器表的一条记录里添加一条新的真实服务器记录。也就是在一个虚拟服务器中增加一台新的真实服务器 -e –edit-server 编辑一条虚拟服务器记录中的某条真实服务器记录 -d –delete-server 删除一条虚拟服务器记录中的某条真实服务器记录 -L –list 显示内核虚拟服务器表 -Z –zero 虚拟服务表计数器清零(清空当前的连接数量等) –set tcp tcpfin udp 设置连接超时值 –start-daemon 启动同步守护进程。他后面可以是master 或backup,用来说明LVS Router 是master 或是backup。在这个功能上也可以采用keepalived 的VRRP 功能。 –stop-daemon 停止同步守护进程 -t –tcp-service service-address 说明虚拟服务器提供的是tcp 的服务[vip:port] or [real-server-ip:port] -u –udp-service service-address 说明虚拟服务器提供的是udp 的服务[vip:port] or [real-server-ip:port] -f –fwmark-service fwmark 说明是经过iptables 标记过的服务类型。 -s –scheduler scheduler 使用的调度算法,选项:rr|wrr|lc|wlc|lblc|lblcr|dh|sh|sed|nq, 默认的调度算法是: wlc. -p –persistent [timeout] 持久稳固的服务。这个选项的意思是来自同一个客户的多次请求,将被同一台真实的服务器处理。timeout 的默认值为300 秒。 -M –netmask netmask persistent granularity mask -r –real-server server-address 真实的服务器[Real-Server:port] -g –gatewaying 指定LVS 的工作模式为直接路由模式DR模式(也是LVS默认的模式) -i –ipip 指定LVS 的工作模式为隧道模式 -m –masquerading 指定LVS 的工作模式为NAT 模式 -w –weight weight 真实服务器的权值 –mcast-interface interface 指定组播的同步接口 –connection 显示LVS 目前的连接 如:ipvsadm -L -c –timeout 显示tcp tcpfin udp 的timeout 值 如:ipvsadm -L –timeout –daemon 显示同步守护进程状态 –stats 显示统计信息 –rate 显示速率信息 –sort 对虚拟服务器和真实服务器排序输出 –numeric -n 输出IP 地址和端口的数字形式
  到后面正式启动LVS的时候,就不要问我参数含义咯。^_^ 2-3、准备两个Nginx节点并保证可用
  在《架构设计:负载均衡层设计方案(5)——LVS单节点安装》(http://blog.csdn.net/yinwenjie/article/details/47010569) 这篇文章中,我们详细讲解了Nginx节点的准备工作,但是为了方便各位读者阅读,这里我们大致再讲一下。
  Nginx节点的准备工作主要由以下步骤构成(这个不是本文的重点,点到即可): 安装Nginx(当然,正式系统中,还涉及到Nginx的参数调优,可以参见《架构设计:负载均衡层设计方案(2)——Nginx安装》这篇文章) 打开Nginx所在服务器的"路由"功能、关闭"ARP查询"功能 将VIP:192.168.220.140 设置成Nginx所在节点的回环IP
  =============安装Nginx [root@vm1 ~]# yum -y install make zlib zlib-devel gcc gcc-c++ ssh libtool pcre* [root@vm1 ~]# 下载nginx(别拷贝,不能执行的) [root@vm1 ~]# 解压nginx(别拷贝,不能执行的) [root@vm1 ~]# ./configure –prefix=/usr/nginx-1.8.0  [root@vm1 ~]# make && make install  [root@vm1 ~]# 设置环境变量(别拷贝,不能执行的) [root@vm1 ~]# 启动nginx
  =============打开Nginx所在服务器的"路由"功能、关闭"ARP查询"功能 [root@vm1 ~]# echo "1" >/proc/sys/net/ipv4/conf/lo/arp_ignore [root@vm1 ~]# echo "2" >/proc/sys/net/ipv4/conf/lo/arp_announce [root@vm1 ~]# echo "1" >/proc/sys/net/ipv4/conf/all/arp_ignore [root@vm1 ~]# echo "2" >/proc/sys/net/ipv4/conf/all/arp_announce
  =============设置回环IP [root@vm1 ~]# ifconfig lo:0 192.168.220.140 broadcast 192.168.220.140 netmask 255.255.255.255 up [root@vm1 ~]# route add -host 192.168.220.140 dev lo:0
  两台Nginx的节点都按照这样的方法去设置。然后使用浏览器,看看这两个节点的Nginx是否工作正常:
  我这里在做实验的时候忘了把防火墙和selinux关了,所以浏览器访问不了。不要忘了关哦
  我们可以把nginx的首页改一下以便分辨区别
  =====
  2-4、其他说明
  keepalived和LVS是天生配合完美的一对, LVS负责进行请求转发不负责任何节点的健康监测;keepalived负责监控整个环境中,包括虚拟ip,真实ip对应的下层节点的健康状态监测 。 3、开始配置:LVS-DR工作模式3-1、keepalived的更改——健康监测
  首先我们要更改之前配置的"最简keepalived"配置,让keepalived能够对结构中所有节点和虚拟ip的健康状态进行监测。更改配置和含义如下: ! Configuration File for keepalived  global_defs {    #notification_email {    #  acassen@firewall.loc    #  failover@firewall.loc    #  sysadmin@firewall.loc    #}    #notification_email_from Alexandre.Cassen@firewall.loc    #smtp_server 192.168.200.1    #smtp_connect_timeout 30    router_id LVS_DEVEL }  vrrp_instance VI_1 {     #141节点设置为MASTER,142或者还有其他的节点设置为BACKUP     #还记得我们前面文章讲到的无抢占设置吗?这里也可以用哦。     state MASTER     #网络适配器名称     interface eth0     virtual_router_id 51     #所有的SLAVE节点的优先级都要比这个设置值低     priority 120     advert_int 1     #真实ip,142要改成相应的lvs节点真实ip     mcast_src_ip=192.168.220.141     authentication {         auth_type PASS         auth_pass 1111     }     #虚拟/浮动IP     virtual_ipaddress {         192.168.220.140     } }  virtual_server 192.168.220.140 80 {     #健康时间检查,单位秒     delay_loop 6     #负载均衡调度算法wlc|rr,和您将使用的LVS的调度算法保持原则一致     lb_algo rr     #负载均衡转发规则 DR NAT TUN。和您将启动的LVS的工作模式设置一致     lb_kind DR     #虚拟地址的子网掩码     nat_mask 255.255.255.0     #会话保持时间,因为我们经常使用的是无状态的集群架构,所以这个设置可有可无     #persistence_timeout 50     #转发协议,当然是TCP     protocol TCP      #真实的下层Nginx节点的健康监测     real_server 192.168.220.131 80 {         #节点权重,         weight 10         #设置检查方式,可以设置HTTP_GET | SSL_GET         HTTP_GET {             url {               path /               digest ff20ad2481f97b1754ef3e12ecd3a9cc             }             #超时时间,秒。如果在这个时间内没有返回,则说明一次监测失败             connect_timeout 3             #设置多少次监测失败,就认为这个真实节点死掉了             nb_get_retry 3             #重试间隔             delay_before_retry 3         }     }      real_server 192.168.220.132 80 {         weight 10         HTTP_GET {             url {               path /               digest 640205b7b0fc66c1ea91c463fac6334d             }             connect_timeout 3             nb_get_retry 3             delay_before_retry 3         }     } }
  这样一来,keepalived就可以检查整个架构中的所有节点状态了。 另外要说明的是,这个检查过程并不是必须的,您使用keepalived的最简配置也是可以的,不过您就需要自己写监测脚本了(道理是一样的) 。 3-2、启动两个LVS节点
  启动LVS的过程就太简单了(两个节点都是一样的启动方式): [root@lvs2 ~]# ipvsadm -C [root@lvs2 ~]# ipvsadm -At 192.168.220.140:80 -s rr  [root@lvs2 ~]# ipvsadm -at 192.168.220.140:80 -r 192.168.220.131 -g [root@lvs2 ~]# ipvsadm -at 192.168.220.140:80 -r 192.168.220.132 -g [root@lvs2 ~]# 然后我们可以使用ipvsadm 监控目前LVS的状态 [root@lvs2 ~]# ipvsadm
  注意:处于standby的lvs1节点也要这样进行设置。
  还有,以上的LVS的设置,和real server上的设置,在重启后都会消失,所以一定要做成脚本哦。 4、验证工作
  这样LVS + Keepalived + Nginx方式的配置就做完了。现在我们进行搭建效果的监测: 4-1、验证Master-LVS节点的工作
  我们使用两个不同的浏览器,验证Master-LVS节点的工作:
  =========浏览器1:
  =========浏览器2:
  看来140这个VIP下的LVS工作是正常的。 4-2、验证Master-LVS节点停止后的效果
  下面我们停止Master-LVS1: [root@lvs2 ~]# service keepalived stop
  在经历了一些访问停顿后,浏览器1显示的效果如下(这就是为什么keepalived最好设置为非抢占模式):
  5、后文介绍
  好了,到这里负载均衡层所使用的几个标准工具就介绍完了。下一篇文章我们将进行总结,然后进入架构设计:业务层设计方案 的系列文章。在下一个系列文章中,我们将介绍至少两套SOA的实现、至少两套系统间通信使用的消息队列。哦,应我朋友的要求,我会专门写几篇文章,介绍Java中线程的基础知识和进阶知识。
  如果本文对你有帮助,别忘记给我个3连 ,点赞,转发,评论,
  咱们下期见!学习更多JAVA知识与技巧,关注与私信博主(666)

4消息!1阶段无观众,广东包机赴杭大外归队,山东签国家级强援根据今天的消息,第一阶段的售票已经确定,CBA已经打算第一阶段不会开放观众。而按照目前的趋势来看,主客场的可能性还是不会很大了。毕竟现在零零散散出现,冬天还是高峰期,这都会限制CB不奋斗,不努力,你靠什么去看世界那么大大家好!我是小小,欢迎阅读。人活着,是为了自我的人生目标和价值追求。为了生活努力向前看。在这样一个人生大舞台上,能获得成功与幸福是十分重要的。人生路上难免会有挫折坎坷和失败,但只要iPhone14Plus正式发售!这6款值得安装iOS应用,让你的手机更好用今年iPhone取消了Mini版本,新增了Plus版本,屏幕更大了。如今iPhone14Plus已经发售了,下面这6款值得安装iOS应用,可以让你的手机更好用。01万能小组件它是一世界杯国足20年后聚首范志毅咧嘴大笑江津满头白发,有人去世近段时间,2002年世界杯国足队员重聚,78岁的功勋主帅米卢现身。这是大家时隔20年重聚,勾起了许多老球迷的回忆,也让人们不得不感叹时光飞逝,20年光阴转瞬即逝。大家十分熟悉的范志爱了!千娇百媚的世界头条作者云开日初这些娇媚勾魂魄,动心弦这些艳丽吸眼球,悦身心在这个残酷现实的世界里求生存,寻找快乐的源泉释放自己压力,不然就会被所有的压力逼疯。人生活着的艰难,确实不容易,夫妻之间(镜观中国新华社国内新闻照片一周精选)(14)鄱阳湖为候鸟留水新华社照片,北京,2022年10月8日鄱阳湖为候鸟留水在江西省都昌县,鄱阳湖主航道的水通过水泵抽水与人工水渠的接力,输入朱袍山区域的碟形湖中(9月28日摄,无人机照片)。江西鄱阳湖推荐3款好用的外文文献翻译软件,功能都超齐全现在有很多软甲就可以轻松搞定一整篇文档翻译的问题,接下来就来把我一直在用的帮我翻译了无数个重要的外文文献3款好用的翻译软件分享给大家,功能都超齐全!!一Google翻译谷歌相信大家大厂抢着要!英国金史密斯学院ampampamp提赛德大学游戏硕士作品集分享前阵子,一款名为羊了个羊的小程序游戏突然爆火,全网热度居高不下。接连几天登顶微博热搜榜单。我们不难发现,无论从游戏销售额还是用户数量的增长趋势来看,游戏行业在逐年壮大。而加上大厂们国米门将争议宣告终结四位队长展示美妙画面国米21击败克星绿巴萨的萨索洛,终结了此前的联赛连败。哲科攻入个人意甲的第100101球,成为意甲历史上跨入百球俱乐部第三老的球员。有老铁要求我痛快淋漓地吹嘘他偶像哲科。可是,国米她在刺绣作品上加了钩织,简直太好看了虽然现在高速发展,人们喜欢了快节奏的生活,像缝缝补补这类事情都觉得太太浪费时间了,而且机绣已经很美还很便宜,何苦非要自己刺绣。不过,刺绣给人带来的成就感,真的让很多人神往,不少人喜华米跃我GTR4以及GTS4怎么样?颜值很值价运动监测功能不错在国内的智能手表市场,华米Amazfit跃我是一家具备一定市场份额的第三方手表厂商(非手机厂商)。根据Counterpoint统计的数据,华米Amazfit跃我在今年一季度的时候的
TA处处都是大片?丹寨杜鹃花节货真价实摄影技巧初学者对于拍摄的技巧掌握较少,当与朋友外出旅行需要拍照时,往往拍出的成片只是漂亮的大头照。摄影技巧是有一套严谨的方式与技巧,不但要求设置好相机,同时要求了解自拍中要求的灯光务虚主义害了康佳谁还记得那款880万元的彩电?蓝科技综述2020年在美国CES上推出一款价值880万元彩电的康佳,却并没有因此带来更多的技术红利和用户。营收连续下降,彩电在集团中占比逐年下降,在风起云涌的资本市场,没有找对方向纳尼?!iPhone情侣可随时随地查看对象定位App查找适用平台iOSAndroid姐妹们,今天有男朋友的都可以来撒狗粮啦苹果自带的定位系统,可以随时随地查看男朋友的定位在哪!比微信共享位置还方便,敲好用!每次和男朋友吵架离家相差800元,新出的iQOONeo6SE和iQOONeo6到底有什么区别?iQOONeo6SE发布了,这次Neo系列的SE版本与上一代不同,不仅没阉割NFC功能,还把红外遥控加上了,好评!。那么iQOONeo6和iQOOneo6SE有什么区别?二者差价高预成冠,保护牙齿小能手通讯员舒翼徐甜甜恩施市中心医院口腔科医生正在给儿童进行口腔治疗。儿童牙病作为口腔医学中的一门独立学科,主要以处于生长发育过程中的儿童为对象,一般年龄为0至15岁左右。由于宝宝爱吃甜奥运金牌迟到十年运动员陷入银牌诅咒,惜败成不断重复的主题因为前面两位运动员都被查出兴奋剂违规,2012年伦敦奥运会女子20公里竞走项目,切阳什姐递补成为冠军。金牌迟到了10年。在体育史里,切阳什姐成了一个极为特殊的案例。过去十年里,她几乔治娜首次晒女儿照片!公布五公主名字,太浪漫了,笑起来可爱北京时间5月7日,曼联巨星C罗的女友乔治娜,久违更新个人社交平台,她晒出了新生女儿的照片,并且首次公布了小公主的名字,据悉,C罗的女儿取名叫贝拉埃斯梅拉达(BellaEsmeral16亿人民币!世纪转会诞生,哈兰德确认加盟曼城,签约5年创纪录上周中,曼城带着43的领先优势,前往伯纳乌球场挑战皇马,双方前70分钟踢得很胶着。曼城70分钟打破僵局后,一只脚踏入欧冠决赛大门,然而小将罗德里戈横空出世,用两个让人意想不到的进球紫晶储存上市后两年来,从78。24元跌到了7。39元紫晶存储,名字叫得多好听,一听就和科技沾边。不熟悉的人,并且还容易和紫光集团,紫光国微等科技公司混淆。公司主营业务是存储,做的事情也的确和科技沾边。2019年,为了鼓励创新,为了发篮协官宣!三人篮球冠军球队,因为职业化退出超级联赛三人篮球正式进入奥运会之后,中国篮协对三人篮球也是十分重视,姚明对三人篮球发展也是很上心。在上届奥运会,中国女子三人篮球队在奥运会上一飞冲天,拿到了奥运会的铜牌,创造了好成绩。中国光纤龙头品牌涉足桌面外设,推出首款扩展坞,售价199元写在前面如今的笔记本电脑,为了提升便携性,设计得越来越轻薄,外出携带的确很方便,不过代价就是接口越来越少。比如MacBook只配备了一个USBC接口,这不就是个大平板电脑么。其他P