设为首页 收藏本站

运维网

查看: 2756|回复: 0

[经验分享] FreeSWITCH折腾笔记7——使用keepalived进行主备切换高可用部署

[复制链接]

尚未签到

发表于 2018-12-28 14:08:22 | 显示全部楼层 |阅读模式
  freeSWITCH的高可用部署方式有两种:主备切换和负载均衡,官方文档介绍的主备切换部署是采用Corosync & Pacemaker,负载均衡采用前置opensips。但对使用keepalived进行主备切换的高可用方式没有介绍,同时网上对该种部署方式也没有介绍。
  本人对Corosync & Pacemaker不熟悉,目前在职的公司web应用大部分采用keepalived+haproxy,所以对keepalived稍微熟悉一点,因此尝试使用keepalived进行freeswitch进行主备切换的高可用部署。
  使用keepalived进行freeswitch进行主备切换的高可用部署比较简单,本文介绍的部署方案有两个亮点(自以为):1、主节点不抢占VIP,否则可能导致主节点恢复后VIP切换导致正在交互的SIP信令处理失败;2、FS可用性检测脚本和主备切换后话务接管脚本。
  
  一、前提
  1、freeswicth和keepalived均能通过服务启动;                       ——通过apt安装freeswitch和keepalived即可通过服务启动
  2、两个节点freeswitch连接同一个pgsql或者mysql数据库;      ——当然也可以是其他外部数据库
  二、环境
  os:debian 8
  A节点IP:172.16.100.10
  B节点IP:172.16.100.11
  VIP:172.16.100.12
  freeswitch域名:sofia.superpipi.cn  ——域名也可以直接使用VIP
  三、配置
  3.1 允许应用绑定非本机IP
  在两个节点均执行以下命令:
echo 'net.ipv4.ip_nonlocal_bind=1' >> /etc/sysctl.conf
sysctl -p  

  3.2 配置freeswitch
  修改“/usr/local/freeswitch/conf/vars.xml ” ——具体路径视实际情况
  将“local_ip_v4”的值修改为VIP:“172.16.100.12”
  将“domain”的值修改为:“sofia.superpipi.cn”
  3.3 配置keepalived
  keepalived默认配置文件路径“/etc/keepalived/keepalived.conf ”
  A节点keepalived配置:
! Configuration File for keepalived
global_defs {
   notification_email {
     acassen
   }
   notification_email_from Alexandre.Cassen@firewall.loc
   smtp_server 172.16.100.251
   smtp_connect_timeout 30
   router_id LVS_DEVEL
}
vrrp_script check_fs {
    script "/etc/keepalived/script/check_fs.sh"
    interval 1
    weight 2
}
vrrp_instance VI_1 {
    state BACKUP
    interface eth0
    garp_master_delay 10
    smtp_alert
    virtual_router_id 51
    priority 100
    nopreempt  #主节点不抢占VIP
    advert_int 1
    authentication {
        auth_type PASS
        auth_pass 1111
    }
    track_script {
        check_fs
    }
    virtual_ipaddress {
        172.16.100.12/24
        172.16.100.12/24 label eth0:1
    }
    notify_master "/etc/keepalived/script/fs_recover.sh"
}  B节点keepalived配置:
! Configuration File for keepalived
global_defs {
   notification_email {
     acassen
   }
   notification_email_from Alexandre.Cassen@firewall.loc
   smtp_server 172.16.100.251
   smtp_connect_timeout 30
   router_id LVS_DEVEL
}
vrrp_script check_fs {
    script "/etc/keepalived/script/check_fs.sh"
    interval 1
    weight 2
}
vrrp_instance VI_1 {
    state BACKUP
    interface eth0
    garp_master_delay 10
    smtp_alert
    virtual_router_id 51
    priority 50
    advert_int 1
    authentication {
        auth_type PASS
        auth_pass 1111
    }
    track_script {
        check_fs
    }
    virtual_ipaddress {
        172.16.100.12/24
        172.16.100.12/24 label eth0:1
    }
    notify_master "/etc/keepalived/script/fs_recover.sh"
}  3.4 检测脚本
  检测脚本路径:
mkdir -p /etc/keepalived/script/  检测可用性脚本
vim /etc/keepalived/script/check_fs.sh  
#!/bin/sh
FS_CLI_PROG='/usr/local/freeswitch/bin/fs_cli'
FS_CLI_HOST='127.0.0.1'
FS_CLI_PORT='8021'
FS_CLI_PASS='ClueCon'
PROFILES='sofia.superpipi.cn'
VIP='172.16.100.12'
fs_cli() {
  $FS_CLI_PROG -H $FS_CLI_HOST -P $FS_CLI_PORT -p $FS_CLI_PASS -x "$1"
}
sofia_profile_started() {
  fs_cli "sofia xmlstatus" | grep "$1" | wc -l
}
save_log(){
count=1
str_tmp="`date +%Y-%m-%d_%H:%M:%S` "
while [ $# -ge 1 ];do
str_tmp="$str_tmp $1"
count=count+1
shift
done
echo $str_tmp >>/var/log/check_fs_`date +%Y-%m-%d`.log
}
check_vrrp(){
ip a|grep $VIP|wc -l
}
check_fs_service(){
ps -ef |grep freeswitch.service|grep -v 'grep'|wc -l
}
#     fs_cli "sofia recover"
for p in $PROFILES; do
   if [ `sofia_profile_started "$p"` -eq 0 ]; then
     # echo "$p DOWN"
     log_str="$p DOWN"
     save_log $log_str
     if [ `check_vrrp` -eq 1 ];then
         save_log "本机已经绑定VRRP,即将重启keepalived和FreeSWITCH。"
         service keepalived restart
         save_log "vrrp切换完成!"
         if [ `check_fs_service` -eq 1 ];then
             save_log "freeswitch服务正在操作中。"
         else
            service freeswitch restart
            save_log "freeswitch重启成功!"
         fi
     else
         if [ `check_fs_service` -eq 1 ];then
             save_log "freeswitch服务正在操作中。 "
         else
             save_log "本机没有绑定VRRP,重启FreeSWITCH。"
             service freeswitch restart
             save_log "freeswitch重启成功!"
         fi
     fi
     exit 1
  fi
done
save_log "freeswitch状态检测:OK!"
#echo "OK"
exit 0  切换为主节点后恢复通话脚本
vim /etc/keepalived/script/fs_recover.sh#!/bin/sh
FS_CLI_PROG='/usr/local/freeswitch/bin/fs_cli'
FS_CLI_HOST='127.0.0.1'
FS_CLI_PORT='8021'
FS_CLI_PASS='ClueCon'
PROFILES='sofia.superpipi.cn'
VIP='172.16.100.12'
fs_cli() {
  $FS_CLI_PROG -H $FS_CLI_HOST -P $FS_CLI_PORT -p $FS_CLI_PASS -x "$1"
}
save_log(){
count=1
str_tmp="`date +%Y-%m-%d_%H:%M:%S` "
while [ $# -ge 1 ];do
str_tmp="$str_tmp $1"
count=count+1
shift
done
echo $str_tmp >>/var/log/check_fs_`date +%Y-%m-%d`.log
}
save_log "本节点切换为主用状态,开始接管切换前的通话。"
fs_cli "sofia recover"
fs_cli "raloadxml"
exit 0



运维网声明 1、欢迎大家加入本站运维交流群:群①:263444886群②:197202523群③:485755530群④:201730672群⑤:202807635运维网交流群⑥:281548029
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@yunvn.com 网址:www.iyunv.com

点击关注更多内容
您需要登录后才可以回帖 登录 | 立即注册  

本版积分规则  允许回帖邮件提醒楼主

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服 E-mail:kefu@yunvn.com

本站由青云提供云计算服务

运维网--中国最专业的运维工程师交流社区

京ICP备14039699号-1 Copyright © 2012-2020

使用手机软件扫描微信二维码

关注我们可获取更多热点资讯

Good good study day day up !


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!


独家合作伙伴: 青云cloud

快速回复 返回顶部 返回列表