高可用负载(主备节点)部署步骤
完成下图一个简单的高可用负载机制:
1.拷贝keepalived-1.2.19.tar.gz至Linux的/home目录(也可以是其它目录)
2.解压并安装keepalived:
tar -zxvf keepalived-1.2.19.tar.gz
yum install popt-devel
yum -y install openssl-devel
cd keepalived-1.2.19
./configure
make && make install
这样keepalived编译及安装完成!
3.拷贝并复制keepalived:
cp /usr/local/etc/rc.d/init.d/keepalived /etc/rc.d/init.d/
cp /usr/local/etc/sysconfig/keepalived /etc/sysconfig/
mkdir /etc/keepalived
cp /usr/local/etc/keepalived/keepalived.conf /etc/keepalived/
cp /usr/local/sbin/keepalived /usr/sbin/
上传并覆盖keepalived.conf至/etc/keepalived
备注:keepalived.conf详见步骤4
上传check_haproxy.sh至/etc/keepalived
备注:check_haproxy.sh配置文件内容如下:
#!/bin/bash
A=`ps -C haproxy --no-header |wc -l`
if [ $A -eq 0 ];then
/usr/local/haproxy/sbin/haproxy -f /usr/local/haproxy/cfg/haproxy.cfg
sleep 3
if [ `ps -C haproxy --no-header |wc -l` -eq 0 ];then
/etc/init.d/keepalived stop
fi
fi
4.修改keepalived.conf配置文件:
! Configuration File for keepalived
global_defs {
notification_email {
receiver@qq.com # 修改成可用的收件人地址,可为多个
}
notification_email_from sender@qq.com # 修改成可用的发件人地址
smtp_server mail.iflytek.com # 修改成可用的邮箱代理地址
smtp_connect_timeout 30
router_id keepalived
}
vrrp_script chk_http_port {
script "/etc/keepalived/check_haproxy.sh" # 修改成Haproxy监控脚本路径
interval 2 # 检查间隔时间,单位:秒
}
vrrp_instance VI_MASTER {
state MASTER # 修改成MASTER,意味着该服务器为主节点;若修改为BACKUP,则为备用节点,即当主机宕掉,从机接管
interface eth0
virtual_router_id 51
priority 150
nopreempt
advert_int 1
authentication {
auth_type PASS
auth_pass 1111
}
track_script {
chk_http_port
}
virtual_ipaddress {
192.168.1.1 # 修改成可用的虚拟IP
}
}
5.解压haproxy-1.5.12并上传至/usr/local
6.修改/usr/local/haproxy/cfg配置文件haproxy.cfg:
global
daemon
nbproc 1
group nobody
user nobody
maxconn 102400
ulimit-n 204821
chroot /usr/local/haproxy
defaults
mode tcp
maxconn 102400
retries 3
option redispatch
option abortonclose
timeout connect 600s
timeout client 600s
timeout server 600s
listen interface
bind 0.0.0.0:8001
balance leastconn
mode http
server interface1 192.168.85.100:8001 weight 1 maxconn 102400 check inter 10s
server interface2 192.168.85.101:8001 weight 1 maxconn 102400 check inter 10s
listen engine
bind 0.0.0.0:18006
balance leastconn
mode tcp
server engine1 192.168.85.100:18006 weight 1 maxconn 102400 check inter 10s
server engine2 192.168.85.101:18006 weight 1 maxconn 102400 check inter 10s
至此完成Haproxy配置修改!
7.运行如下命令,启动Haproxy运行:
/etc/init.d/keepalived start
8.测试:
telnet 192.168.1.1 8001
telnet 192.168.1.1 18006
依次使用虚拟IP+路由端口的形式验证对应端口是否可用!
说明:对于从机部署,与主机部署一致。这里说明一下:对于HA,只会使用主节点,仅当主节点挂掉,才会切换到从节点!
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· AI与.NET技术实操系列:基于图像分类模型对图像进行分类
· go语言实现终端里的倒计时
· 如何编写易于单元测试的代码
· 10年+ .NET Coder 心语,封装的思维:从隐藏、稳定开始理解其本质意义
· .NET Core 中如何实现缓存的预热?
· 25岁的心里话
· 闲置电脑爆改个人服务器(超详细) #公网映射 #Vmware虚拟网络编辑器
· 零经验选手,Compose 一天开发一款小游戏!
· 因为Apifox不支持离线,我果断选择了Apipost!
· 通过 API 将Deepseek响应流式内容输出到前端