百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 技术资源 > 正文

高可用、负载均衡 集群部署方案:Keepalived + Nginx + Tomcat

off999 2025-01-17 12:34 18 浏览 0 评论

前言:初期应用较小,一般以单机部署为主,即可满足业务的需求,随着业务的不断扩大,单机部署的模式无法承载这么大的业务量,需要进行服务集群化的部署,本文主要介绍服务器Tomcat多实例部署,搭载Keepalived + Nginx,实现Web服务的高可用。

  • Nginx 是一个高性能的 HTTP反向代理服务器
  • Keepalived 是一个基于VRRP协议来实现的服务高可用方案,可以利用其来避免服务的单点故障
  • Nginx作为反向代理服务器,来提供负载均衡的能力,使我们的Web服务器,能够水平扩容,这时反向代理服务器(Nginx)又变成了一个单点,如果挂掉,整合Web服务器就不能被外界访问到;所以需要结合Keepalived来保障反向代理服务器(Nginx)的高可用;

    环境准备

    CentOS7系统

    Keepalived-2.0.15

    Nginx-1.14.2

    Tomcat8

    准备2台服务器,每台上部署安装Nginx+Keepalived和Tomcat,另外一个VIP(虚拟IP);这里省略了2台,这样在实际模拟中方便演练(Tomcat不单独部署在一台服务器而已)

    1、Nginx的安装

    2、Keepalived的安装

    3、配置Keepalived + Nginx,实现高可用

    准备的2台服务器上,一台作为MASTER,一台作为BACKUP;每台上需要准备文件如下图

    1. keepalived 和 nginx 都编译安装到/usr/local目录下面,名称分别是keepalived 和 nginx

    2. ck_ng.sh、 keepalived.conf 文件放置到/etc/keepalived/目录, ck_ng.sh文件权限设置成755

    3. nginx.service、 keepalived.service 文件放置到/usr/lib/systemd/system目录

    3.1、MASTER配置

    keepalived.conf配置

    global_defs {
     #notification_email {
     # localhost@163.com
     #}
     #notification_email_from Keepalived@localhost
     #smtp_server 163@smtp.com
     #smtp_connect_timeout 30
     router_id 192.168.1.101 #MASTER服务器的IP地址
    }
    
    #配置vrrp_script,主要用于健康检查,以及检查失败后执行的动作。
    vrrp_script chk_nginx {
     #健康检查脚本,当脚本返回值不为0时认为失败
     script "/etc/keepalived/ck_ng.sh"
     #检查频率,以下配置每2秒检查1次
     interval 2
     #当检查失败后,将vrrp_instance的priority减小5
     weight -5
     #连续监测失败3次,才认为真的健康检查失败。并调整优先级
     fall 3
     #连续监测2次成功,就认为成功。但不调整优先级
     rise 2
    }
    
    #定义对外提供服务的VIP vrrp_instance配置
    vrrp_instance VI_1 {
     #指定vrrp_instance的初始状态,是MASTER还是BackUP主要还是看优先级。
     state MASTER
     #指定vrrp_instance绑定的网卡,最终会通过指定的网卡宣告VIP
     interface ifcfg-eth0
     #发送心跳包的源IP,可使用绑定的网卡IP,也可以使用本服务器上的其他IP
     mcast_src_ip 192.168.1.101
     #相当于VRID,用于在一个网内区分组播,需要组播域内内唯一。
     virtual_router_id 55
     #本机的优先级,VRID相同的机器中,优先级最高的会被选举为MASTER
     priority 100
     #心跳间隔,下面配置,MASTER会每隔1秒发送一个报文高职组内其他机器,自己还活着。
     advert_int 1
     #定义主从的验证方式以及密码,一般使用PASS(最长8位,超过了只会识别前8位作为密码)
     authentication {
     auth_type PASS
     auth_pass 123456
     }
    
     #VIP 虚拟 IP 池, 两个节点设置必须一样 
     virtual_ipaddress {
    					192.168.1.100/24
     }
    
     #本vrrp_instance所引用的脚本配置,名称就是vrrp_script 定义的容器名
     track_script {
     chk_nginx
     }
     
     #状态切换,使用上述配置发送邮件通知
     smtp_alert
    }

    ck_ng.sh配置

    keepalived.service配置

    nginx.service配置

    3.2、BACKUP配置

    keepalived.conf配置(和MASTER类似,列出差异的地方)

    global_defs {
     		router_id 192.168.1.102
    }
    
    #定义对外提供服务的VIP vrrp_instance配置
    vrrp_instance VI_1 {
     #指定vrrp_instance的初始状态,是MASTER还是BackUP主要还是看优先级。
     state BACKUP
     #发送心跳包的源IP,可使用绑定的网卡IP,也可以使用本服务器上的其他IP
     mcast_src_ip 192.168.1.102
     #本机的优先级,VRID相同的机器中,优先级最高的会被选举为MASTER
     priority 99
    } 

    ck_ng.sh配置(和MASTER一致)

    keepalived.service配置(和MASTER一致)

    nginx.service配置(和MASTER一致)

    3.3、Tomcat服务通过反向代理Nginx对外提供服务

    Tomcat的安装和应用部署不再具体描述,主要看一下如何通过Nginx的配置实现对外服务(两个Nginx都通过这样的配置来完成)

    nginx.conf配置

    # upstream configure 
    upstream myapp {
     ip_hash;
     server 192.168.1.101:8080; #Tomcat的应用
     server 192.168.1.102:8080; #Tomcat的应用
    }
    
    server
     {
     listen 8888; #假设对外提供的服务端口
     server_name localhost;
     port_in_redirect on;
     
     location /app1 #Tomcat下的一个应用
     {
     proxy_pass http://myapp/app1;
     proxy_http_version 1.1;
     proxy_set_header Upgrade $http_upgrade;
     proxy_set_header Connection "upgrade";
    
     proxy_set_header Host $host:$server_port;
     proxy_set_header X-Real-IP $remote_addr;
     proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
     }
    
     location /app2 #Tomcat下的另外一个应用
     {
     proxy_pass http://myapp/app2;
     proxy_http_version 1.1;
     proxy_set_header Upgrade $http_upgrade;
     proxy_set_header Connection "upgrade";
    
     proxy_set_header Host $host:$server_port;
     proxy_set_header X-Real-IP $remote_addr;
     proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
     }
    
     location /
     {
     proxy_pass http://myapp;
     proxy_http_version 1.1;
     proxy_set_header Upgrade $http_upgrade;
     proxy_set_header Connection "upgrade";
    
     proxy_set_header Host $host:$server_port;
     proxy_set_header X-Real-IP $remote_addr;
     proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
     }
     }

    通过以上的搭建,可以实现高可用、负载均衡 集群部署方案。

    相关推荐

    win8家庭中文版下载(windows家庭中文版下载)

    可以按照以下步骤在Win8上下载和安装Word:1.通过微软官网下载购买,或者通过MicrosoftStore应用商店进行购买和下载。2.下载完成后,打开文件夹,双击setup进行安装。3.安...

    教大家强制退出苹果id账号(教大家强制退出苹果id账号ipad)

    1.首先将手机强制关机,并在电脑端安装iTunes并打开。2.用数据线将手机与电脑连接起来,长按手机电源键。3.当出现苹果标志时不要松开电源键,接着按Home键。4.直到屏幕黑屏,松开电源键。5.继续...

    惠普官网驱动下载官网(惠普驱动官方)

    在惠普官网下载系统驱动方法如下访问HP官网:www.hp.com找到支持与驱动页面(通常在顶部导航栏的支持或下载中)输入你的HP产品的序列号或选择产品类型和型号选择你的操作系统,然后下载相关的驱动。安...

    电脑公司取名字大全(电脑行业公司取名)

    动感网络IT狂人行鱼雷IT网PC宝宝网外有鱼超导技术网PC技术网加点分吧,不然想不出太多,呵呵绿苑计算机协会绿色代表生命,有起航的意义,苑是一个范畴,有地域的意思,是给你们一片天地的意思...

    系统一键重装win7(win7一键重装系统win10)
    • 系统一键重装win7(win7一键重装系统win10)
    • 系统一键重装win7(win7一键重装系统win10)
    • 系统一键重装win7(win7一键重装系统win10)
    • 系统一键重装win7(win7一键重装系统win10)
    如何卸载显卡驱动(主板驱动)
    • 如何卸载显卡驱动(主板驱动)
    • 如何卸载显卡驱动(主板驱动)
    • 如何卸载显卡驱动(主板驱动)
    • 如何卸载显卡驱动(主板驱动)
    wifi怎么设置网速快(手机测wifi网速怎么测)

    wifi加速设置方法步骤如下。1设置网速:浏览器中输入终端地址,输入账号和密码。找到连接设备数目并进行更改,找到信道宽度,选择更快的网速。2提高WiFi网速:进入设置中心,点击WLAN选项。点击高级设...

    华硕驱动软件叫什么(华硕自带驱动管理软件)

    q-installer驱动啥意思?华硕q-installer驱动能让用户更加方便地管理各种文件。将会同时显示4个Windows资源管理器的窗口,这样能让用户更加简单地对文件进行一些操作,例如复制,粘贴...

    懂行的人建议买华为还是惠普电脑

    华为电脑好。华为笔记本电脑主打的就是轻薄,质感,多屏协同生态,面向商务人群和学生党。目前在售的机型并不多,但每一台机子本身都不错,不过因为被制裁的缘故,定价过高,性价比打折扣。惠普笔记本好,惠普除了家...

    如何把win系统换成安卓(怎么把系统改为win10)

    方法/步骤分步:1首先点击打开酷安应用市场;2点击打开位于屏幕右下方的“应用游戏”选项;3选择想要下载的软件或者游戏app,点击进入;4选择“下载”按钮,点击开始下载;5APP下载完成后,系统会自动跳...

    win7摄像头软件哪个好(win7摄像头软件ecap)
    • win7摄像头软件哪个好(win7摄像头软件ecap)
    • win7摄像头软件哪个好(win7摄像头软件ecap)
    • win7摄像头软件哪个好(win7摄像头软件ecap)
    • win7摄像头软件哪个好(win7摄像头软件ecap)
    如何复制粘贴(如何复制粘贴excel表格内容)
    如何复制粘贴(如何复制粘贴excel表格内容)

    需要复制文字的时候只要先选中文字,然后同时按住Ctrl+C键,然后松手就已经复制了文字,在需要粘贴的地方同时按住:Ctrl+V就可以看到文字被粘贴了,非常的方便。扩展资料:Alt键,这个键叫做改变,很多快捷键都需要使用到这个键,矩形...

    2025-11-14 05:51 off999

    hotmail电子邮箱登录(hotmail邮箱在线登录)

    ***@hotmail.com1、其中***是你自己申请的邮箱的用户名。2、hotmail要写在符号@后面。3、最后加上.com,这样就是一个完整的hotmail邮箱的格式。4、比如:zhangj...

    qq恢复官方网站聊天记录(qq恢复聊天记录在哪里)
    • qq恢复官方网站聊天记录(qq恢复聊天记录在哪里)
    • qq恢复官方网站聊天记录(qq恢复聊天记录在哪里)
    • qq恢复官方网站聊天记录(qq恢复聊天记录在哪里)
    • qq恢复官方网站聊天记录(qq恢复聊天记录在哪里)
    win10iso文件(win10iso文件怎么安装)

    安装Win10ISO系统文件需要以下步骤:1.首先需要从Microsoft官网下载Win10ISO系统文件,打开网站后选择Win10的版本、语言和架构(32位或64位),点击下载即可。2.下载...

    取消回复欢迎 发表评论: