Ubuntu上ipvsadm+keepalived

简介:

Ubuntu上ipvsadm+keepalived


http://www.keepalived.org/software/keepalived-1.1.19.tar.gz


MASTER服务器

keepalived部分:


$ sudo apt-get install libpopt-dev

$ sudo apt-get install daemon

$ sudo tar zxfv keepalived-1.1.19.tar.gz

$ cd keepalived-1.1.19

$ ./configure --prefix=/usr/local/keepalived

$ make

$ sudo make install

$ sudo mkdir /etc/sysconfig

$ sudo cp /usr/local/keepalived/etc/sysconfig/keepalived /etc/sysconfig/

$ sudo cp /usr/local/keepalived/etc/rc.d/init.d/keepalived /etc/init.d/

$ sudo cp /usr/local/keepalived/sbin/keepalived /sbin/

$ sudo mkdir /etc/keepalived

$ sudo cp /usr/local/keepalived/etc/keepalived/keepalived.conf /etc/keepalived/

$ sudo vi /etc/keepalived/keepalived.conf

按a或i进入编辑模式

! Configuration File for keepalived
global_defs {
   notification_email {
yang@126.com      (当IP发生迁移等事件的时候发送邮件到指定邮箱)
   }
   notification_email_from root@localhost      (邮件发送方)
   smtp_server 127.0.0.1                (邮件外发服务器地址)
   smtp_connect_timeout 30              (邮件超时时间为30秒)
   router_id LVS_DEVEL                  (一个实例的标识)

}             
vrrp_instance VI_1 { 
    State MASTER        (设置服务器模式,注要大写)
    interface eth0      (实例网卡,也就是提供服务的网卡)
    virtual_router_id 51

    priority 100        (设定权值为100 主备之间的权值差最好大于50  权值范围为0~255)

    advert_int 1        (检查时间为1秒)
    authentication {        (认证方式为密码认证)
        auth_type PASS
        auth_pass 1111
}

    virtual_ipaddress {
     10.0.1.10          (10.0.1.10并不存在)       
    }
   
}

后面的内容不用改

按Esc键退出编辑模式

:wq


$ sudo mkdir -p /etc/rc.d/init.d

$ sudo cp /usr/share/initramfs-tools/scripts/functions /etc/rc.d/init.d/

$ sudo vi /etc/init.d/keepalived +23

按a或i进入编辑模式

daemon keepalived start  (默认为daemon keepalived ${KEEPALIVED_OPTIONS})

按Esc键退出编辑模式

:wq  (保存并退出)

$ sudo mkdir /var/lock/subsys   (注:这个目录重启服务器后会消失,需要将其写道开机启动项中,如写到/etc/rc.local里)

$ service keepalived start

开机自启动

$ sudo vi /etc/rc.local  (在exit 0前)

按a或i进入编辑模式

mkdir /var/lock/subsys

service keepalived start

按Esc键退出编辑模式

:wq (保存并退出)


$ sudo ip a   (可以看到eth0多了个10.0.1.10的ip)


ipvsadm部分:


$ sudo apt-get install ipvsadm

$ sudo ipvsadm -A -t 10.0.1.10:22 -s rr   (注rr为轮询模式)

$ sudo ipvsadm -a -t 10.0.1.10:22 -r 10.0.1.3:22 -g

$ sudo ipvsadm -a -t 10.0.1.10:22 -r 10.0.1.4:22 -g

$ sudo ipvsadm --save  (保存ipvsadm设置)

$ sudo ipvsadm -l (查看ipvsadm设置)

$ sudo ipvsadm -C  (清除ipvsadm设置)

$ sudo ipvsadm -a  (增加real服务器,如:$ sudo ipvsadm -a -t 10.0.1.10:22 -r 10.0.1.3:22 -g)

$ sudo ipvsadm -d   (删除real服务器,如:$ sudo ipvsadm -d -t 10.0.1.10:22 -r 10.0.1.3:22)


设置开机自启动:

$ sudo vi /etc/rc.local  (在exit 0上面)

按a或i进入编辑模式

ipvsadm -A -t 10.0.1.10:22 -s rr   (注rr为轮询模式)

ipvsadm -a -t 10.0.1.10:22 -r 10.0.1.3:22 -g

ipvsadm -a -t 10.0.1.10:22 -r 10.0.1.4:22 -g

ipvsadm --save

按Esc键退出编辑模式

:wq (保存并退出)



BACKUP服务器步骤同上,只需将/etc/keepalived/keepalived.conf里的MASTER改为BACKUP,priority改为50即可


BACKUP服务器ip a显示eth0没有多出10.0.1.10这个ip,等MASTER服务器宕后就会显示出来,当MASTER服务器正常后会自动消失



ipvsadm客户端(10.0.1.3)


$ sudo ifconfig lo:0 10.0.1.10 netmask 255.255.255.255 broadcast 10.0.1.10

$ sudo ip a (查看设置是否生效)

$ sudo route add -host 10.0.1.10 dev lo:0

$ sudo route -n  (查看设置是否生效)

$ sudo echo "1" > /proc/sys/net/ipv4/conf/lo/arp_ignore

$ sudo echo "1" > /proc/sys/net/ipv4/conf/all/arp_ignore

$ sudo echo "2" > /proc/sys/net/ipv4/conf/lo/arp_announce

$ sudo echo "2" > /proc/sys/net/ipv4/conf/all/arp_announce

设置开机自启动:

$ sudo vi /etc/rc.local  (在exit 0上面)

按a或i进入编辑模式

ifconfig lo:0 10.0.1.10 netmask 255.255.255.255 broadcast 10.0.1.10

按Esc键退出编辑模式

:wq (保存并退出)



ipvsadm客户端(10.0.1.4)


$ sudo ifconfig lo:0 10.0.1.10 netmask 255.255.255.255 broadcast 10.0.1.10

$ sudo ip a (查看设置是否生效)

$ sudo route add -host 10.0.1.10 dev lo:0

$ sudo route -n  (查看设置是否生效)

$ sudo echo "1" > /proc/sys/net/ipv4/conf/lo/arp_ignore

$ sudo echo "1" > /proc/sys/net/ipv4/conf/all/arp_ignore

$ sudo echo "2" > /proc/sys/net/ipv4/conf/lo/arp_announce

$ sudo echo "2" > /proc/sys/net/ipv4/conf/all/arp_announce

设置开机自启动:

$ sudo vi /etc/rc.local  (在exit 0上面)

按a或i进入编辑模式

ifconfig lo:0 10.0.1.10 netmask 255.255.255.255 broadcast 10.0.1.10

按Esc键退出编辑模式

:wq (保存并退出)



验证:


putty或ssh 10.0.1.10  (第一次登录的是10.0.1.3,第二次登录的是10.0.1.4)

本文转自linux博客51CTO博客,原文链接http://blog.51cto.com/yangzhiming/1441474如需转载请自行联系原作者


yangzhimingg

相关文章
|
Ubuntu 数据安全/隐私保护 Linux
|
负载均衡 算法 网络协议
Ubuntu构建LVS+Keepalived高可用负载均衡集群【生产环境部署】 推荐
1、环境说明: 系统版本:Ubuntu 14.04 LVS1物理IP:14.17.64.2   初始接管VIP:14.17.64.13 LVS2物理IP:14.17.64.3   初始接管VIP:14.17.64.14 真实web服务器IP:14.17.64.4-12 实现效果:去往14.17.64.13或14的报文,转发给14.17.64.4-12中的一台服务器处理,实现负载均衡。
1621 0
|
3月前
|
并行计算 Ubuntu Linux
Ubuntu学习笔记(五):18.04安装多版本CUDA
这篇博客文章介绍了在Ubuntu 18.04系统上如何安装和切换不同版本的CUDA,以及如何安装不同版本的cuDNN。
266 2
|
3月前
|
并行计算 PyTorch TensorFlow
Ubuntu安装笔记(一):安装显卡驱动、cuda/cudnn、Anaconda、Pytorch、Tensorflow、Opencv、Visdom、FFMPEG、卸载一些不必要的预装软件
这篇文章是关于如何在Ubuntu操作系统上安装显卡驱动、CUDA、CUDNN、Anaconda、PyTorch、TensorFlow、OpenCV、FFMPEG以及卸载不必要的预装软件的详细指南。
5427 3
|
11天前
|
JSON Ubuntu 开发者
ubuntu 22安装lua环境&&编译lua cjson模块
通过上述步骤,可以在 Ubuntu 22.04 系统上成功安装 Lua 环境,并使用 LuaRocks 或手动编译的方式安装 lua-cjson 模块。本文详细介绍了每一步的命令和操作,确保每一步都能顺利完成,适合需要在 Ubuntu 系统上配置 Lua 开发环境的开发者参考和使用。
57 13
|
8天前
|
监控 关系型数据库 MySQL
Ubuntu24.04安装Librenms
此指南介绍了在Linux系统上安装和配置LibreNMS网络监控系统的步骤。主要内容包括:安装所需软件包、创建用户、克隆LibreNMS仓库、设置文件权限、安装PHP依赖、配置时区、设置MariaDB数据库、调整PHP-FPM与Nginx配置、配置SNMP及防火墙、启用命令补全、设置Cron任务和日志配置,最后通过网页完成安装。整个过程确保LibreNMS能稳定运行并提供有效的网络监控功能。
|
18天前
|
Ubuntu Linux Docker
Ubuntu22.04上Docker的安装
通过以上详细的安装步骤和命令,您可以在Ubuntu 22.04系统上顺利安装
259 11
|
2月前
|
Ubuntu 开发工具 git
Ubuntu安装homebrew的完整教程
本文介绍了如何在没有公网的情况下安装 Homebrew。首先访问 Homebrew 官网,然后通过阿里云的镜像克隆安装脚本,并创建普通用户进行安装。接着修改 `install.sh` 文件指向国内镜像,执行安装命令。最后配置环境变量并更换 Homebrew 源为国内镜像,确保安装顺利。
390 50