骞没蕴 发表于 2018-12-28 14:08:22

FreeSWITCH折腾笔记7——使用keepalived进行主备切换高可用部署

  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


jackccj 发表于 2020-6-30 12:00:57

hello 我部署FS+Keepalived+mysql,遇到一个问题,那位遇到同样问题,并解决的帮忙看下,我这边在目前是主的一台freeswitch上做fsctl crash,然后浮动ip会自动切换到另外一台,但是fsctl recover或者sofia recover都不会切换会之前的通话,,,但是当我之使用其中一台freeswitch,当通话中,我手动fsctl crash,然后使用脚本自动启动freeswitch,通话可以继续恢复,,,二台freeswitch就不可以恢复通话,其他设置我有按官网设置完(https://freeswitch.org/confluence/display/FREESWITCH/High+Availability),,,帮忙看下二台做fsctl crash的实验,是否需要做其他什么设置尼,,,谢谢
页: [1]
查看完整版本: FreeSWITCH折腾笔记7——使用keepalived进行主备切换高可用部署