构建高可用服务器之一 Keepalive介绍及安装

简介:

    Keepalived 是一个基于VRRP协议来实现的LVS服务高可用方案,可以利用其来避免单点故障。一个mysqllvsnginx服务会有2台服务器运行Keepalived,一台为主服务器(MASTER),一台为备份服务器(BACKUP),但是对外表现为一个虚拟IP,主服务器会发送特定的消息给备份服务器,当备份服务器收不到这个消息的时候,即主服务器宕机的时候,备份服务器就会接管虚拟IP,继续提供服务,从而保证了高可用性。

以下简图为例,当服务调用mysql的时候,直接调用vip,这样即使master上宕机,依旧可访问从数据库。

wKioL1VaFzHDXH_IAADg7tHdTAY044.jpg

Keepalive的安装:

1、  安装环境包

1
[root@jacken ~] # yum  -y  install  kernel-devel openssl-devel  popt-devel

2、  安装keepalive

1
2
3
4
5
[root@jacken ~] #  wget http://www.keepalived.org/software/keepalived-1.1.15.tar.gz
[root@jacken ~] # tar -zxf keepalived-1.1.15.tar.gz
[root@jacken ~] # cd keepalived-1.1.15
[root@jacken keepalived-1.1.15] #./configure --with-kernel-dir=/usr/src/kernels/2.6.32-431.el6.x86_64/
[root@jacken ~] # make && make install

在编译选项中,“--sysconf”指定了Keepalived配置文件的安装路径.“--with-kernel-dir”是个很重要的参数,但这个参数并不是要把Keepalived编译进内核,而是指定使用内核源码中的头文件,即include目录。只有在使用LVS时,才需要用到“--with-kernel-dir”参数,其他时候是不需要的。

3、  设置keepalive

1
2
3
4
5
6
7
8
9
10
[root@jacken ~] # DIR=/usr/local/ ; cp$DIR/etc/rc.d/init.d/keepalived /etc/rc.d/init.d/
[root@jacken ~] # cp $DIR/etc/sysconfig/keepalived  /etc/sysconfig/ && mkdir -p /etc/keepalived
[root@jacken ~] # cp $DIR/sbin/keepalived  /usr/sbin/
[root@jacken ~] # cp /usr/local/etc/keepalived/keepalived.conf /etc/keepalived/
[root@jacken ~] # /etc/init.d/keepalivedrestart
Stopping keepalived:                                       [FAILED]
Starting keepalived:                                       [  OK  ]
[root@jacken ~] #modprobe ip_vs 
[root@jacken ~] #modprobe ip_vs_rr
[root@jacken ~] #modprobe ip_vs_wrr

Other

脚本配置文件:

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
[root@jacken ~] # chmod +xinstall_keepalive.sh
[root@jacken ~] # cat install_keepalive.sh
#!/bin/bash
yum -y   install   kernel-devel openssl-devel  popt-devel &&
wget http: //www .keepalived.org /software/keepalived-1 .1.15. tar .gz &&
tar  -zxf  keepalived-1.1.15. tar .gz &&
cd  keepalived-1.1.15 &&
. /configure  --with-kernel- dir = /usr/src/kernels/2 .6.32-431.el6.x86_64/ &&
make  &&  make  install  &&
DIR= /usr/local/
cp  $DIR /etc/rc .d /init .d /keepalived   /etc/rc .d /init .d/  &&
cp  $DIR /etc/sysconfig/keepalived  /etc/sysconfig/  &&  mkdir  -p  /etc/keepalived  &&
cp  $DIR /sbin/keepalived  /usr/sbin/ &&
cp  /usr/local/etc/keepalived/keepalived .conf  /etc/keepalived/  &&
/etc/init .d /keepalived  restart
if  [ $? - eq  0 ]; then
          echo  -e  '\e[32mInstall Keepalive Successfully!\e[0m'
else
          echo  -e  '\e[31mInstall Keepalive Failure!\e[0m'
fi
[root@jacken ~] #

其实这个不算是什么脚本,方便安装而已,一定要注意内核版本号要对应。


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

相关文章
|
10天前
|
网络安全 Apache
Apache服务器安装SSL证书
Apache服务器安装SSL证书
14 0
|
2月前
|
存储 Ubuntu 网络协议
|
1月前
|
缓存 网络协议 数据可视化
WinSCP下载安装并实现远程SSH本地服务器上传文件
WinSCP下载安装并实现远程SSH本地服务器上传文件
|
18天前
|
Ubuntu Linux 虚拟化
【Linux】ubuntu安装samba服务器
【Linux】ubuntu安装samba服务器
|
18天前
|
Linux
Linux安装bind9搭建自己的域名服务器
Linux安装bind9搭建自己的域名服务器
11 0
|
22天前
|
弹性计算 Serverless 数据库
ECS安装问题之docker安装如何解决
ECS(Elastic Compute Service,弹性计算服务)是云计算服务提供商提供的一种基础云服务,允许用户在云端获取和配置虚拟服务器。以下是ECS服务使用中的一些常见问题及其解答的合集:
|
29天前
|
Linux 数据安全/隐私保护 Docker
linux和windows中安装emqx消息服务器
linux和windows中安装emqx消息服务器
27 0
|
1月前
|
弹性计算 网络安全 文件存储
ECS热门应用 | 安装家用内网穿透服务
使用云服务器ECS,让家庭网络可以被外部网络访问。不在家时,也可以读取备份资料。
|
1月前
|
消息中间件 存储 Kafka
Kafka【环境搭建 02】kafka_2.11-2.4.1 基于 zookeeper 搭建高可用伪集群(一台服务器实现三个节点的 Kafka 集群)
【2月更文挑战第19天】Kafka【环境搭建 02】kafka_2.11-2.4.1 基于 zookeeper 搭建高可用伪集群(一台服务器实现三个节点的 Kafka 集群)
140 1
|
1月前
|
机器学习/深度学习 Python
Python基础:构建一个简单的Web服务器
Python基础:构建一个简单的Web服务器
51 1

热门文章

最新文章